ASP.NET Core多平台部署 (Windows Server+IIS与CentOS 7+Nginx)

一,Windows Server+IIS部署

1,安装配置IIS,这个应该都不用多说了,教程一堆

2,下载安装.NET Core Runtime 与 .NET Core SDK,下载请点击下载地址,如图

3,打开IIS管理器,应用程序池——添加应用程序池,名称随意,.NET Framework版本选择无托管代码托管管道模式选择集成,如下图

4,网站——添加网站

  • 网站名称
  • 应用程序池,选择上一步创建的无托管代码的应用程序池
  • 物理路径选择你发布的项目的所在路径
  • 绑定-绑定主机名,绑定你解析的域名

 

5,浏览刚才创建的网站,访问成功

二,CentOS 7+Nginx

 前言:之前没接触过Linux平台,下面的内容纯属个人见解,莫见笑

1,服务器连接工具,Xshell 6,协议SSH,用户身份验证,输入账户,密码,连接

2,安装.NET Core运行环境,NET Core Runtime 与 .NET Core SDK,安装请点击下载地址,如图

  

3,项目上传到服务器,推荐使用FileZilla连接服务器管理文件

  • 打开FileZilla
  • 文件-新建站点
  • 协议使用SSH,输入主机名(IP),用户名,密码,点击连接
  • 连接成功,菜单-服务器,开启 强制显示隐藏文件
  • 本地文件与服务器文件实现互通上传,下载,删除等操作

4,项目通过FileZilla上传到服务器后,使用Xshell 6使用命令cd到项目所在的路径

使用.net core的运行命令,运行启动项目的dll文件

dotnet xxxxxxxx.dll

项目运行成功后,即可以通过IP+端口号访问项目了,假如访问不到注意是否是阿里云服务器的端口是否打开,或者是服务器的防火墙端口是否打开

注:ASP.NET Core默认的端口号是5000,可以通过修改项目的Program.cs文件,修改端口号

WebHost.CreateDefaultBuilder(args)
                .UseUrls("http://*:5001")//修改默认端口
                .UseStartup<Startup>();

注:这里有个问题就是当你把Xshell 6关闭后,项目也没办法访问了。。。这里得用另外一个命令保持后台常驻

nohup dotnet xxxxxxxx.dll &

如果需要关闭这个进程,可以通过lsof加项目的端口号查找进程信息

lsof -i:5005

再通过kill -9 id杀死这个进程,项目就无法访问了

kill -9 17377

5,安装Nginx为项目绑定域名

      由于对Linux命令不熟悉,又不想花太多的心思在服务器上,我这里选择服务器安装 宝塔Linux  去界面化管理服务器

  • 安装宝塔Linux,点击进入宝塔Linux官网
  • 选择 宝塔Linux 免费版,查看页面底部的安装发放
  • 选择CentOS脚本安装,复制命令,使用Xshell 6粘贴执行命令
  • 等待宝塔Linux安装完毕
  • 安装的最后一步会显示宝塔Linux的登录地址与初始账号密码,登录地址默认是服务器IP地址加上8888端口号    http://IP地址:8888
  • 打开宝塔Linux的链接,输入初始账户密码,登录成功后可以修改账号密码

4,通过宝塔的软件商店,安装Nginx,打开Nginx,配置修改

在Nginx加以下配置

# http 80端口
server {
     listen 80; #监听80端口
     server_name www.baidu.com; #绑定解析的域名
     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;
     }
}

5,增加https访问,把SSL证书文件放到 /www/server/nginx/conf/cert 路径下,使用以下配置

# http80端口兼容https443端口
server {
     listen 80 default_server; #监听80端口,作为默认网站,即使用ip访问时默认出现的站点
     listen 443 ssl; #同时监听443端口为ssl
     server_name www.baidu.com;
     #配置证书段,证书放在nginx安装目录的conf/cert目录下。
     ssl_certificate cert/xxxxxxxxxx.pem; #证书pem
     ssl_certificate_key cert/xxxxxxxx.key;#证书key
     ssl_session_timeout 5m;
     ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
     ssl_ciphers ALL:!DH:!EXPORT:!RC4:+HIGH:+MEDIUM:-LOW:!aNULL:!eNULL;
     ssl_prefer_server_ciphers on;
     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;
     }   
    }

 注:点击保存,Nginx会自动重启服务,如需手动启动切换到服务选项卡里重载配置

原文地址:https://www.cnblogs.com/zhangchunyu/p/11065191.html