So Easy - 在Linux伺服器上部署 .NET Core App
一.環境準備
- 伺服器:阿里雲64位CentOS 7.4.1708版本;
- 客戶端:Windows 10;
- SFTP客戶端:FileZilla;用來進行檔案傳輸;
- SSH工具:Xshell 6;用來在Windows 上遠端訪問CentOS;
二.在Linux上安裝.NET 環境
使用如下命令註冊Microsoft需要的依賴環境,該命令類似於Window上的環境變數,它指向了微軟的環境源,地址中的對每個系統是不一樣,所以我們要斟酌一下的Linux系統是什麼,再去拉取。
wget -q https://packages.microsoft.com/config/ubuntu/18.04/packages-microsoft-prod.deb
比如你當時裝了.NET Core3.0,但是呢!微軟過了幾天又出了.NET Core 3.1 ,這個時候就需要更新你這個配給的配置,通過以下命令。
yum update
yum update命令會重新拉取下,隨後重新做配置,但你的dotnet sdk不會受任何影響,隨後安裝dotnet sdk。
yum install dotnet-sdk-3.1
安裝完會出現以下截圖,隨後我們可以通過dotnet--info來判斷是否安裝成功。
此時環境就執行環境就搭建完璧了~
二.使用FileZilla工具向伺服器推送應用程式
值得一提的是任何伺服器的ftp埠都是22,這個是必須要注意的,否則會一直連線失敗。
此時我們向伺服器傳送了釋出檔案,如果不出意外我們可以直接在Liunx上看到。通過Ls 、Cd /完成檢視。
隨後我們找到了以dll結尾並且是你解決方案的名稱,隨後我們直接dotnet 命令來進行啟動專案。
三.啟動應用程式
此時我們可以看到我們的內網是以5000埠啟動的,這得益於我們直接將.NET Core直接設定原因,當然我們如果要在阿里雲上公網IP的安全對映進行設定,在此之前我們要測試一下內網是否正常,常用的命令是curl,不夠這個命令需要安裝,在Centos和ubuntu安裝命令是不一樣的。具體命令如下:
apt-get install curl //ubuntu的命令
yum install curl //Centos的命令
關於Curl這個命令很強大,這個就不這裡詳談了,安裝完成之後就可以使用這個命令了,最後我們測試內網看看是否正常。
此時發現內網已經打通,現在我們通過阿里雲公網IP對內網進行對映。在阿里雲中的安全組中,找到安全組規則,新增一條對映。放開所有IP,這樣就ok了,具體如下。
此時,試著激動的雙手開啟手機試著去訪問....OK,Nice..
.
四.程序守護
不過一個尷尬的事情出現了,我們只是通過dotnet命令啟動了專案,但是我們的XShell關閉你的應用程式就會關閉,此時我們就需要程序守護了。這樣就可以讓你的應用程式每時每刻都可以為你服務。Supervisor是Python做一個client/server服務,是Linux/Unix雙系統下的一個程序管理工具。它可以很方便的監聽、啟動、停止、重啟一個或多個程序。用Supervisor管理的程序,當一個程序意外被殺死,supervisort監聽到程序死後,會自動將它重新拉起,很方便的做到程序自動恢復的功能,不再需要自己寫shell指令碼來控制。通過這裡你應該就會明白我們會幹什麼,我們會嘗試著關閉Xshell,看看它會不會幫我們去重啟應用程式,如果可以正常訪問,那麼你的程序守護配置成功!好吧廢話不多說。
我們首先需要在Linux系統上安裝 Supervisor ,在安裝它之前,我們需要安裝Python 包。
yum install python-setuptools
隨後我們在安裝Supervisor,執行結果如下圖。
easy_install supervisor
隨後建立幾個資料夾,包括supervisor,在這個資料夾中包含了supervisor的一切配置。包含了程序配置檔案(也就是大概你想讓這個程序去幹什麼?去執行什麼命令?在什麼目錄下?下面我們會逐一說明下配置檔案的各個節點)以及supervisor本身監聽服務的配置。
4.1 在etc資料夾下新建資料夾supervisor
mkdir /etc/supervisor
4.2 在supervisor資料夾下新建資料夾conf.d
mkdir /etc/supervisor/conf.d
4.3 生成supervisord.conf 配置檔案
echo_supervisord_conf > /etc/supervisor/supervisord.conf
4.4 定位到資料夾下修改配置檔案:
cd /etc/supervisor vim supervisord.conf
改變這個路徑只是為了能夠找到我們的conf.d資料夾中我們自定義的配置檔案。conf.d中是我們自己建立的。所以要進行改變。我們在這個檔案內容的最下面,可以看到有一個included標籤,這個就是我剛才所說的。它預設是這個樣子,從內容可以看出是讓我們進行修改的。
修改前的內容如下:
;[include] ;files = relative/directory/*ini
修改後的內容如下:
[include] files = conf.d/*.conf
這個時候supervisord的配置已經結束了,那麼就剩你的應用程式級別的配置檔案了。上述的步驟其實都可以通過FileZilla工具實現,這樣更好的去編輯。
4.5 建立應用程式級別配置檔案
[program:AspNetCore_Cookie] command=dotnet AspNetCore_Cookie.dll directory=/home/publish environment=ASPNETCORE__ENVIRONMENT=Production user=root stopsignal=INT autostart=true autorestart=true startsecs=1 stderr_logfile=/var/log/HelloWebApp.err.log stdout_logfile=/var/log/HelloWebApp.out.log
對於上述的配置檔案我做了如下解釋,當然有錯誤的話可以糾正,畢竟是根據我對鳥語的理解不是很...emmm
command= 要執行的命令,在.NET Core 應用程式中 我們都是使用dotnet 命令來啟動應用程式的
directory= 命令執行的目錄 比如你的publish 在某個資料夾 那你就寫哪裡
environment= 環境變數 ASP.NET Core的環境變數 可能是有的時候需要linux管理員去訪問,不過我是root,這個我是不太懂
user= 程序執行的使用者身份 這裡寫的root
stopsignal=INT 這個都沒人動 我也不動 emmm
autostart= 是否自動啟動
autorestart= 是否自動重啟
startsecs= 自動重啟間隔
stderr_logfile= 標準錯誤日誌
stdout_logfile= 標準輸出日誌
就現在,我們的配置已完畢,如果你是按照上方進行配置的,那麼你肯定是沒有問題的。
4.6 啟動程序守護服務
執行 supervisord -c /etc/supervisor/supervisord.conf 看看是否包報錯資訊,如果沒有則配置成功。隨後我們直接啟動Supervisord服務。
sudo supervisorctl shutdown && sudo supervisord -c /etc/supervisor/supervisord.conf
並且我們檢視程序看看我們剛才的應用程式級別配置是否有效。
現在配置一切成功,去開啟你的網站吧!,關閉你的XShell 或者 雲端線上遠端,這個時候再去試著訪問你的網站。ok沒問題。