1. 程式人生 > >.Net Core WebApi(二)在Windows伺服器上部署

.Net Core WebApi(二)在Windows伺服器上部署

  上一篇學習到了如何簡單的建立.Net Core Api和Swagger使用,既然寫了介面,那麼就需要部署到伺服器上才能夠正式使用。伺服器主要用到了兩種系統,Windows和Linux,.Net和Windows都是屬於微軟爸爸的,那麼這一篇就先從部署到Windows伺服器系統開始吧。

一、準備伺服器

  首先,我們需要一臺裝了Windows Server的雲伺服器,但是我沒有。那麼,到這裡就結束了。(╮( ̄▽ ̄)╭開玩笑的)

  言歸正傳,我們沒有云伺服器怎麼辦,那當然是要買一臺了。有人會說有點貴,確實,便宜的一個月都好幾十,不過那是在連續不間斷使用的情況下的,既然我們是學習那麼就不需要一直用,所以我們只需要買【按量計費】的就行了。

  到阿里雲購買伺服器卻發現:

  嗯,要100元才能買,果斷轉戰其他平臺。

  然後發現騰訊雲沒有這個限制,果然騰訊親民啊。(瘋狂暗示)

 

  經過我一系列的操作,發現成都地區的最便宜,一個小時只需要2毛錢,比去網咖上網便宜多了。(不要告訴我你買不起,搶QQ紅包都能搶夠,更何況是花在學習上的錢,那叫投資(~ ̄▽ ̄)~ )

  按照圖下,選擇【按量計費】,選地區(我用的最便宜的成都地區),選機型(最便宜的,夠用)。

  選擇公共映象,【Windows Server 2012 R2 資料中心版 64位中文版】,當然如果你英語好,也可以選英文版的。

  系統盤最低50GB,不用改了。

  免費分配獨立公網IP(重要,必須√上,不然就失去了主要的意義了)

  選擇【按頻寬計費】(因為你保不準用多少流量)

  下一步設定主機,選擇【新建安全組】,然後下拉框選【放通全部埠】(因為我們是學習臨時使用,不用在意什麼安全性的問題了)

  然後【設定密碼】,這個不用我多說了吧。

  【定時銷燬】這個要看你用不用,你也可以選擇用完之後手動銷燬,但是如果你忘記的話,會按時間繼續扣錢的。(定時銷燬一定要設定好時間,要不然你會發現用著用著突然就沒了)

  確認資訊,沒啥說的,開通。

  兩毛錢一小時,隨便你折騰,是不是很划算。

  開通後自動跳轉到控制檯例項頁面,可以看到我們的公網IP了。

  然後我們進行遠端桌面連線。

  如果出現無法連線的錯誤。

  回到我們的控制檯,在操作列中點選【登入】。 

  彈出提示微信掃碼操作,開啟微信掃碼,確定。

  確定之後,彈出登入Windows例項視窗,用其他方式(VNC)點選【立即登入】。

  彈出新網頁,提示按Ctrl+Alt+Delete登入。然後你直接在鍵盤上按Ctrl+Alt+Delete,卻發現打開了你自己電腦的安全視窗╮( ̄▽ ̄)╭,其實是要點發送遠端命令來操作的。

  右上角開啟【傳送遠端命令】,點選【Ctrl-Alt-Delete】登入。

  輸入賬號密碼登入之後,開啟系統屬性,把【僅允許執行使用網路網路級別身份驗證的遠端桌面的計算機連線】的勾去掉。

  之後退出頁面,重新進行遠端桌面連線,就可以了。

  輸入使用者名稱密碼登入進去,搞定。

  好了,雲服務買好了,接下來該進入我們的正題了。

二、環境搭建及釋出

  首先,我們需要在伺服器上下載.NET Core Runtime,下面附上鍊接。

  https://dotnet.microsoft.com/download/dotnet-core

  選擇我們的.NET Core版本,我的是2.2的。

  如圖所示,下載最新的。

  下載完成後,執行exe檔案,勾選同意安裝,然後等待安裝完成就行了。

  然後回到我們之前的專案中,右鍵專案,選擇釋出。

  選取釋出目標,選擇資料夾,選擇路徑(我用的預設路徑),然後點擊發布。

  然後找到你釋出的資料夾,拷貝該資料夾到伺服器上。

  拷貝到伺服器上,重新命名為專案名稱,便於區分。

  內容如下。

三、程式部署

  我這裡有兩種部署方法,第一種是執行命令列執行,第二種是通過IIS部署。推薦使用第二種常用的IIS部署方式,第一種作為了解使用,當然你要用也是可以的。

第一種方式執行命令列:

  按住Shift鍵不送,滑鼠右鍵空白處,彈出的右鍵選單有【在此處開啟命令視窗】,點選它開啟命名視窗。

  會發現我們cmd的路徑直接在該資料夾裡,然後執行下面的命令(FirstApi是你的專案名,也就是上圖中FirstApi.dll檔案)。

  dotnet FirstApi.dll

  會發現有一個地址,監聽本地的5000埠。

  然後輸入該地址就能訪問了。誒,怎麼內部錯誤了 o(゚Д゚)っ!

  看一下我們的命令視窗,原來是缺少檔案。這個檔案是Swagger生成的xml註釋檔案,vs釋出的時候沒有包含在裡面,所以我們要手動將該檔案拷過來。

  找到該xml檔案拷貝到伺服器資料夾下。

  重新執行,訪問地址就能看到了。但這個是localhost本地的,我們想要在外網訪問需要改一下程式碼(當然你也可以用反向代理)。

 

  開啟我們的專案,點選Program檔案。

  在箭頭所指的位置加入圖中的程式碼,5555是你自己指定的埠。

  加入後Program類檔案程式碼如下。

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Logging;

namespace FirstApi
{
    public class Program
    {
        public static void Main(string[] args)
        {
            CreateWebHostBuilder(args).Build().Run();
        }

        public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
            WebHost.CreateDefaultBuilder(args).UseUrls("http://*:5555")
                .UseStartup<Startup>();
    }
}

  然後重新生成將dll檔案拷貝到伺服器上覆蓋,按照之前的方式執行。

  輸入在自己電腦上輸入公網ip加上埠,就能成功訪問了。

  我們可以測試一下。執行第一個試試,成功返回結果。

  接下來進入我們的第二種方法。

第二種方式通過IIS部署:

  首先,開啟伺服器管理器。(注:因為我是緊跟著第一個方式操作的,請保證已將xml檔案拷到伺服器資料夾下,不然部署完成了也會出錯)

  在管理裡點選【新增角色和功能】

  到選擇伺服器角色,勾選【Web伺服器(IIS)】。

  然後選擇角色伺服器,根據需求勾選。(我都勾上了,為了避免出現問題,反正用不用都先加上沒多大壞處(~ ̄▽ ̄)~ )。

  安裝完成之後,開啟我們的IIS管理器。

  右鍵網站,選擇新增網站。輸入網站名稱,選擇檔案路徑,輸入埠。

  然後點選【應用程式池】,點開編輯我們剛剛建立的。

  將.NET CLR版本的下拉框選擇為【無託管程式碼】,確定。

  然後開啟網站,又報錯了(ŎдŎ;),查了一下是缺少了【AspNetCoreModule】託管模組。

  選擇根節點的伺服器,開啟【模組】這一項。

  發現沒有找到叫做【AspNetCoreModule】的託管模組,emmmmm好像是漏掉了。

  重新開啟我們下載的安裝程式,點選【Repair】重新安裝。

  等待重新安裝完成之後,重啟IIS管理器,再次開啟【模組】,發現已經有了。

  然後我們訪問網站,成功出現Swagger文件頁面,大功告成。

  OK,.Net Core WebApi在Windows伺服器上部署到這裡就告一段落了,相信各位也會了吧,覺得不錯的小夥伴可以在右邊→點一下推薦(〃^ω^) ,不足的地方也請大家提出來,多多關照。接下來是在Linux伺服器上的部署,其實是和上面的第一種方式差不多,但是為了區分,單獨寫一篇(其實是為了水一篇)來記錄如何搭建,想要了解的小夥伴可以關注我喲⁄(⁄⁄•⁄ω⁄•⁄⁄)⁄。