將ASP.NET Core應用程式部署至生產環境中(CentOS7)

KAnts發表於2016-08-03

這段時間在使用Rabbit RPC重構公司的一套系統(微信相關),而最近相關檢驗(邏輯測試、壓力測試)已經完成,接近部署至線上生產環境從而搗鼓了ASP.NET Core應用程式在CentOS上的部署方案,今天就跟大家分享一下如何將ASP.NET Core應用程式以生產的標準部署在CentOS上。

環境說明

伺服器系統:CentOS 7.2.1511

相關工具:Xshel、Xftp

伺服器軟體軟體:.netcore、nginx、supervisor、policycoreutils-python

準備你的ASP.NET Core應用程式

首先將你的應用程式以便攜的模式進行釋出。

ps:這邊我使用一個空的Web專案來進行演示,因為本篇主要介紹生產環境的部署,與應用無關。

命令為:dotnet publish –c release

具體的可以看:擁抱.NET Core,如何開發跨平臺的應用並部署至Ubuntu執行,這篇博文介紹了以便攜與自宿主方式釋出web應用。

image

確保這份釋出應用可以在windows上執行,以減少後續的問題。

image

為什麼不用自宿主的方式進行部署?

自宿主的釋出方式進行部署會簡單很多,為什麼生產環境要使用便攜的方式進行釋出呢?

原因1:效能比行動式的低(主)。

原因2:微軟給出的建議(次)。

口說無憑,有圖有真相。

image

image

參考地址:https://docs.microsoft.com/zh-cn/dotnet/articles/core/app-types

so,既然是用於生產環境的,當然我們要追求更高的效能。

安裝CentOS7

這個就不細說了,網上教程很多,這邊我使用了Hyper-V來虛擬化了CentOS7。

安裝.NET Core SDK for CentOS7。

sudo yum install libunwind libicu(安裝libicu依賴)

image

curl -sSL -o dotnet.tar.gz https://go.microsoft.com/fwlink/?LinkID=809131(下載sdk壓縮包)

sudo mkdir -p /opt/dotnet && sudo tar zxf dotnet.tar.gz -C /opt/dotnet(解壓縮)

sudo ln -s /opt/dotnet/dotnet /usr/local/bin(建立連結)

image

輸入 dotnet –info 來檢視是否安裝成功

image

如果可以執行則表明.NET Core SDK安裝成功。

參考資料:https://www.microsoft.com/net/core#centos

部署ASP.NET Core應用程式

上傳之前釋出的資料夾至/home/wwwroot/。

這邊我使用了Xftp進行檔案的上傳。

image

image

檢查是否能夠執行

命令:dotnet /home/wwwroot/WebApplication1/WebApplication1.dll

image

如果出現這些資訊則表示成功執行。

這時候我們是無法訪問到這個頁面的,這時候我們需要部署一個web容器來進行轉發。

配置Nginx

安裝Nginx

curl -o  nginx.rpm http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

image

rpm -ivh nginx.rpm

yum install nginx

image

安裝成功!

輸入:systemctl start nginx 來啟動nginx。

輸入:systemctl enable nginx 來設定nginx的開機啟動(linux當機、重啟會自動執行nginx不需要連上去輸入命令)

配置防火牆

命令:firewall-cmd --zone=public --add-port=80/tcp --permanent(開放80埠)

命令:systemctl restart firewalld(重啟防火牆以使配置即時生效)

測試nginx是否可以訪問。

image

配置nginx對ASP.NET Core應用的轉發

修改 /etc/nginx/conf.d/default.conf 檔案。

將檔案內容替換為

server {
    listen 80;
    location / {
        proxy_pass
http://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;
    }
}

上傳至CentOS進行覆蓋。

執行:nginx –s reload 使其即時生效

執行ASP.NET Core應用程式

image

命令:dotnet /home/wwwroot/WebApplication1/WebApplication1.dll

這時候再次嘗試訪問。

image

想哭的心都有。。。經過後續瞭解,這個問題是由於SELinux保護機制所導致,我們需要將nginx新增至SELinux的白名單。

接下來我們通過一些命令解決這個問題。。

yum install policycoreutils-python

sudo cat /var/log/audit/audit.log | grep nginx | grep denied | audit2allow -M mynginx

sudo semodule -i mynginx.pp

image

再次嘗試訪問。

image

至此基本完成了部署。

配置守護服務(Supervisor)

目前存在三個問題

問題1:ASP.NET Core應用程式執行在shell之中,如果關閉shell則會發現ASP.NET Core應用被關閉,從而導致應用無法訪問,這種情況當然是我們不想遇到的,而且生產環境對這種情況是零容忍的。

問題2:如果ASP.NET Core程式意外終止那麼需要人為連進shell進行再次啟動,往往這種操作都不夠及時。

問題3:如果伺服器當機或需要重啟我們則還是需要連入shell進行啟動。

為了解決這個問題,我們需要有一個程式來監聽ASP.NET Core 應用程式的狀況。在應用程式停止執行的時候立即重新啟動。這邊我們用到了Supervisor這個工具,Supervisor使用Python開發的。

安裝Supervisor

yum install python-setuptools

easy_install supervisor

配置Supervisor

mkdir /etc/supervisor

echo_supervisord_conf > /etc/supervisor/supervisord.conf

修改supervisord.conf檔案,將檔案尾部的配置

image

修改為

image

ps:如果服務已啟動,修改配置檔案可用“supervisorctl reload”命令來使其生效

配置對ASP.NET Core應用的守護

建立一個 WebApplication1.conf檔案,內容大致如下

[program:WebApplication1]
command=dotnet WebApplication1.dll ; 執行程式的命令
directory=/home/wwwroot/WebApplication1/ ; 命令執行的目錄
autorestart=true ; 程式意外退出是否自動重啟
stderr_logfile=/var/log/WebApplication1.err.log ; 錯誤日誌檔案
stdout_logfile=/var/log/WebApplication1.out.log ; 輸出日誌檔案
environment=ASPNETCORE_ENVIRONMENT=Production ; 程式環境變數
user=root ; 程式執行的使用者身份
stopsignal=INT

將檔案拷貝至:“/etc/supervisor/conf.d/WebApplication1.conf”下

執行supervisord,檢視是否生效

supervisord -c /etc/supervisor/supervisord.conf

ps -ef | grep WebApplication1

image

如果存在dotnet WebApplication1.dll 程式則代表執行成功,這時候在使用瀏覽器進行訪問。

image

至此關於ASP.NET Core應用程式的守護即配置完成。

配置Supervisor開機啟動

新建一個“supervisord.service”檔案

# dservice for systemd (CentOS 7.0+)
# by ET-CS (
https://github.com/ET-CS)
[Unit]
Description=Supervisor daemon

[Service]
Type=forking
ExecStart=/usr/bin/supervisord -c /etc/supervisor/supervisord.conf
ExecStop=/usr/bin/supervisorctl shutdown
ExecReload=/usr/bin/supervisorctl reload
KillMode=process
Restart=on-failure
RestartSec=42s

[Install]
WantedBy=multi-user.target

將檔案拷貝至:“/usr/lib/systemd/system/supervisord.service”

執行命令:systemctl enable supervisord

image

執行命令:systemctl is-enabled supervisord #來驗證是否為開機啟動

image

測試

GIF

相關文章