Asp.NetCore轻松学-使用Supervisor进行托管部署

时间:2023-03-09 01:38:39
Asp.NetCore轻松学-使用Supervisor进行托管部署

前言

上一篇文章 Asp.NetCore轻松学-部署到 Linux 进行托管 介绍了如何在 Centos 上部署自托管的 .NET Core 应用程序,接下来的内容就是介绍如何使用第三方任务管理程序来托管 .NET Core 应用程序,这里以笔者常用的 Supervisor 为例子,从安装环境开始,一步一步的进入 Linux 的世界,部署程序还是以上一篇的项目文件 Deploy.Linux 为基础。

1. 安装前置条件

Centos 和 ubuntu 下,安装 supervisor 的步骤有所不同,在 Centos 下,需要先添加 Centos 下的扩展包源,

1.1 安装 Centos 扩展源
sudo yum install epel-release

Asp.NetCore轻松学-使用Supervisor进行托管部署

1.2. 安装 supervisor
sudo yum install supervisor
  • ubuntu 下使用 apt-get install supervisor 进行安装
1.3 supervisor 安装完成
  • 输入supervisord --version 查看安装已完成,

Asp.NetCore轻松学-使用Supervisor进行托管部署

注意是 supervisord 后面多了一个字符:d,因为安装的服务名称是:supervisord.service,通过命令查看服务文件可知道

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

Asp.NetCore轻松学-使用Supervisor进行托管部署

1.4 设置 supervisor 开机启动
sudo systemctl enable supervisord
sudo systemctl start supervisord
1.5 进入 supervisor 控制台执行命令
sudo supervisorctl

Asp.NetCore轻松学-使用Supervisor进行托管部署

进入 supervisor 控制台,表示服务安装成功,并已成功启动

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

2.1 查看配置文件目录

通过查看 cat /etc/supervisord.conf 看到 supervisor 引入配置文件的指定目录为

[include]
files = supervisord.d/*.ini

可以看到,默认的托管服务配置文件目录在 supervisord.d/ 下面,这个目录的完整地址是 /etc/supervisord.d/

2.2 建立配置文件 demo.ini

关于 supervisor 配置文件的含义,这里不做过多的解释,可移步官网查看帮助文档:http://www.supervisord.org/configuration.html,我们在这里只做一个最简单的配置文件,刚好够启动 .NET Core 应用程序即可

[program:demo]
command=/usr/bin/dotnet Deploy.Linux.dll ; 输入执行命令,这里表示 dotnet Deploy.Linux.dll
directory=/data/sites/demo/publish ; 应用程序根目录
autostart=true ; 是否自动启动,当 supervisor 加载该配置文件的时候立即启动它
autorestart=true ; 是否自动重启,当执行 dotnet Deploy.Linux.dll 启动失败时,会重复的自动重启
logfile_maxbytes=50MB ; 该配置文件输出单个日志文件的大小
logfile_backups=10 ; 日志备份个数
loglevel=info ; 记录日志级别
stderr_logfile=/data/logs/demo/demo.err.log ; 指定标准错误输出日志文件
stdout_logfile=/data/logs/demo/demo.out.log ; 指定标准输出日志文件
environment=ASPNETCORE_ENVIRONMENT=Production ; 可配置环境变量,该环境变量将通过执行 dotnet Deploy.Linux.dll 命令的时候传入到 .NET Core 应用程序中
user=root ;启动服务的用户
stopsignal=INT
redirect_stderr=true
  • 上面包含了几个关键的参数,都在注释中了,接下来建立日志目录,否则服务启动出错,输入命令
2.3 创建日志文件目录
sudo mkdir -p /data/logs/demo
2.4 重启 supervisor 服务,并进入 supervisorctl
sudo systemctl restart supervisord
sudo supervisorctl

Asp.NetCore轻松学-使用Supervisor进行托管部署

2.5 查看服务状态

输入站点地址:http://139.219.9.102/ 查看服务已正常启动

Asp.NetCore轻松学-使用Supervisor进行托管部署

2.6 查看日志输出

查看日志输出,定位到目录 /data/logs/demo 查看日志文件内容正常

Asp.NetCore轻松学-使用Supervisor进行托管部署

结束语

本文从零开始介绍如何使用 Supervisor,一步一步的从安装环境到编写托管服务文件,设置执行文件、执行文件目录、日志输出配置等细节,最终成功将 .NET Core 应用程序托管到了 Supervisor 中,文中都是通过命令形式进行安装部署,对于接触 Linux 比较少的同学来说,可能有些不适应,不过不要紧,这些都是很基础的命令,我们呢,就是要多学多用,达到熟悉和强化记忆,然后平滑过渡到 Linux 平台。