.NetCore项目nginx发布

举报
红目香薰 发表于 2022/10/28 00:26:52 2022/10/28
【摘要】 ​ ​编辑目录环境:服务器型号项目创建:添加自定义的API控制器修改访问路径示例代码配置跨域启动测试项目发布发布的项目准备服务器【Alibaba Cloud Linux 3.2104 LTS 64位 快速启动版】链接linux服务器安装ASP.Net Core3.1环境安装 SDK.NET版本验证直接启动安装nginx查看nginx.service状态命令:启动nginx.serviceng...

 编辑

目录

环境:

服务器型号

项目创建:

添加自定义的API控制器

修改访问路径

示例代码

配置跨域

启动测试

项目发布

发布的项目

准备服务器【Alibaba Cloud Linux 3.2104 LTS 64位 快速启动版】

链接linux服务器

安装ASP.Net Core3.1环境

安装 SDK

.NET版本验证

直接启动

安装nginx

查看nginx.service状态命令:

启动nginx.service

nginx文件位置

公网访问



我之前写过docker的,这里写一下nginx的发布方法:

环境:

系统:win10专业版

开发工具:Visual Studio 2019

.NET环境:.NET Core 3.1

项目:ASP.NET Core Web API

运行系统:Alibaba Cloud Linux 3.2104 LTS 64位 快速启动版

服务器:nginx

服务器型号

编辑


项目创建:

编辑

编辑

这里选择.NET Core 3.1版本,因为只有它是长期支持的,如果是vs2022版本是.NET Core 6.0那个很麻烦找配套。 

编辑

创建完毕 

编辑

添加自定义的API控制器

编辑

这里我用Test作为控制器名称。 

编辑

修改访问路径

【*】代表所有IP都能访问编辑

示例代码

using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace APIDemo20221020.Controllers
{
    [Route("api/[controller]/[action]")]
    [ApiController]
    public class TestController : ControllerBase
    {
        public Object GetInfo() {
            Dictionary<String, Object> map = new Dictionary<string, object>();
            map.Add("state",true);
            map.Add("message","访问成功");
            List<string> list=new List<string>();
            for (int i = 0; i < 100; i++)
            {
                list.Add(((char)(30000 + i)).ToString());
            }
            map.Add("result", list);
            return map;
        }
    }
}

配置跨域

ASP.NET Core微服务(三)——【跨域配置】_红目香薰的博客-CSDN博客

直接在Startup.cs中添加代码即可。

编辑

启动测试

编辑

编辑

访问:http://localhost:5000/api/Test/GetInfo

访问成功

编辑

项目发布

编辑

编辑

编辑

编辑

编辑

编辑

编辑

编辑

编辑

发布的项目

我的项目名叫做【APIDemo20221020】所以,应用程序叫做【APIDemo20221020.dll】编辑


准备服务器【Alibaba Cloud Linux 3.2104 LTS 64位 快速启动版】

编辑

链接linux服务器

编辑

安装ASP.Net Core3.1环境

Download .NET (Linux, macOS, and Windows)

编辑

选择.NET Core 3.1版本

编辑

选择图片中标注红色外框的选项。 

编辑

选择脚本安装

将 Microsoft 包签名密钥添加到受信任密钥列表,并添加 Microsoft 包存储库。

编辑

sudo rpm -Uvh https://packages.microsoft.com/config/centos/7/packages-microsoft-prod.rpm

编辑

安装 SDK

.NET SDK 使你可以通过 .NET 开发应用。 如果安装 .NET SDK,则无需安装相应的运行时。 若要安装 .NET SDK,请运行以下命令:这个版本支持.NET Core

sudo yum install aspnetcore-runtime-3.1 -y

不是很大,一会就安装完毕了。

编辑

.NET版本验证

dotnet --list-runtimes

编辑

上传linux-x64位版本的项目包

编辑

使用XFTP上传

编辑

直接启动

编辑

安装nginx

yum install nginx -y

编辑

由于nginx不是自动启动的,需要咱们启动一下。

查看nginx.service状态命令:

systemctl status nginx.service

编辑

启动nginx.service

systemctl start nginx.service
systemctl status nginx.service

编辑

nginx文件位置

nginx 日志文件 /var/log/nginx
nginx配置文件目录 /etc/nginx
nginx 可执行文件 /usr/sbin/nginx
nginx环境配置 /etc/sysconfig/nginx
nginx默认站点目录 /usr/share/nginx/html

公网访问

编辑

修改配置

vi /etc/nginx/nginx.conf

编辑

修改到项目路径,输入【i】进行insert模式,修改完毕后按【ESC】加【:wq】进行保存。


这里看到有【;】,不要忘记。保存并重新启动。

这里我给了我修改server的全部编码。当然,端口号是65535里找不常用的随便用都行。

    server {
        listen       8080;
       # listen       [::]:80;
        server_name  _;
#        root         /usr/share/nginx/html;
        location / {
        proxy_pass http://localhost:5000;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection keep-alive;
        proxy_set_header Host $host;
        proxy_cache_bypass $http_upgrade;
        }
        root /root/linux-x64;
        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        error_page 404 /404.html;
            location = /40x.html {
        }

        error_page 500 502 503 504 /50x.html;
            location = /50x.html {
        }
    }

编辑


重新启动并运行【do】

systemctl restart nginx.service
dotnet APIDemo20221020.dll

编辑

访问成功

编辑

如果访问不了就行没开安全组: 

编辑

我这里是全部,肯定是能访问的。 

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。