银河麒麟V10安装ASP.NET Core并配置Supervisor让网站开机自动运行
银河麒麟高级服务器操作系统V10是针对企业级关键业务,适应虚拟化、云计算、大数据、工业互联网时代对主机系统可靠性、安全性、性能、扩展性和实时性的需求,依据CMMI 5级标准研制的提供内生安全、云原生支持、国产平台深入优化、高性能、易管理的新一代自主服务器操作系统;同源支持飞腾、龙芯、申威、兆芯、海光、鲲鹏等自主CPU及x86平台;可支撑构建大型数据中心服务器高可用集群、负载均衡集群、分布式集群文件系统、虚拟化应用和容器云平台等,可部署在物理服务器和虚拟化环境、私有云、公有云和混合云环境;应用于政府、国防、金融、教育、财税、公安、审计、交通、医疗、制造等领域。--来自官网介绍(http://www.kylinos.cn/scheme/server/1.html)
在产品试用页面填写完申请后,可以下载试用版银河麒麟服务器版操作系统(试用期一年,试用地址http://www.kylinos.cn/support/trial.html)。
本文章采用的是x86架构的银河麒麟操作系统。
安装完成后,银河麒麟自带GUI图形桌面
安装时设置好密码后,会自动启动SSH管理,使用SSH管理工具即可远程连接管理。
在根目录下建立一个文件夹upload,把以下文件上传到此目录
aspnetcore-runtime-3.1.11-linux-x64.tar.gz(https://dotnet.microsoft.com/download/dotnet-core/3.1)
1 2 | rpm -Uvh https: //packages .microsoft.com /config/centos/7/packages-microsoft-prod .rpm yum install aspnetcore-runtime-3.1 |
setuptools-53.0.0.tar.gz(https://pypi.org/project/setuptools/)
supervisor-4.2.1.tar.gz(https://pypi.org/project/supervisor/#files)
libgdiplus-6.0.5.tar.gz(http://download.mono-project.com/sources/libgdiplus/libgdiplus0-6.0.4.tar.gz)
我们先安装libgdiplus,因为网站登录需要显示验证码,显示验证码调用System.Draw时需要libgdiplus支持。
(如果直接使用yum按照,需要先rpm -ivh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm按安装这个源,然后在yum install libgdiplus)
我们可以直接用CentOS的包管理工具yum来进行安装,需要注意的是银河麒麟不支持第三方的软件源(国内阿里、163等镜像源都不可用)
1 2 | yum install autoconf automake libtool yum install libjpeg-turbo-devel libpng-devel giflib-devel libtiff-devel libexif-devel |
进入到libgdiplus解压缩后的目录,然后执行
1 2 3 4 5 | . /autogen .sh --prefix= /usr/local/lib . /configure --prefix= /usr/local/lib make make install ldconfig |
安装完成后需要在/etc/ld.so.conf.d下建立一个文件(如local.conf),内容填写上/usr/local/lib(此目录请以当时make install时输出的最终安装路径为准),然后用root权限执行ldconfig。这样调用相应的so文件就会在/usr/local/lib中搜索了。
解压缩setuptools-53.0.0.tar.gz和supervisor-4.2.1.tar.gz
先安装setuptools-53.0.0(需要Python3.6支持,银河麒麟默认是3.7可以直接安装)
1 2 | cd setuptools-53.0.0 python3 setup.py install |
然后安装supervisor-4.2.1
1 2 | cd .. /supervisor-4 .2.1/ python3 setup.py install |
安装完成后,进入到后/usr/lib64/python3.7目录,执行
1 | echo_supervisord_conf > /etc/supervisord .conf |
就会在/etc/目录下生成supervisord.conf配置文件。然后建立一个目录/var/supervisord,用来保存supervisord运行时生成的三个文件保存路径,并在此目录中保存要守护的程序的配置文件(也可以另外建立一个目录)
然后分别执行
1 2 3 4 5 6 | touch /var/supervisord/supervisor .sock touch /var/supervisord/supervisor .log touch /var/supervisord/supervisor .pid chmod 777 /var/supervisord/supervisor .sock chmod 777 /var/supervisord/supervisor .log chmod 777 /var/supervisord/supervisor .pid |
然后vim /etc/supervisord.conf 把配置文件中的supervisor.sock、supervisor.log、supervisor.pid三个文件的保存位置改为刚建立的三个文件位置
在文件最后打开守护程序配置所在目录
完成后保存退出。然后建立一个Supervisor的启动脚本(vim /lib/systemd/system/supervisord.service)然后填入以下内容保存退出。
1 2 3 4 5 6 7 8 9 10 11 | [Unit] Description=Process Monitoring and Control Daemon After=rc- local .service [Service] Type=forking ExecStart=supervisord -c /etc/supervisord .conf SysVStartPriority=99 [Install] WantedBy=multi-user.target |
然后执行systemctl enable supervisord.service来设置开机自动启动服务,接着重启服务器,然后我们运行ps -ef |grep supervisord即可看到supervisor已经开机自动启动
接着我们按照微软官网上的教程安装ASP.NET Core3.1运行时(本次上传路径在/upload下)
1 2 3 | mkdir -p "$HOME/dotnet" && tar zxf aspnetcore-runtime-3.1.11-linux-x64. tar .gz -C "$HOME/dotnet" export DOTNET_ROOT=$HOME /dotnet export PATH=$PATH:$HOME /dotnet |
或者直接用命令安装
1 2 | sudo rpm -Uvh https: //packages .microsoft.com /config/rhel/8/packages-microsoft-prod .rpm sudo yum -y install aspnetcore-runtime-3.1 |
接着我们运行dotnet --version就可以看到当前ASP.NET Core的版本是3.1
此时我们就可以把我们编译后的网站上传到服务器上(本次使用的目录是/usr/src/wwww/whitelist),然后在/var/supervisord/目录下建一个网站的ini配置文件,内容如下
1 2 3 4 5 6 7 8 9 10 11 | [program:bmd.Site] command =dotnet WhiteList.dll directory= /usr/src/wwww/whitelist environment=ASPNETCORE__ENVIRONMENT=Production user=root stopsignal=INT autostart= true autorestart= true startsecs=3 stderr_logfile= /var/log/whitelist .err.log stdout_logfile= /var/log/whitelist .out.log |
随后我们运行supervisorctl reload或者systemctl restart supervisord.service重新启动supervisord,
因为我们使用的是Kestrel来作为web服务,所以我们需要把5000端口对外开放(
firewall-cmd --zone=public --add-port=5000/tcp --permanent
firewall-cmd --reload
)同时需要在appsettings.json中启用配置
1 2 3 4 5 6 7 | "Kestrel" : { "EndPoints" : { "Http" : { "Url" : "http://0.0.0.0:5000" } } }, |
随后我们就可以看到我们的网站已经运行成功。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步