從零實操基於WSL2 Docker部署Asp.Net Core專案

什麼都看不懂發表於2021-07-03

前言

平日在公司裡都是基於阿里Teambition中的飛流進行Docker部署Api專案或服務,已經習慣了那一套成熟的操作流程,開發和部署確實快捷方便,但是還沒在自己的電腦上進行操作過,特別是Windows10開始已經有WSL、WSL2

去年在筆記本上搗鼓過WSL2,但也只是開啟安裝完後打了下幾行命令嚐個鮮,沒有進行過後續跟開發有關的操作

前兩天把家裡電腦系統升級到Windows 11,新系統感覺良好,抽空再次嘗試下WSL2,順便記錄下完整的專案部署流程

 

WSL

WSL:適用於 Linux 的 Windows 子系統。

  • 什麼是適用於 Linux 的 Windows 子系統?

適用於 Linux 的 Windows 子系統可讓開發人員按原樣執行 GNU/Linux 環境 - 包括大多數命令列工具、實用工具和應用程式 - 且不會產生虛擬機器開銷。

  • 什麼是 WSL 2?

WSL 2 是適用於 Linux 的 Windows 子系統體系結構的一個新版本,它支援適用於 Linux 的 Windows 子系統在 Windows 上執行 ELF64 Linux 二進位制檔案。 它的主要目標是提高檔案系統效能,以及新增完全的系統呼叫相容性。

  • WSL 2 和 WSL 1 的區別?

 

安裝WSL 2

WSL官方教程:https://docs.microsoft.com/zh-cn/windows/wsl/install-win10

Hyper-V說明:https://docs.microsoft.com/zh-cn/virtualization/hyper-v-on-windows/about/

  1. 首先要去 控制皮膚 -> 程式和功能 -> 啟用或關閉Windows功能 -> 開啟 Hyper-V適用於Lindex的Windows子系統、虛擬機器平臺(僅用WSL 1無需這個) ,設定成功後需要重啟系統

  2. 開啟Windows Terminal (支援多命令視窗的終端工具,Windows11已自帶,之前版本需要去應用商品下載安裝)  或者 CMD 或者 PowerShell,輸入以下程式碼可檢視當前已註冊的Linux分發版本
    wsl -l

     
    注意:上面截圖裡是我已安裝完Ubuntu和Docker的結果,如果第一次安裝,只有一個預設Linux

  3. 安裝完成預設架構是WSL 1,需要手動切換到WSL 2,在這之前需要先下載安裝Linux的核心更新包

    點選下載Linux核心更新包

    安裝完畢之後執行下面命令,切換到WSL 2
    wsl --set-default-version 2

 

安裝Ubuntu

  1. 開啟Windows應用商城,搜尋Ubuntu,並選擇一個版本進行安裝



  2. 安裝完成後,點選啟動Ubuntu,會提示需要設定使用者名稱和密碼
    (網上截圖)

  3. 設定Ubuntu為WSL預設系統,WSL 版本號為2(這裡以Ubuntu 20.04為例)
    wsl --set-version Ubuntu-20.04 2
  4. 在Windows Terminal 下會多一個Ubuntu的命令列選項

 

安裝Docker

    Windows環境下可以去Docker官方下載Docker Desktop進行安裝,最新版本已經支援使用WSL2執行,也可以在Ubuntu下以Linux傳統方式安裝Docker(自行某度)

    

    

 

遷移Docker映象預設儲存路徑(如果你的C盤很大,可跳過這步)

   Docker的映象預設儲存路徑在:C:\Users\你的使用者名稱\AppData\Local\Docker\wsl\data      長期使用映象多了,C盤就會吃緊了,可以遷移目錄到其他盤

  1. 關閉Docker
  2. 關閉所有發行版Linux
    wsl --shutdown
  3. 將docker-desktop-data匯出到指定目錄下 D:\Docker\wsl\data\docker-desktop-data.tar(注意,原有的docker images不會一起匯出)
    wsl --export docker-desktop-data D:\Docker\wsl\data\docker-desktop-data.tar
  4. 登出docker-desktop-data
    wsl --unregister docker-desktop-data
  5. 重新匯入docker-desktop-data到要存放的資料夾:D:\Docker\wsl\data\
    wsl --import docker-desktop-data D:\Docker\wsl\data\ D:\Docker\wsl\data\docker-desktop-data.tar --version 2

    #引數說明
    -version 2 : 指定WSL版本為2
  6. 重啟Docker
  7. 如果重啟Docker出現報錯:Failed to set version to docker-desktop: exit code: -1
    需要開啟cmd執行以下命令,執行完畢後需要重啟電腦
    netsh winsock reset

    報錯原因:https://zhuanlan.zhihu.com/p/151392411
    如果重啟後映象預設路徑又會恢復到原路徑,需要重新弄一遍上面所有步驟,囧

 

在Docker中安裝Nginx、MySQL等(沒用到,可跳過這步)

直接在Ubuntu的命令下使用docker命令安裝元件

  • Nginx
    docker pull nginx  --拉取Nginx最新映象
    #此處省略拉取映象過程中的幾十行命令
    #....
    #....
    docker run --name nginx-local -p 8080:80 -d nginx --啟動Nginx容器 #引數說明 --name nginx-local:設定容器名稱 -p 8080:80:埠進行對映,將本地 8080 埠對映到容器內部的 80-d:設定容器在在後臺一直執行 nginx:映象名或標籤名

     瀏覽器中輸入 http://localhost:8080


  • MySQL
    docker pull mysql  --拉取MySQL最新映象
    #此處省略拉取映象過程中的幾十行命令
    #....
    #....
    docker run
    --name mysql-local -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
    #引數說明 --name mysql-local:設定容器名稱 -p 3306:3306:埠進行對映,將本地 3306埠對映到容器內部的 3306
    -e MYSQL_ROOT_PASSWORD=123456 :設定mysql的登入密碼,預設帳號名為root
    -d:設定容器在在後臺一直執行 mysql:映象名或標籤名

     測試連線MySQL
    

  • Docker Desktop 中同步顯示映象

新建Asp.Net Core專案

  • 在專案中新增健康檢查元件
    Install-Package Microsoft.Extensions.Diagnostics.HealthChecks
  • 在Startup.cs檔案中新增註冊程式碼
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddHealthChecks();
    }
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
       app.UseHealthChecks("/health");    
    }

     

  • 在控制器中隨便寫一個Action方法


  • 通過VS執行專案,測試健康檢查Action

生成Dockerfile檔案

  • VS很早就支援快速生成Dockerfile,在專案的右鍵中,新增Docker支援,選擇Linux即可


  • 編輯Dockerfile新增時區,當然也可以什麼都不動,直接進行下一步
    RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
    RUN echo 'Asia/Shanghai' >/etc/timezone

     

  • 在VS中開啟終端,也可以手動開啟命令列終端工具cd到專案解決方案根目錄下
    注意:命令列開啟必須是定位在解決方案根目錄下,這麼做是因為專案複雜以後專案之間會相互引用,而Dockefile檔案自動生成出來的csproj引用路徑預設是以解決方案根目錄為準,除非你手動修改了Dockerfile中csproj的檔案路徑


  • 在命令列中輸入docker build命令,構建映象
    docker build -f DockerApi/Dockerfile -t docker-api .   --注意結尾最後還有個點
    #此處省略構建映象過程中的幾十行命令
    #....
    #....

    #引數說明
    -f DockerApi/Dockerfile : 指定Dockerfile檔案路徑,如果Dockerfile已經在當前定位的目錄下就不用特別指定了
    -t docker-api : 設定映象標籤為docker-api,標籤名自定義
    . :構建映象的上下文路徑

    #構建完成後檢視映象
    docker images



  • 啟動容器
    docker run --name docker-api -it -p 5000:80 docker-api
    
    #引數說明
    --name docker-api :設定容器名稱
    -it :i-互動式操作,t-終端
    -p 5000:80 :埠進行對映,將本地5000埠對映到容器內部的80埠
    docker-api :映象名或標籤名
  • 開啟瀏覽器輸入
    http://localhost:5000/health
    http://localhost:5000/api/demo/get



  • 大功告成!檢視Docker Desktop,同步顯示所有容器

 

以上就是Docker上部署Asp.Net Core的所有實操步驟,如果按教程一步步來,應該是沒有多大問題的

 

作者:Harry

原文出處:https://www.cnblogs.com/simendancer/articles/14967916.html

有些文字描述和圖片源自網路,如有侵犯請私信告知

相關文章