ASP.NET CORE在docker中的健康檢查(healthcheck)

来源:https://www.cnblogs.com/podolski/archive/2022/08/21/16603177.html
-Advertisement-
Play Games

在使用docker-compose的過程中,很多程式都提供了健康檢查(healthcheck)的方法,通過健康檢查,應用程式能夠在確保其依賴的程式都已經啟動的前提下啟動,減少各種錯誤的發生,同時,合理設計的健康檢查也能夠提供給外界關於應用程式狀態的一些信息。 大多數docker鏡像的詳細說明中,會交 ...


在使用docker-compose的過程中,很多程式都提供了健康檢查(healthcheck)的方法,通過健康檢查,應用程式能夠在確保其依賴的程式都已經啟動的前提下啟動,減少各種錯誤的發生,同時,合理設計的健康檢查也能夠提供給外界關於應用程式狀態的一些信息。

大多數docker鏡像的詳細說明中,會交代如何進行健康檢查,.NET 6也提供了文檔。也有其他人寫了文章說了更細節的內容。

實踐一下,現在docker-compose裡面是這樣:

version: '3.7'
services:
  postgres:
    container_name: postgres-container
    image: postgres:13
    volumes:
      - ./postgres_data:/var/lib/postgresql/data/pgdata
    ports:
      - "5432:5432"
    environment:
      POSTGRES_PASSWORD: "123456"
      PGDATA: "/var/lib/postgresql/data/pgdata"
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 10s
      timeout: 5s
      retries: 5  
    networks: 
      - dotnet-network
  
  dotnet-service:
    image: dotnet-service:latest
    container_name: dotnet-service-container
    ports:
      - 5000:5000
    build:
      context: ./TestWeb/
      dockerfile: ./TestWeb/Dockerfile
    environment:
      # - ASPNETCORE_ENVIRONMENT=Docker
      - ASPNETCORE_URLS=http://*:5000
      - App__SelfUrl=http://*:5000
    restart: on-failure 
    depends_on:
      postgres:
        condition: service_healthy
    networks: 
      - dotnet-network

networks:
  dotnet-network:
    external: false

首先調整一下程式:

var builder = WebApplication.CreateBuilder(args);

builder.Services.AddHealthChecks();

var app = builder.Build();

app.MapHealthChecks("/healthz");

app.Run();

如果直接運行的話,web訪問/healthz節點,那麼可以頁面將直接返回Healthy。看上去沒有問題,那我們按照要求調整一下Dockerfile

FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
HEALTHCHECK CMD curl --fail http://localhost:5000/healthz || exit
ENTRYPOINT ["dotnet", "TestWeb.dll"]

然後調整docker-compose.yml文件,讓postgres啟動依賴dotnet-service:

version: '3.7'
services:
  postgres:
    container_name: postgres-container
    image: postgres:13
    volumes:
      - ./postgres_data:/var/lib/postgresql/data/pgdata
    ports:
      - "5432:5432"
    environment:
      POSTGRES_PASSWORD: "123456"
      PGDATA: "/var/lib/postgresql/data/pgdata"
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 10s
      timeout: 5s
      retries: 5  
    depends_on:
      dotnet-service:
        condition: service_healthy
    networks: 
      - dotnet-network
  
  dotnet-service:
    image: dotnet-service:latest
    container_name: dotnet-service-container
    ports:
      - 5000:5000
    build:
      context: ./TestWeb/
      dockerfile: ./TestWeb/Dockerfile
    environment:
      # - ASPNETCORE_ENVIRONMENT=Docker
      - ASPNETCORE_URLS=http://*:5000
      - App__SelfUrl=http://*:5000
    restart: on-failure 
    networks: 
      - dotnet-network

networks:
  dotnet-network:
    external: false

然後postgres就啟動不了了,提示容器unhealthy。運行docker ps,發現.net容器的後面有一個unhealthy。但是程式訪問正常,說明只是沒有正確運行這段話而已。

Dockerfile方案

文檔說.NET 6的鏡像裡面不帶curl這個工具了,需要手動裝一下:

FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
RUN apt-get update && apt-get install -y curl
HEALTHCHECK CMD curl --fail http://localhost:5000/healthz || exit
ENTRYPOINT ["dotnet", "TestWeb.dll"]

這樣再看,就完全沒問題了,如果把aspnet:6.0改成aspnet:6.0-alpine,空間更節省了(預設是239M,alpine版是108M),還自帶了wget,也沒必要這麼麻煩先安裝curl(比較費時間按)。

HEALTHCHECK CMD wget --spider http://localhost:5000/healthz || exit

docker-compose方案

我不太喜歡去改Dockerfile,而是更傾向於修改docker-compose.yml文件。當然,沒有curl依然還是得在Dockerfile中添加相應語句安裝,但是可以刪除HEALTHCHECK這一條了,直接在docker-compose.yml中對應服務下麵添加:

healthcheck:
    test: ["CMD-SHELL", "wget --spider http://localhost:5000/healthz || exit"]
    interval: 10s
    timeout: 5s
    retries: 5  

程式依然可以正常運行。

P.S. 如果程式沒有使用AddHealthChecks,那麼也可以使用暴力一點的,直接用HEALTHCHECK CMD curl --fail http://localhost:5000 || exit,只要能夠正常訪問頁面,就認為是Healthy,不過肯定就少了很多高級特性了。

除非特殊說明,本作品由podolski創作,採用知識共用署名 4.0 國際許可協議進行許可。歡迎轉載,轉載請保留原文鏈接~喜歡的觀眾老爺們可以點下關註或者推薦~
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 文末有Gitee鏈接,記得star哦 課程整體內容概述 第一部分:編程語言核心結構 主要知識點:變數、基本語法、分支、迴圈、數組、 第二部分:Java面向對象的核心邏輯 主要知識點:OOP、封裝、繼承、多態、介面、 第三部分:開發JavaSE高級應用程式 主要知識點:異常、集合、|℃、多線程、反射機 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • Java集合06 13.Map介面02 13.2Map介面常用方法 put():添加 remove():根據鍵鍵刪除映射關係 get():根據鍵獲取值 size():獲取元素個數 isEnpty():判斷個數是否為0 clear():清除 containsKey():查找鍵是否存在 例子1:Map接 ...
  • ​ 前幾天聽到朋友說自己選課事情,突發奇想想要搞這樣一個東西,但是由於各種原因只做到以下的完成度,具體的情況也會在解釋的最後留下。這個只適用於曲師大的教務系統,因為用的這個系統來進行的一個調試,對於其他的系統,思路都是一樣的,代碼也只適用於學習,請不要用以其他用途!代碼放在最後。 工具 Python ...
  • 1、前言 在執行自動化測試時,我們通常都希望能夠控制執行測試用例的順序。 在unittest框架中預設按照ACSII碼的順序載入測試用例並執行,順序為:0~9、A~Z、a~z,測試目錄、測試模塊、測試類、測試方法/測試函數都按照這個規則來載入測試用例。 在pytest測試框架中,預設從上至下執行,也 ...
  • 1. Mybatis的一級緩存 Mybatis的一級緩存是預設開啟的,你只要搭建一個Mybatis框架,就可以直接使用一級緩存。 一級緩存是SqlSession級別的,通過SqlSession查詢的數據會被緩存,下次使用同一個SqlSession查詢相同的數據,就會從緩存中直接獲取,不會從資料庫重新 ...
  • 哈嘍兄弟們,今天咱們分享一下類的定義和使用。 在Python中,類表示具有相同屬性和方法的對象的集合。在使用類時,需要先定義類,然後再創建類的實例,通過類的實例就可以訪問類中的屬性和方法了。 1、定義類 在Python中,類的定義使用class關鍵字來實現,語法如下: class ClassName ...
  • 面向對象簡介 面向過程的程式設計把電腦程式視為一系列的命令集合,即一組函數的順序執行。為了簡化程式設計,面向過程把函數繼續切分為子函數,即把大塊函數通過切割成小塊函數來降低系統的複雜度。 面向對象編程——Object Oriented Programming,簡稱OOP,是一種程式設計思想。OOP ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...