在騰訊ubuntu雲服務器上面部署asp.net core 2.1網站

  微軟之後的政策確定是在開源和跨平臺這一塊,因此最近在學習asp.net core 2.1,查看市面上面大部分的把asp.net core部署在Linux後,決定親自實驗一番,不操做不知道,竟然最新版本的跟老版本差距有點大,簡單點就是網上的參考只適合老版本,通過了屢次試坑以後發佈成功,因此決定寫出來供有須要的人蔘考。linux

第一步:在Ubuntu上面安裝asp.net core 2.1 sdknginx

這一步驟能夠參考:https://www.microsoft.com/net/learn/get-started-with-dotnet-tutorial#linuxubuntuweb

選擇合適的版本後:shell

1.註冊微軟的keyjson

wget -q https://packages.microsoft.com/config/ubuntu/16.04/packages-microsoft-prod.deb
sudo dpkg -i packages-microsoft-prod.deb

2.安裝sdkubuntu

sudo apt-get install apt-transport-https
sudo apt-get update sudo apt-get install dotnet-sdk-2.1

第二步:建立一個mvcapp測試項目bash

dotnet new mvc -o mvcappmvc

cd mvcappapp

dotnet runasp.net

 啓動後會看到下面信息,重點關注紅框中的信息,比網上大部分教程都多了一行連接:https://localhost:5001

據我在測試後面的操做中發現,這裏面第一連接是https,很顯然須要證書信任,能夠參考這個網站看看https://blogs.msdn.microsoft.com/webdev/2018/02/27/asp-net-core-2-1-https-improvements/。

你用wget http://localhost:5000/ 的時候會發現,會重定向到https://localhost:5001/上面去,這樣會打不開網站,後面的ngnix代理該地址也會訪問不了,這裏有幾種方案去掉https或者增長認證證書。我這裏選擇的是去掉https這個地址,怎麼去掉呢,須要打開項目下面的 vi mvcapp/Properties/launchSettings.json,修改爲下面所示:

 

從新編譯:dotnet restore

從新運行:dotnet run

再用wget http://localhost:5000 發現能夠訪問了 不會出現重定向302等訪問不了的問題

 

 三步:像網上同樣經過nginx設置代理,這樣能夠外網訪問

安裝 Nginx

sudo apt-get install nginx

啓動 Nginx

sudo service nginx start

配置 Nginx

server {
listen 80;
location / {
proxy_pass http://localhost:5000; # 監聽 5000 端口,由於 DotNet 默認端口是 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

 最終在外網能夠訪問啦:

 

 

 

 

 

 

 

 

 以上  謝謝查看

相關文章
相關標籤/搜索