【詳細】【轉】CentOS 7部署ASP.NET Core應用程式

来源:https://www.cnblogs.com/gdsblog/archive/2018/04/11/8795871.html
-Advertisement-
Play Games

很早就看過關於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埠。

Nginx官方文檔 & Nginx開發從入門到精通 - Tengine

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

歡迎大家關註我都我的微信 公眾號,公眾號漲粉絲人數,就是你們對我的喜愛程度!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Java 內部類分為: 1)成員內部類 2)靜態嵌套類 3)方法內部類 4)匿名內部類 內部類的共性 1、內部類仍然是一個獨立的類,在編譯之後內部類會被編譯成獨立的.class文件,但是前面冠以外部類的類名和$符號 。 2、內部類不能用普通的方式訪問。內部類是外部類的一個成員,因此內部類可以自由地訪 ...
  • 方法 綁定方法和非綁定方法 綁定方法和非綁定方法在創建時沒有任何區別,同一方法,既可以為綁定方法,也可以為非綁定方法,一切不同都只在調用時的手法上有所區別。 綁定方法即該方法綁定類的一個實例上,必須將self作為第一個參數傳入,而這個過程是由Python自動完成。可以通過實例名.方法名(參數列表)來 ...
  • 出現這個問題的原因可能很多,但是最終原因都是部署的項目文件中沒有這個類包。 那麼出錯的點在哪呢?逐一排除! 1.首先在項目文件中沒有添加相應的jar包,可以在maven dependencis文件夾中看是否有。如果沒有,在pom文件添加依賴配置即可;如果有,還是出現問題轉第二步 2.在maven的本 ...
  • 概述 UWP Community Toolkit Extensions 中有一個為 View 提供的擴展 - View Extensions,本篇我們結合代碼詳細講解 View Extensions 的實現。 View Extensions 包括了 ApplicationViewExtensions ...
  • 文章是很基礎,但很實用,看了這篇文章,讓我一下回到了2016年剛剛學委托的時候,故轉之! 1.委托 委托類似於C++中的函數指針(一個指向記憶體位置的指針)。委托是C#中類型安全的,可以訂閱一個或多個具有相同簽名方法的函數指針。簡單理解,委托是一種可以把函數當做參數傳遞的類型。很多情況下,某個函數需要 ...
  • •LINQ(發音:Link)是語言級集成查詢(Language INtegrated Query) •LINQ是一種用來進行數據訪問的編程模型,使得.NET語言可以直接支持數據查詢 •LINQ的目標是降低訪問數據的複雜度 •LINQ可以用統一的方法訪問不同類型的數據,可以將數據作為對象使用 •能夠更 ...
  • 寫過介面的同學都知道,介面會越來越多,那麼控制器也會越來越多。這時候就需要根據某種業務或特性對controller進行分類然後建立文件夾。 我想到一個折中的方案:偽Areas! 在Areas文件夾下建立對應的文件夾,比如說用戶相關的,建立一個Account文件夾 圖中就是我創建的文件夾及對應的Con ...
  • RabbitMQ is a message broker: it accepts and forwards messages. You can think about it as a post office: when you put the mail that you want posting i ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...