CentOS+Linux部署.NET Core应用程序

工具:

WinSCP+Xshell+VMware

1.安装CentOS

省略安装过程...

2. 安装.Net Core Sdk

①更新可用的安装包:sudo yum update

②安装.NET需要的组件,libunwind和libicu库:sudo yum install libunwind libicu

③安装.NET SDK(ps:我的开发环境是2.2.300,cmd:dotnet –version查看):

sudo yun install dotnet-sdk-2.2

④安装完成之后,检测是否安装成功

dotnet --version

3.使用Visual Studio 2019发布WebApi应用程序

 

4.部署应用程序至CentOS服务器

这里使用WinSCP工具操作。

将发布程序拖到想的任一文件夹下

5.运行发布程序

进入部署对应的文件下面运行对应dll,就可以正常run起来。

 

6.配置守护进程Supervisor

 上面的操作已经能正常将.NET Core程序发布到CentOS下来, 但是发布过程中我们也发现了问题, 就是.NET Core不能自动的运行, 一旦我们的命令行工具关掉, 发布的程序就不能访问了;

 Supervisor 是用Python开发的Linux/Unix系统下的一个进程管理工具。它可以使进程(类似Windows Service)脱离终端,变为后台守护进程(daemon)。能实时监控进程状态,异常退出时能自动重启。

6.1.安装Supervisor

yum install python-setuptools

easy_install supervisor

6.2.配置Supervisor

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

mkdir /etc/supervisor

②初始化配置文件:

echo_supervisord_conf > /etc/supervisor/supervisord.conf

③修改supervisord.conf配置信息:

vi /etc/supervisor/supervisord.conf

④最下边找到如下文本片段:

修改为:

注意:文件存放的目录,最好写明从根目录开始。

该操作的目的是我们创建一个supervisor 进程配置文件加载目录。让supervisor自动加载该目录下 .ini 后缀的文件作为服务配置

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

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

②在此文件加下创建uiorderapi.ini(名称随便取)文件

③配置uiorderapi.ini文件

 默认 80端口,我这边指定8082端口

 1 [program:uiorderapi]
 2 command=dotnet eHi.UI.Order.Api.dll --urls http://*:8082  --environment "Dev"      ; the program (relative uses PATH, can take args)
 3 ;process_name=%(program_name)s ; process_name expr (default %(program_name)s)
 4 ;numprocs=1                    ; number of processes copies to start (def 1)
 5 directory=/root/www                ; directory to cwd to before exec (def no cwd)
 6 ;umask=022                     ; umask for process (default None)
 7 ;priority=999                  ; the relative start priority (default 999)
 8 ;autostart=true                ; start at supervisord start (default: true)
 9 ;startsecs=1                   ; # of secs prog must stay up to be running (def. 1)
10 ;startretries=3                ; max # of serial start failures when starting (default 3)
11 ;autorestart=unexpected        ; when to restart if exited after running (def: unexpected)
12 ;exitcodes=0,2                 ; 'expected' exit codes used with autorestart (default 0,2)
13 ;stopsignal=QUIT               ; signal used to kill process (default TERM)
14 ;stopwaitsecs=10               ; max num secs to wait b4 SIGKILL (default 10)
15 ;stopasgroup=false             ; send stop signal to the UNIX process group (default false)
16 ;killasgroup=false             ; SIGKILL the UNIX process group (def false)
17 ;user=chrism                   ; setuid to this UNIX account to run the program
18 ;redirect_stderr=true          ; redirect proc stderr to stdout (default false)
19 ;stdout_logfile=/a/path        ; stdout log path, NONE for none; default AUTO
20 ;stdout_logfile_maxbytes=1MB   ; max # logfile bytes b4 rotation (default 50MB)
21 ;stdout_logfile_backups=10     ; # of stdout logfile backups (0 means none, default 10)
22 ;stdout_capture_maxbytes=1MB   ; number of bytes in 'capturemode' (default 0)
23 ;stdout_events_enabled=false   ; emit events on stdout writes (default false)

6.4 启动 Supervisor 服务

supervisord -c /etc/supervisor/supervisord.conf

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

6.5配置Supervisor开机启动

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

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

 1 [Unit]
 2 Description=supervisor  daemon
 3 After=network.target
 4 
 5 [Service]
 6 Type=forking
 7 ExecStart=/usr/bin/supervisord -c /etc/supervisor/supervisord.conf
 8 ExecStop=/usr/bin/supervisorctl $OPTIONS shutdown
 9 ExecReload=/usr/bin/supervisorctl $OPTIONS reload
10 KillMode=process
11 Restart=on-failure
12 RestartSec=42s
13 
14 [Install]
15 WantedBy=multi-user.target

设置开机启动

systemctl enable supervisord.service

systemctl daemon-reload

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

 

7.Supervisor端口号设置

①查看当前所有开放的端口sudo firewall-cmd --list-ports

 

②添加端口到防火墙(这里已8082端口为例)sudo firewall-cmd --zone=public --add-port={port}/tcp --permanent 

③重启防火墙,使配置生效sudo firewall-cmd --reload

④查看是否已经增加sudo firewall-cmd --list-ports

⑤更新supervisor配置文件,保存并执行sudo supervisorctl update

coredemo 详细X
  没有英汉互译结果
  请尝试网页搜索

 

 若无法访问重启防火墙 systemctl restart firewalld.service 

 

 

posted on 2019-07-25 10:10  无痕~  阅读(465)  评论(0)    收藏  举报

导航