從零實操基於WSL2 Docker部署Asp.Net Core項目


前言

平日在公司里都是基於阿里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

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM