前言
在上篇文章中,主要介紹了 Dotnet Core Run 命令,這篇文章主要是講解如何在Linux中,對(duì) Asp.Net Core 的程序進(jìn)行發(fā)布和部署。
目錄
- 新建一個(gè) WebApp 項(xiàng)目
- 發(fā)布到 Linux,Mac OS
- 使用 Nginx 進(jìn)行反向代理
新建一個(gè) WebApp 項(xiàng)目
在 Asp.Net Core 項(xiàng)目中,我們使用 dotnet new -t WebApp
命令和創(chuàng)建一個(gè)新的空的 Web 應(yīng)用程序。
以下是我在 Mac 中的截圖:
主要是用以下幾個(gè)命令:
mkdir HelloWebApp
這個(gè)命令是創(chuàng)建一個(gè)名為 HelloWebApp 的文件夾。
dotnet new -t Web
這個(gè)命令是使用 Web 模板來新建一個(gè) WebApp 的 Mvc 應(yīng)用程序。
新建了應(yīng)用程序之后,使用dotnet restore
和 dotnet run
命令來測(cè)試一下我們的應(yīng)用程序。
可以看到已經(jīng)成功運(yùn)行了。
我們打開瀏覽器輸入 http://localhost:5000,來看一下效果。
ps: Safari 下面,瀏覽器地址欄看不到端口號(hào),實(shí)際上是5000端口。
發(fā)布到 Linux,Mac OS
如果發(fā)布應(yīng)用程序,我們需要使用 dotnet publish
命令,通過使用 --help
參數(shù)可以看到一些可以使用的命令參數(shù)。
-f|--framework <FRAMEWORK> Target framework to compile for
-r|--runtime <RUNTIME_IDENTIFIER> Target runtime to publish for
-b|--build-base-path <OUTPUT_DIR> Directory in which to place temporary outputs
-o|--output <OUTPUT_PATH> Path in which to publish the app
--version-suffix <VERSION_SUFFIX> Defines what `*` should be replaced with in version field in project.json
-c|--configuration <CONFIGURATION> Configuration under which to build
--native-subdirectory Temporary mechanism to include subdirectories from native assets of dependency packages in output
--no-build Do not build projects before publishing
我們直接運(yùn)行dotnet publish
使用默認(rèn)的發(fā)布路徑,當(dāng)看到Published 1/1 projects successfully
的時(shí)候,說明已經(jīng)發(fā)布成功了。 接著進(jìn)入到 bin 文件夾下的Debug 文件夾下的netcoreapp1.0 文件夾,然后會(huì)看到有一個(gè) publish 的文件夾。這就是默認(rèn)發(fā)布生成的文件夾,在這個(gè)文件夾中可以看到我們程序所有依賴的程序集文件。
發(fā)布之后 publish 文件夾里面的子文件夾有必要說明一下。
appsettiong.json 應(yīng)用程序的配置文件
refs 應(yīng)用程序引用的.net fx系統(tǒng)程序集
runtimes 運(yùn)行時(shí)環(huán)境,可以看到里面的文件夾包含 win7、linxu,mac os 等,說明我們這個(gè)應(yīng)用程序是跨平臺(tái)的。
views 這個(gè)文件夾存放的就是我們的 mvc 的視圖文件。
wwwroot 文件夾,存放的是前端使用的 js 庫(kù),css 樣式表,和圖片等。
然后我們把工作目錄切換到發(fā)布的 publish 文件夾。使用dotnet HelloWebApp.dll
測(cè)試發(fā)布過后的程序是否運(yùn)行正常。
使用 Nginx 進(jìn)行反向代理
- Mac OS
- Linux(Ubuntu)
- 注意事項(xiàng)
反向代理,即把我們應(yīng)用程序的一部分路徑交給 Nginx 去處理,比如靜態(tài)文件,圖片等。另外一部分動(dòng)態(tài)的交給 Kestrel 來處理。這樣可以降低我們的后端 Kestrel 的壓力,以及可以在 Nginx 配置負(fù)載均衡等。
還有一個(gè)很重要的優(yōu)勢(shì)就是 Web 中的緩存,會(huì)在代理服務(wù)器這一步來處理。大家看下面這個(gè)圖:
至于怎么樣添加代理服務(wù)器可以識(shí)別到的緩存,可以關(guān)注我后面發(fā)表的博客文章。
Mac OS
安裝 dotnet 環(huán)境參見官方網(wǎng)站 https://www.microsoft.com/net/core#macos。
1、 在 mac 中打開命令行,輸入 brew install nginx
首先安裝 nginx。
2、 安裝完成之后,輸入 nginx -v
查看是否安裝成功。顯示nginx version: nginx/1.10.1
表示安裝已經(jīng)成功。
3、配置 nginx 代理。
安裝完 nginx 之后,默認(rèn)的配置文件路徑在 /usr/local/etc/nginx
文件夾中。在這個(gè)文件夾中找到nginx.conf 配置文件,使用 Visual Studio Code 打開,在 Server
節(jié)點(diǎn)中,找到監(jiān)聽 80端口的location 節(jié)點(diǎn),修改配置為如下:
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;
}
保存并退出。 然后使用sudo nginx -s reload
命令來重新加載配置。
然后我們打開瀏覽器 輸入http://localhost,發(fā)現(xiàn)此時(shí)已經(jīng)通過 nginx 來訪問我們的站點(diǎn)了。
ps: Safari 下面,瀏覽器地址欄看不到端口號(hào),實(shí)際上是80端口。
Linux(Ubuntu)
安裝 dotnet 環(huán)境參見官方網(wǎng)站 https://www.microsoft.com/net/core#ubuntu。
首先在Ubuntu 中新建一個(gè)文件夾,把我們發(fā)布的 publish 文件夾拷貝到 Liunx 中。然后測(cè)試一下是否可以正常運(yùn)行。
1、 在 linux(Ubuntu) 中新開一個(gè)命令行窗口,輸入 apt-get install nginx
首先安裝 nginx。
2、 安裝完成之后,輸入 nginx -v
查看是否安裝成功。顯示nginx version: nginx/1.4.6
表示安裝已經(jīng)成功。
yxd@ubuntu:~$ sudo nginx -v
nginx version: nginx/1.4.6 (Ubuntu)
測(cè)試 nginx 是否運(yùn)行成功,打開瀏覽器,輸入 http://localhost 查看是否顯示如下界面。
3、配置 nginx 代理。
安裝完 nginx 之后,默認(rèn)的配置文件路徑在 /etc/nginx/sites-available/default
文件中。切換工作目錄到/etc/nginx/sites-available/
,使用sudo gedit default
命令打開 default 文件。 在 Server
節(jié)點(diǎn)中,找到監(jiān)聽 80端口的location 節(jié)點(diǎn),修改內(nèi)容為如下:
server {
listen 80;
#root /usr/share/nginx/html;
#index index.html index.htm;
# Make site accessible from http://localhost/
server_name localhost;
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;
}
}
保存并退出。 然后使用sudo nginx -s reload
命令來重新加載配置。
然后我們打開瀏覽器 輸入http://localhost,發(fā)現(xiàn)此時(shí)已經(jīng)通過 nginx 來訪問我們的站點(diǎn)了。
注意事項(xiàng)
1、在使用 nginx 代理訪問站點(diǎn)的時(shí)候, 保持命令dotnet run HelloWebApp.dll
的命令行窗口必須開啟。
2、可以使用下面的命令來讓一個(gè)命令行運(yùn)行在后臺(tái)進(jìn)程中。
nohup dotnet HelloWebApp.dll &
這個(gè)時(shí)候你就可以把命令行窗口關(guān)掉了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:http://www.cnblogs.com/savorboard/p/dotnet-core-publish-nginx.html