ASP.NET Core部署到Linux服务器(CentOS7 x64)

ASP.NET Core部署指南
本文详细介绍了如何将ASP.NET Core网站逐步部署到Linux服务器的过程,包括项目创建、发布、服务器软件安装、Nginx配置、守护进程设置及开机自启等关键步骤。

前言

  本文主要讲解如何一步步将ASP.NET Core网站发布到Linux服务器,文中会讲解具体步骤及需要避免的各种问题。


 

目录

  一、环境介绍

  二、创建及发布ASP.NET Core网站项目

  三、服务器软件安装(.NET Core SDK)

  四、在服务器上部署ASP.NET Core网站项目

  五、服务器端配置Nginx

  六、配置服务器端的守护进程(Supervisor)

  七、设置守护程序为开机自启

 


 

环境介绍

  本机所需开发工具: vs2017、XShell 、FileZilla(不限定,可使用其他上传工具)

  服务器系统及所需软件:CentOS7、.Netcore、Nginx、Supervisor、Policycoreutils-python


 

创建及发布ASP.NET Core网站项目

  打开vs2017,选择 文件->新建->项目,选择ASP.NET Core Web应用程序(.NET Core),在ASP.NET Core 1.1 模板处选择 Web应用程序

  

  

  此时ASP.NET Core 网站项目已建立完成,直接F5运行,可以在浏览器中看到如下页面

  

  回到vs2017,右键项目->发布,选择文件夹,文件夹名称更改为MyWebCore(可以不更改,默认名为PulishOutput,默认路径为bin\Release)点击发布后,可以在发布时填写的文件夹下找到发布的文件

  

  ASP.NET Core 网站发布完成,进行下一步


 

 服务器软件安装(.NET Core SDK)

 

  通过XShell登录Linux服务

  执行下列命令,安装.NET Core SDK(微软官方教程地址 https://www.microsoft.com/net/core#linuxcentos)   

 sudo yum install libunwind libicu
 curl -SSL -o dotnet.tar.gz https://go.microsoft.com/fwlink/?linkid=843449  sudo mkdir -p /opt/dotnet && sudo tar zxf dotnet.tar.gz -c /opt/dotnet  sudo ln -s /opt/dotnet/dotnet /usr/local/bin

  执行下列命名,返回版本号即表示.NET Core SDK已经安装成功   

 dotnet -–version

  

  .NET Core SDK安装完成,进行下一步


在服务器上部署ASP.NET Core网站项目

  找到本地发布好的ASP.NET Core项目(bin\Release\MyWebCore),使用FileZilla(可以使用其他上传工具)将MyWebCore文件夹整个上传至服务器(具体上传到什么位置可以自定义,此处使用/usr/myweb/文件夹)

  确保文件都成功上传之后,就可以进行在Linux服务器的部署了

  执行下列命令,部署ASP.NET Core网站  

 cd /usr/myweb/MyWebCore
 dotnet MyWebCore.dll

  出现如下信息,即表示网址已部署成功

  

  (注:ASP.NET Core 默认端口为5000,可以在项目中通过配置自定义端口,此处不做过多介绍)

  此时是无法访问到这个页面的,需要部署一个web容器来进行转发(即需要为Linux服务器配置Nginx)  

  ASP.NET Core网站部署完成,进行下一步


服务器端配置Nginx

  执行下列命令,安装Nginx  

 curl -o  nginx.rpm http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
 rpm -ivh nginx.rpm
 yum install nginx

  成功安装Nginx之后继续执行下列命令  

 systemctl start nginx        //启动Nginx
 systemctl enable nginx  //将Nginx设置为开机自启

  执行下列命令,配置防火墙

 firewall-cmd --zone=public --add-port=80/tcp --permanent    //开放80端口
 systemctl restart firewalld  //重启防火墙,使配置生效

  此时在浏览器输入服务器IP地址,测试Nginx是否可以访问

  

  Nginx可以正常访问,接下来开始配置Nginx对我们所部署的ASP.NET Core应用的转发

  找到Nginx配置文件nginx.conf(我的是在/ect/nginx/目录下)下载到本地,并将其server{}中的内容进行如下修改(建议先备份)  

server {
    listen 80;
    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.conf回传至服务器进行覆盖

  执行下列命令,使修改后的文件生效  

 nginx -s reload

  执行下列命令,启动ASP.NET Core网站

 cd /usr/myweb/MyWebCore
 dotnet MyWebCore.dll

  浏览器输入网址进行访问

  如果出现502错误,执行下列命令,将Nginx添加至白名单,然后再重启启动ASP.NET Core  

 yum install policycoreutils-python
 sudo cat /var/log/audit/audit.log | grep nginx | grep denied | audit2allow -M mynginx
 sudo semodule -i mynginx.pp

  

  Nginx配置完成,进行下一步


 

 配置服务器端的守护进程(Supervisor)

  为避免Shell退出后仍然可以继续访问网站,我们需要守护进程(Supervisor)来监控ASP.NET Core网站,以保证其长久健康的运行

  执行下列命令,安装Supervisor  

 yum install python-setuptools
 easy_install supervisor

  执行下列命令,配置Supervisor 

 mkdir /etc/supervisor  //此处也可以使用上传工具手动创建文件夹 
 echo_supervisord_conf > /etc/supervisor/supervisord.conf
 mkdir /etc/supervisor/conf.d

 

  修改supervisord.conf,对文件最后部分的内容进行修改

//原内容
;[include]
;files = relative/dictory/*.ini
//新内容 
[include]
files = conf.d/*.conf   //此处也可以是*.ini
//注意以上内容不要有;

  创建MyWebCore.conf文件(也可以是*.ini,需跟上一步保持一致),填写如下内容  

[program:MyWebCore]
command=dotnet MyWebCore.dll ;
directory=/usr/myweb/MyWebCore ;
autorestart=true ;
stderr_logfile=/var/log/MyWebCore.err.log ;
stdout_logfile=/var/log/MyWebCore.out.log ; environment=ASPNETCORE_ENVIRONMENT=Production ; user=root ; stopsignal=INT

  将MyWebCore.conf文件拷贝至下列目录  

  /etc/supervisor/conf.d/

  执行下列命令,查看是否生效

supervisord -c /etc/supervisor/supervisord.conf
ps -ef | grep MyWebCore

  

  如果存在 dotnet MyWebCore.dll进程,则表示运行成功

  配置文件如有修改,执行下列命令更新(没有则忽略)  

  supervisorctl reload

  此处可能出现的问题(没有则忽略)

  --重复的监听,会提示如下错误  
    another program is already listening on a port that one of our HTTP servers is configured to use

   --解决方法  

ps -ef | grep supervisord  //查看监听的端口,出现以下信息
root   2503  1  0 Nov19 ?  00:03:23 /usr/bin/python /usr/bin/supervisord
root   21337 2556  0 18:15 pts/8   00:00:00 grep --color=auto supervisord
kill -s SIGTERM 2503  
 在浏览器中进行访问

  

  守护进程Supervisor配置完成,进行下一步


 

 设置守护程序开机自启

  如果服务器宕机,重新启动后我们希望守护程序可以自启,那么需要做以下操作

  新建supervisord.service文件,并写入以下内容  

# dservice for systemd (CentOS 7.0+)
# by ET-CS (https://github.com/ET-CS)
[Unit]
Description=Supervisor daemon

[Service]
Type=forking
ExecStart=/usr/bin/supervisord -c /etc/supervisor/supervisord.conf
ExecStop=/usr/bin/supervisorctl shutdown ExecReload=/usr/bin/supervisorctl reload KillMode=process Restart=on-failure RestartSec=42s [Install] WantedBy=multi-user.target

  将supervisord.service文件上传至服务器下列目录  

  /usr/lib/systemd/system/

  执行下列命令,将supervisor设为开机启动  

  systemctl enable supervisord

  执行下列命令,验证设置是否成功

  systemctl is-enabled supervisord

  返回enabled即为成功,可以执行重启Linux服务器来进行验证  

  reboot

  至此,ASP.NET Core网站部署到Linux服务器的操作全部完成。

 

转载于:https://www.cnblogs.com/iamzl/p/7363766.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值