欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

asp.net core在CentOS上发布

程序员文章站 2022-06-02 22:42:02
...
CentOS环境信息:
CentOS 8
生成发布文件时的参数信息:

一、安装.Dotnet Core 2.2
在安装Dotnet Core前,需要注册Microsoft签名密钥并添加Microsoft产品提要,每台机器只需注册一次,执行如下命令:
sudo rpm -Uvh https://packages.microsoft.com/config/rhel/7/packages-microsoft-prod.rpm

安装Dotnet Core SDk,执行下列命令

sudo yum update
y
sudo yum install dotnet-sdk-2.2
y


安装完成后通过命令:
dotnet --info
来查看安装情况

二、部署Asp.net Core 应用程序

在CentOS系统中,新建publish文件夹(根目录下创建的)
mkdir publish


创建完成后用Xftp软件将本地发布好的文件上传到服务器的publish文件夹下
拷贝完成后进入publish目录
cd publish


使用命令:
ls
  查看上传上去的文件

检查是否能运行
dotnet 项目名.dll


如果出现xxxxxx Press Ctrl+C to shut down 就表明可以运行了
到此,项目就运行成功了,这时候我们是无法访问到这个页面的,这时候我们需要部署一个web容器来进行转发,我们可能还要安装 nginx 、配置我们的 FireWall 以及配置守护服务 Supervisor 等等

三、配置Nginx托管

  微软官方提供的https://docs.microsoft.com/zh-cn/aspnet/core/host-and-deploy/linux-nginx?view=aspnetcore-2.2#monitor-the-app,把dotnet创建成一个服务

  安装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


设置开机启动(linux宕机、重启会自动运行nginx不需要连上去输入命令)
systemctl enable nginx


成功提示信息:
Created symlink from /etc/systemd/system/multi-user.target.wants/nginx.service to /usr/lib/systemd/system/nginx.service.

四、配置防火墙
  查看防火墙状态:
sudo systemctl status firewalld


已开启的消息提示:Active: active (running) since Sat 2019-09-07 16:57:00 CST; 9min ago

  开放80端口:

firewall-cmd --permanent --zone=public --add-port=80-80/tcp

 

  重启防火墙以使配置即时生效:

systemctl restart firewalld

 
   检查测试nginx是否可以访问
在浏览器中输入本地虚拟机ip地址或者服务器的公网IP,如果能看到Welcome to nginx!则表示配置OK了

五、配置Nginx对ASP.net Core 应用的转发
 
  使用命令:
vi /etc/nginx/conf.d/default.conf

  修改Nginx的default.conf文件
  
  将文件内容替换为:
 
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;
    }
}


配置完成后,输入服务器或本机ip地址进行访问。检查是否能启动网站
我一次性成功。如果有502 Bad Gateway,请参考原文。

但是,我们还是存在着其他的问题:

  1.ASP.NET Core应用程序运行在shell之中,如果关闭shell则会发现ASP.NET Core应用被关闭,从而导致应用无法访问,这种情况当然是我们不想遇到的,而且生产环境对这种情况是零容忍的。

  2.如果ASP.NET Core进程意外终止那么需要人为连进shell进行再次启动,往往这种操作都不够及时。

  3.如果服务器宕机或需要重启我们则还是需要连入shell进行启动。

  为了解决这些问题,我们需要有一个程序来监听ASP.NET Core 应用程序的状况。

六、配置Supervisor守护服务

在应用程序停止运行的时候立即重新启动。这边我们用到了Supervisor这个工具,Supervisor使用Python开发的。

安装Supervisor:

yum install python-setuptools


配置Supervisor:

①运行supervisord 服务的时候,需要指定 Supervisor 配置文件,所以,先通过如下命令创建目录,以便让 supervisor 成功加载默认配置:

mkdir /etc/supervisor

②目录创建成功后, 通过 echo_supervisord_conf 程序(用来生成初始配置文件,文件名可以自定义)来初始化一个配置文件:

echo_supervisord_conf > /etc/supervisor/supervisord.conf

③通过vim命令修改创建好的supervisord.conf配置信息:

vi /etc/supervisor/supervisord.conf

④最下边找到如下文本片段:
;[include]
;files=relative/directory/*.ini


修改为:
;[include]
;files=/etc/supervisor/conf.d/*.ini


为我们部署的.NET Core添加进程配置文件:

①创建配置文件OAManager.ini(文件名自定义)

[program:OAManager]
command=dotnet /root/oa-publish/OAManager.dll
directory=/root/oa-publish/
autostart=true
autorestart=true
stderr_logfile=/var/log/OAManager.err.log
stdout_logfile=/var/log/OAManager.out.log
environment=ASPNETCORE_ENVIRONMENT=Production
user=root
stopsignal=INT

②在/etc/supervisor/目录下创建一个文件夹conf.d

mkdir /etc/supervisor/conf.d/

将刚创建的配置文件OAManger.ini移到conf.d文件夹下
mv OAManager.ini /etc/supervisor/conf.d/


如果服务已经启动,则需要使用 supervisorctl reload 命令来使新的配置生效,当然,我们这里并没有启动,所以不需要这一步。

  启动 Supervisor 服务

supervisord -c /etc/supervisor/supervisord.conf

启动服务后,我们可以检测看一下:

ps -ef | grep OAManager.dll


这个时候, 我们已经不需要使用dotnet命令运行程序, 同样可以访问我们部署的.NET Core程序了。

  至此关于ASP.NET Core应用程序的守护即配置完成。
七、配置Supervisor开机启动:

①进入/usr/lib/systemd/system/目录,并创建supervisord.service文件(或者在本地写好了再通过ftp工具传输到指定目录下)

vi /usr/lib/systemd/system/supervisord.service

  修改文件


[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

②设置开机启动

  激活开机启动:

systemctl enable supervisord

命令成功后,会出现Create ...字样

查看设置后的启动状态
systemctl is-enabled supervisord



  重启,测试是否可以开机自启

  好了。最终也成功的在重启之后,可以访问地址。


参考地址:https://www.cnblogs.com/i3yuan/p/11025672.html
https://www.cnblogs.com/sundahua/p/9149692.html