很早就看過關於net core部署在Linux上的文章,自己也曾親自將項目部署在Linux上,今天看到這篇文章,為其格式之工整而轉! 1.環境準備 網上看了一下,Linux雲伺服器還挺貴的,那就只好先用VMware虛擬機搭建個吧。這裡我選裝的Linux系統版本的是CentOS,Linux系統眾多發行 ...
很早就看過關於net core部署在Linux上的文章,自己也曾親自將項目部署在Linux上,今天看到這篇文章,為其格式之工整而轉!
1.環境準備
網上看了一下,Linux雲伺服器還挺貴的,那就只好先用VMware虛擬機搭建個吧。這裡我選裝的Linux系統版本的是CentOS,Linux系統眾多發行版之一,相信各位園友也不陌生。
軟體版本信息如下:
虛擬機安裝、系統鏡像配置過程,大家參考網上教程應該沒啥問題,我這不再贅述。
成功安裝並登陸CentOS 7 Minimal系統後,發現無法上網,後來搜索找到原因:CentOS 7 Minimal 預設沒有啟動網路配置。
接下來就通過
vi
命令編輯網卡配置文件ifcfg-ens33
(其他版本名稱可能略有不同,但路徑一致)。具體命令如下:
vi /etc/sysconfig/network-scripts/ifcfg-ens33
將
ONBOOT=no
改為ONBOOT=yes
,設置隨系統開機運行。然後:wq
強制保存並退出編輯文件即可。最後,需要重啟一下網路服務。命令如下:
service network restart
目前應該可以上網了,可以嘗試用命令
ping www.baidu.com
來檢查下網路是否通暢。如上圖,可以接收響應,證明網路暢通。反之,證明你的網路還是不通,就需要考慮其他原因了。
暫時還沒有安裝VMware Tools,直接在虛擬機中編(復)寫(制)命令多有不便,這裡可以通過連接工具PuTTY在Window系統中連接虛擬機中的CentOS系統,連接伺服器也同樣適用。
軟體截圖:
選擇SSH連接協議,輸入CentOS系統IP地址,點擊【Open】按鈕連接。輸入系統用戶名密碼即可登錄系統。
問:怎麼知道虛擬機中CentOS系統的IP地址呢?
答:可以通過
ifconfig
命令來獲取系統的IP地址。說明一點,因為這裡我選的是CentOS 7 Minimal最小化安裝,需要聯網後先執行命令yum install net-tools
下載網路工具包,然後才能使用ifconfig
命令。2.安裝.NET Core SDK
Linux各個發行版如何安裝.NET Core SDK,微軟官方已經給出了標準答案,我這裡就把在CentOS上的安裝方法做一個簡要說明。
Step1:安裝dotnet產品提要
要開始安裝.NET,您需要註冊Microsoft簽名密鑰並添加Microsoft產品提要。每台機器只需要做一次。 打開命令提示符並運行以下命令:
sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc sudo sh -c 'echo -e "[packages-microsoft-com-prod]\nname=packages-microsoft-com-prod \nbaseurl= https://packages.microsoft.com/yumrepos/microsoft-rhel7.3-prod\nenabled=1\ngpgcheck=1\ngpgkey=https://packages.microsoft.com/keys/microsoft.asc" > /etc/yum.repos.d/dotnetdev.repo'
Step2:安裝.NET SDK
更新可用於安裝的產品,安裝.NET所需的組件,然後安裝.NET SDK。
在命令提示符下,運行以下命令:
sudo yum update sudo yum install libunwind libicu sudo yum install dotnet-sdk-2.1.3 #最新版本請關註官網
兩步即可完成.NET Core SDK在CentOS7系統下的安裝,最後可執行一下命令
dotnet --version
,如果正常輸出版本號則說明安裝沒有出現問題。Linux其他發行版安裝.NET Core SDK教程請參見官方教程 Get started with .NET in 10 minutes。
3.部署ASP.NET Core應用程式
下麵就嘗試把我用ASP.NET Core Web API 開發的一個介面網站部署到我們已經安裝.NET SDK的CentOS系統(下文簡稱伺服器)中。
程式發佈過程省略,把編譯後的程式發佈到了本地
F:\wwwroot\Scorpio
文件夾。然後藉助FTP工具FileZilla把程式文件傳輸到伺服器
/home/wwwroot/scorpio
文件夾。上傳截圖:
上傳完畢後,需要先通過
cd
命令進入網站根目錄/home/wwwroot/scorpio/
,再輸入如下命令啟動網站程式:
dotnet Scorpio.WebApi.dll
如果在任意非站點根目錄,通過下麵這種方式直接運行,程式會拋異常,不知是程式原因還是其他原因。
dotnet /home/wwwroot/scorpio/Scorpio.WebApi.dll
如果你可以看到如下界面則表示程式啟動成功。
4.Nginx配置反向代理
Nginx是一個高性能的Web伺服器軟體。這是一個比Apache HTTP Server更加靈活和輕量級的程式。
我們的網站程式啟動的埠是
5000
,可以藉助Nginx把程式5000
埠映射到80
埠。4.1.安裝Nginx
首先,我們需要在伺服器上安裝Nginx。
Step1:添加Nginx存儲庫
要添加CentOS 7 EPEL倉庫,請打開終端並使用以下命令:
sudo yum install epel-release
Step2:安裝Nginx
現在Nginx存儲庫已經安裝在您的伺服器上,請使用以下
yum
命令安裝Nginx:
sudo yum install nginx
Step3:啟動Nginx
Nginx不會自行啟動。要運行Nginx,請輸入:
sudo systemctl start nginx
如果您正在運行防火牆,請運行以下命令以允許HTTP和HTTPS通信:
sudo firewall-cmd --permanent --zone=public --add-service=http sudo firewall-cmd --permanent --zone=public --add-service=https sudo firewall-cmd --reload
此時,可以在本機的瀏覽器中訪問伺服器的IP地址
http://192.168.83.128
來驗證Nginx是否成功運行。如果能看到Nginx的預設轉髮網頁則說明一切正常。如下截圖:
如果拒絕訪問,考慮伺服器
80
埠是否開放。可嘗試通過下麵兩條命令開放80
埠、重啟防火牆使修改即時生效。
firewall-cmd --zone=public --add-port=80/tcp --permanent systemctl restart firewalld
4.2.設置Nginx開機啟動
避免開機需要手動開啟Nginx,可以通過如下快捷命令把Nginx配置成系統服務,並設置為開機啟動:
systemctl enable nginx #設置開機啟動
其他命令:
systemctl disable nginx #禁止開機啟動 systemctl status nginx #查看運行狀態 systemctl restart nginx #重啟服務
4.3.修改Nginx配置文件
首先,拿到Nginx的預設配置文件
/etc/nginx/nginx.conf
,把預設80
埠轉發配置server
節點用#
符註釋掉。然後,我們新建一個配置文件
netcore.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; } }
保存並上傳到Nginx的配置載入目錄
/etc/nginx/conf.d
,最後執行命令nginx -s reload
重啟Nginx即可。在本地瀏覽器上訪問伺服器地址,運行結果如下:
這個問題是由於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
再次訪問,運行結果如下:
可以看到,訪問的介面成功返回數據,證明Nginx已經完成對我們部署應用程式的轉發。
5.Supervisor配置守護進程
Supervisor是用Python開發的Linux/Unix系統下的一個進程管理工具。它可以使進程脫離終端,變為後臺守護進程(daemon)。實時監控進程狀態,異常退出時能自動重啟。
Supervisor不支持任何版本的Window系統;僅支持在Python2.4或更高版本,但不能在任何版本的Python 3下工作。
其主要組成部分:
supervisord:Supervisor的守護進程服務,用於接收進程管理命令;
supervisorctl:Supervisor命令行工具,用於和守護進程通信,發送管理進程的指令;
Web Server:Web端進程管理工具,提供與supervisorctl類似功能,管理進程;
XML-RPC Interface:提供XML-RPC介面,請參閱XML-RPC API文檔。
5.1.安裝Supervisor
聯網狀態下,官方推薦首選安裝方法是使用
easy_install
,它是setuptools(Python包管理工具)的一個功能。所以先執行如下命令安裝 setuptools:
yum install python-setuptools
請更換
root
用戶,執行如下命令安裝Supervisor:
easy_install supervisor
5.2.配置Supervisor
運行
supervisord
服務的時候,需要指定Supervisor配置文件,如果沒有顯示指定,預設會從以下目錄中載入:
$CWD/supervisord.conf #$CWD表示運行supervisord程式的目錄 $CWD/etc/supervisord.conf /etc/supervisord.conf /etc/supervisor/supervisord.conf (since Supervisor 3.3.0) ../etc/supervisord.conf (Relative to the executable) ../supervisord.conf (Relative to the executable)
所以,先通過如下命令創建目錄,以便讓Supervisor成功載入預設配置:
mkdir /etc/supervisor
載入目錄有了,然後通過
echo_supervisord_conf
程式(用來生成初始配置文件)來初始化一個配置文件:
echo_supervisord_conf > /etc/supervisor/supervisord.conf
打開
supervisord.conf
文件,可以看到echo_supervisord_conf
已經幫我們初始化好了一個樣例配置,我們需要簡單修改一下。尾部找到如下文本片段:
;[include] ;files = relative/directory/*.ini
改為:
[include] files = conf.d/*.conf
即,把註釋去除、設置
/etc/supervisor/conf.d
為Supervisor進程配置文件載入目錄。這樣,Supervisor會自動載入該目錄下
.conf
尾碼的文件作為共同服務配置。Supervisor管理的每個進程單獨寫一個配置文件放在該目錄下,supervisord.conf
配置文件中保留公共配置。創建進程配置載入目錄:
mkdir /etc/supervisor/conf.d
接下來就需要為我們已經部署的ASP .NET Core程式的宿主進程創建一個進程配置文件
netcore.conf
,保存並上傳到/etc/supervisor/conf.d
目錄。配置文件
netcore.conf
內容如下:
[program:Scorpio.WebApi] ;自定義進程名稱 command=dotnet Scorpio.WebApi.dll ;程式啟動命令 directory=/home/wwwroot/scorpio ;命令執行的目錄 autostart=true ;在Supervisord啟動時,程式是否啟動 autorestart=true ;程式退出後自動重啟 startretries=5 ;啟動失敗自動重試次數,預設是3 startsecs=1 ;自動重啟間隔 user=root ;設置啟動進程的用戶,預設是root priority=999 ;進程啟動優先順序,預設999,值小的優先啟動 stderr_logfile=/var/log/Scorpio.WebApi.err.log ;標準錯誤日誌 stdout_logfile=/var/log/Scorpio.WebApi.out.log ;標準輸出日誌 environment=ASPNETCORE_ENVIRONMENT=Production ;進程環境變數 stopsignal=INT ;請求停止時用來殺死程式的信號
啟動Supervisor服務,命令如下:
supervisord -c /etc/supervisor/supervisord.conf
這時,在會發現我們部署的網站程式不在shell中通過
dotnet xxx.dll
啟動,同樣可以訪問。5.3.設置Supervisor開機啟動
首先為Supervisor新建一個啟動服務腳本
supervisor.service
,然後保存並上傳至伺服器/usr/lib/systemd/system/
目錄。腳本內容如下:
# supervisord service 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 $OPTIONS shutdown ExecReload=/usr/bin/supervisorctl $OPTIONS reload KillMode=process Restart=on-failure RestartSec=42s [Install] WantedBy=multi-user.target
設置開啟啟動:
systemctl enable supervisor
驗證是否成功:
systemctl is-enabled supervisor
如果輸出
enabled
則表示設置成功,也可重啟伺服器驗證。其它Linux發行版開機啟動腳本 User-contributed OS init scripts for Supervisor
5.4.Supervisorctl管理進程
Supervisor服務啟動後,受其管理的進程會在後臺運行。可以通過
supervisorctl
客戶端管理進程。輸入如下命令進入
supervisorctl
交互終端,按Ctrl
+C
鍵退出:supervisorctl
輸入
help
查詢幫助:
supervisor> help default commands (type help <topic>): ===================================== add exit open reload restart start tail avail fg pid remove shutdown status update clear maintail quit reread signal stop version
輸入
help ****
查詢詳細命令,比如輸入help stop
:
supervisor> help stop stop <name> Stop a process stop <gname>:* Stop all processes in a group stop <name> <name> Stop multiple processes or groups stop all Stop all processes
如何啟動、停止、重啟進程等命令,我這裡就不在記錄,大家自行查找吧。
除此之外,Supervisor還提供了Web管理界面用來管理進程,如何配置啟動請參考官方文檔。
至此,我們已經完成了ASP.NET Core應用程式在CentOS7伺服器上的部署。
6.相關閱讀
【轉】:http://www.cnblogs.com/esofar/p/8043792.html
歡迎大家關註我都我的微信 公眾號,公眾號漲粉絲人數,就是你們對我的喜愛程度!