序言
本文从Linux小白的视角,在CentOS服务器上搭建一个Nginx-PoweredAspNetCoreWeb准生产应用。在开始之前centos 查看用户组,我们还是重温一下布署原理,正如你所常见的.NetCore布署图:
在Linux上布署.NetCoreApp最好的方法是使用Kestrel服务在端口5000上支撑web应用;之后设置Nginx作为反向代理服务器,将输入恳求转发给Kestrel服务器,这个模式称为边沿代理服务器(edge-originproxy)。
布署模型优势:
知识打算
首先明晰dotnet程序是一个独立进程,本来可不依赖反向代理服务器运行;
第二明晰Nginx反向代理服务器的作用,这儿须要为.NetCore程序添加必要的转发中间件
// Invoke the UseForwardedHeaders middleware and configure it to forward the X-Forwarded-For and X-Forwarded-Proto headers.
// NOTE: This must be put BEFORE calling UseAuthentication or similar authentication scheme middlewares.
// ref.: //www.ryadel.com/en/asp-net-core-2-publish-deploy-web-application-linux-centos-tutorial-guide-nginx
app.UseForwardedHeaders(new ForwardedHeadersOptions
{
ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto
});
第三明晰dotnet程序须要在Linux系统中以守护进程的形式运行,可使用supervisor、systemd等管控工具。
CentOS布署1.安装环境
sudo rpm -Uvh //packages.microsoft.com/config/rhel/7/packages-microsoft-prod.rpm
-- rpm是一种软件包管理方式,这里的微软软件包仓库以rpm包的形式提供,包含仓库配置和供发行版认证软件包的公钥,你可以理解为添加了一个nuget包仓库
sudo yum update
sudo yum install aspnetcore-runtime-2.2
-- yum基于rpm包管理,能够从指定服务器自动下载rpm包并且安装,可自动处理依赖关系,并一次安装所有依赖软件包。
2.dotnet程序发布、测试
scp D:productioneqidproxyServer.zip root@10.201.80.126:/var/www --以下将zip包拷贝到 /var/www目录下
unzip -d eqidproxyServer eqidproxyServer.zip
3.使用systemd将dotnet进程设置成Linux守护进程
完成以上步骤centos 查看用户组,dotnet程序并不能在后台作为服务运行linux重启,Nginx似乎能作为反向代理服务器转发恳求到dotnet进程,而且并不具备管理dotnet进程的能力。
下边使用systemd来将dotnet进程设定为系统服务。
systemd是一个Linux的系统服务管理器,其作用是提供系统服务依赖管理、实现系统初始化时服务的并行启动。
①创建服务文件:vim/etc/systemd/system/kestrel-eqidproxyserver.service
[Unit]
Description=EqidProxyServer deploy on centos
[Service]
WorkingDirectory=/var/www/eqidproxyserver/eqidproxyServer
ExecStart=/usr/bin/dotnet /var/www/eqidproxyserver/eqidproxyServer/EqidProxyServer.dll
Restart=always
# Restart service after 10 seconds if the dotnet service crashes:
RestartSec=10
TimeoutStopSec=90
KillSignal=SIGINT
SyslogIdentifier=dotnet-example
User=root
Environment=ASPNETCORE_ENVIRONMENT=Production
Environment=DOTNET_PRINT_TELEMETRY_MESSAGE=false
[Install]
WantedBy=multi-user.target
绿色背景行是须要你注意配置的,这儿我们使用root来执行dll,通常情况下须要创建一个web帐户,并给与项目文件夹owner权限。
下边在root用户组下创建www-data用户,并给与owner权限
sudo useradd -m -g root www-data
sudo chown www-data var/www/eqidproxyserver
注意:Linux是大小写敏感的文件系统,设定ASPNETCORE_ENVIRONMENT=Production会在配置文件中搜索如下配置文件:appsettings.Production.json,故配置和文件名须要留心匹配。
②启用、启动服务
sudo systemctl enable kestrel-eqidproxyserver.service // 启用服务
sudo systemctl start kestrel-eqidproxyserver.service // 指定服务名启动
sudo systemctl status kestrel-eqidproxyserver.service // 验证服务状态
以下是验证服务状态的输出:
● kestrel-eqidproxyserver.service - EqidProxyServer deploy on centos
Loaded: loaded (/etc/systemd/system/kestrel-eqidproxyserver.service; enabled; vendor preset: disabled)
Active: active (running) since Thu 2019-02-28 18:04:20 CST; 3min 2s ago
Main PID: 52859 (dotnet)
Memory: 46.3M
CGroup: /system.slice/kestrel-eqidproxyserver.service
└─52859 /usr/bin/dotnet /var/www/eqidproxyserver/eqidproxyServer/EqidProxyServer.dll
Feb 28 18:06:18 gs-server-5809 dotnet-eqidproxyserver[52859]: info: Microsoft.AspNetCore.Hosting.Internal.WebHost[2]
Feb 28 18:06:18 gs-server-5809 dotnet-eqidproxyserver[52859]: Request finished in 136.6715ms 200
Feb 28 18:06:23 gs-server-5809 dotnet-eqidproxyserver[52859]: info: Microsoft.AspNetCore.Hosting.Internal.WebHost[1]
Feb 28 18:06:23 gs-server-5809 dotnet-eqidproxyserver[52859]: Request starting HTTP/1.1 GET //127.0.0.1/
Feb 28 18:06:23 gs-server-5809 dotnet-eqidproxyserver[52859]: info: Microsoft.AspNetCore.Hosting.Internal.WebHost[2]
Feb 28 18:06:23 gs-server-5809 dotnet-eqidproxyserver[52859]: Request finished in 3.5599ms 200
Feb 28 18:06:32 gs-server-5809 dotnet-eqidproxyserver[52859]: info: Microsoft.AspNetCore.Hosting.Internal.WebHost[1]
Feb 28 18:06:32 gs-server-5809 dotnet-eqidproxyserver[52859]: Request starting HTTP/1.1 GET //10.201.80.126/
Feb 28 18:06:32 gs-server-5809 dotnet-eqidproxyserver[52859]: info: Microsoft.AspNetCore.Hosting.Internal.WebHost[2]
Feb 28 18:06:32 gs-server-5809 dotnet-eqidproxyserver[52859]: Request finished in 1.3498ms 200
4.搭配Nginx布署web程序
①安装Nginx,在终端使用curllocalhost测试nginx
sudo yum install nginx 【首次安装需要显式启动:sudo service nginx start】
CentOS安装的nginx并没有作为守护进程运行,执行sudosystemctlenablenginx启用nginx守护进程
②配置Nginx作为反向代理服务器
server {
listen 80;
server_name default_website;
root /usr/share/nginx/html;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
proxy_pass //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;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
一旦nginx配置完成,可以使用sudonginx-t测试配置文件;
假如配置文件合法,重启nginx(sudonginx-sreload)
完成以上步骤过后,如今已然可以从127.0.0.1、127.0.0.1:5000、服务器IP访问web程序。
5.查看进程日志
使用systemd形式管理进程,所有风波和进程就会记录到某个集中日志linux vi命令,该集中日志包含所有被systend管理的服务和进程的日志。(这个日志功能相当于windows服务器中的风波查看器)
查看刚刚完善的服务日志,可使用下边的:
sudo journalctl -fu kestrel-eqidproxysever.service
// 时间过滤:
sudo journalctl -fu kestrel-eqidproxysever.service --since "2018-11-18" --until "2019-03-28 04:00"
本文原创地址://lrxjmw.cn/cfwqsdjnzscy.html编辑:刘遄,审核员:暂无