.Net Core - 使用Supervisor进行托管部署

环境

CentOS 7 x64,详见 安装CentOS7虚拟机

.Net Core 2.1.801 详见 CentOS 7 下安装.NET Core SDK 2.1

 

辅助工具

Xftp上传文件到CentOS (账号密码通常为安装CentOS时设置的root账号和密码,也可另外设置,详细见:CentOS7 FTP安装与配置

PuTTY工具连接CentOS, 安装包下载

一、安装配置supervisor  

如果需要卸载supervisor 执行:

yum remove supervisor

 查看是否已卸载(查看supervisor版本)

supervisord -v

1.执行下列命令安装supervisor

wget https://mirrors.tuna.tsinghua.edu.cn/epel/epel-release-latest-7.noarch.rpm
rpm -ivh epel-release-latest-7.noarch.rpm
yum install supervisor -y

如提示“。。。。To connect to mirrors.tuna.tsinghua.edu.cn insecurely, use `--no-check-certificate'.”  则 在后面加一下 --no-check-certificate

  

wget https://mirrors.tuna.tsinghua.edu.cn/epel/epel-release-latest-7.noarch.rpm --no-check-certificate

如报“-bash: wget: 未找到命令”,则先安装一下 yum 命令,再执行上面的命令

yum -y install wget

2.查看版本,检验是否安装成功

supervisord -v

3.配置

修改supervisor配置文件

vim /etc/supervisord.conf

修改以下几行

#启用访问web控制界面,inet_http_server区段修改为
[inet_http_server]        
port=*:9001     

#设置账户和密码
username=user 
password=123     

 

 

4.启动supervisord服务

开机自动启动

sudo systemctl enable supervisord

启动

sudo systemctl start supervisord

其他命令:

如果修改了/etc/supervisord.conf 文件,可以通过reload命令来重新加载配置文件

重启命令:

sudo supervisorctl reload

停止命令:

sudo systemctl stop supervisord

  

5.防火墙设置

开放端口

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

重启防火墙

firewall-cmd --reload

查看已开放的端口

firewall-cmd --list-ports

 

6.输入 http://ip:9001,提示需要输入密码,用户名为user,密码123

查询本机ip命令:

ip addr

 

 

二、部署.net core 2.1项目

1.准备好.net core项目

 

 

 添加host.json文件,设置端口号(可以改成其他端口号)

   

{
  "url": "http://*:2222"
}

 修改Program.cs

  

 public static IWebHostBuilder CreateWebHostBuilder(string[] args)
 {
     var configuration = new ConfigurationBuilder().SetBasePath(Environment.CurrentDirectory)
                                          .AddJsonFile("host.json")
                                          .Build();
     var url = configuration["url"];
     return WebHost.CreateDefaultBuilder(args).UseUrls(url).UseStartup<Startup>();
}

确保你的项目运行正常

2.发布

发布前,先修改“HelloWeb.csproj.user”文件,加上如下内容(你也可以不用加):

 

 

<MvcRazorCompileOnPublish>False</MvcRazorCompileOnPublish>

 右键项目->发布 

 

  不加“<MvcRazorCompileOnPublish>False</MvcRazorCompileOnPublish>”的发布效果 

 

 加“<MvcRazorCompileOnPublish>False</MvcRazorCompileOnPublish>”的发布效果

本文发布方式使用了加“<MvcRazorCompileOnPublish>False</MvcRazorCompileOnPublish>” 

3.使用ftp工具上传到CentOS服务器,这里使用Xftp工具上传

新建文件夹“helloweb”

  

复制已发布的文件到helloweb

 

4.检测文件是否可正常运行

cd /home/vsftpd/admin/helloweb
ls

 用dotnet命令运行项目

dotnet HelloWeb.dll

如出现上面提示则表示可以正常运行

按Ctrl+C退出来

5.创建 supervisor 托管的 .NET Core 的服务配置文件

切换到supervisor的统一配置目录,注意这里的supervisord多了个“d”

cd /etc/supervisord.d

创建配置文件helloweb.ini (注意后缀为.ini,与上面配置supervisor的第3点的include区段的文件后缀设置一致

vim helloweb.ini
[program:helloweb]
command=/usr/bin/dotnet  HelloWeb.dll ; 输入执行命令,这里表示 dotnet  HelloWeb.dll
directory=/home/vsftpd/admin/helloweb ; 应用程序根目录
autostart=true ; 是否自动启动,当 supervisor 加载该配置文件的时候立即启动它
autorestart=true ; 是否自动重启,当执行 dotnet  Deploy.Linux.dll 启动失败时,会重复的自动重启
logfile_maxbytes=50MB ; 该配置文件输出单个日志文件的大小
logfile_backups=10 ; 日志备份个数
loglevel=info ; 记录日志级别
stderr_logfile=/home/vsftpd/admin/helloweb/helloweb.err.log ; 指定标准错误输出日志文件,前面的目录可改成其他的,但要确保该目录已存在 
stdout_logfile=/home/vsftpd/admin/helloweb/helloweb.out.log ; 指定标准输出日志文件 ,前面的目录可改成其他的,但要确保该目录已存在 
environment
=ASPNETCORE_ENVIRONMENT=Production ; 可配置环境变量,该环境变量将通过执行 dotnet HelloWeb.dll 命令的时候传入到 .NET Core 应用程序中 user=root ;启动服务的用户 stopsignal=INT redirect_stderr=true

更新新的配置到 supervisord  (这种方式不会影响之前已运行中的其他的配置的程序)

supervisorctl update

其他命令:

重新启动配置中的所有程序:

# supervisorctl reload

 

启动某个进程(program_name=你配置中[program:xxxx]写的程序名称,例如:helloweb )

supervisorctl start program_name

本文这里启动的操作是: supervisorctl start helloweb

查看正在守候的进程

supervisorctl

(退出查看进程命令是: exit )

停止某一进程 (program_name=你配置中[program:xxxx]写的程序名称,例如:helloweb )

spervisorctl stop program_name

重启某一进程 (program_name=你配置中[program:xxxx]写的程序名称,例如:helloweb)

supervisorctl restart program_name

停止全部进程

supervisorctl stop all

注意:用stop停止掉的进程,用reload或者update都不会自动重启。

  

6.防火墙设置

开放端口:

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

重启防火墙:

firewall-cmd --reload

7.重新访问Supervisor,输入 http://ip:9001

出现绿色的“running”表示成功,名称“helloweb”就是刚刚的helloweb.ini配置中的[program:helloweb] 的program:后面定义的名称

  

访问helloweb的站点网址:http://ip:2222

8.更新部署

如果需更新 dll文件,复制dll覆盖原dll后,点一下“Restart”即可

 

 

  

posted @ 2019-09-04 15:34  hellocjr  阅读(1411)  评论(0编辑  收藏  举报