C#

[C#] .NET WorkerService Docker Container HEALTHCHECK 방법

범범조조 2023. 1. 26. 21:54

개요

  • .NET WorkerService Docker Container HEALTHCHECK 방법에 대해서 정리 진행합니다.

개발환경

  • 테스트 개발 환경은 다음과 같습니다.
    • Visual Studio 2022
    • .NET 6
    • WorkerService 프로젝트

1. WorkerService 프로젝트 생성

  • 제일 먼저, WorkerService 프로젝트를 생성해줍니다.


2. WorkerService.csproj 프로젝트 수정

  • 본인이 생성한 WorkerService.csproj 를 열고, Project 속성을 Microsoft.Net.Sdk.Worker -> Microsoft.Net.Sdk.Web 으로 수정합니다.

수정 전


수정 후


프로젝트 다시 로드

  • Microsoft.Net.Sdk.Web 수정하고 나면, 다음과 같이 프로젝트를 다시 로드하라는 메시지가 나옵니다.
  • 프로젝트를 다시 로드해줍니다.


3. launchSetting.json 파일 수정

  • 다음으로, launchSetting.json 파일을 아래와 같이 수정 진행해 줍니다.
{
    "profiles": {
        "ConsoleApp1": {
            "commandName": "Project",
            "launchBrowser": true,
            "environmentVariables": {
                "ASPNETCORE_ENVIRONMENT": "Development"
            },
            "applicationUrl": "http://localhost:5001"
        }
    }
}
  • 위에서 "applicationUrl": "http://localhost:5001" 내용을 추가해 주었습니다.
  • 즉, WorkerService 가 실행 되면, http://localhost:5001 url 로 호스팅 되도록 설정해 주었습니다.

4. Startup.cs 클래스 추가 및 코드 작성

  • 다음으로 Startup 클래스를 생성 후, 아래와 같이 코드를 추가해 줍니다.
namespace SelfHosting;

public class Startup
{
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        app.UseRouting();
        app.UseEndpoints(endpoints => {
            endpoints.MapHealthChecks("/healthy");
        });
    }
}
  • 위에서 endpoints.MapHealthChecks("/healthy"); 코드를 통해 entdpoint 를 추가해 주었습니다.

5. Program.cs

  • 이제 Program.cs 에 서비스를 등록해 주어야 합니다.
  • 등록하는 코드는 아래와 같습니다.
using WorkerServiceSelfHosting;

IHost host = Host.CreateDefaultBuilder(args)
    .ConfigureServices(services =>
    {
        services.AddHostedService<Worker>();
        services.AddHealthChecks();
    })
    .ConfigureWebHostDefaults(webHost =>
    {
        webHost.UseStartup<Startup>();
    })
    .Build();

await host.RunAsync();

6. 프로그램 실행 후, http://localhost:5001/healthy 접속 확인

  • 이제 코드 작성은 모두 완료 되었습니다.
  • 프로그램을 실행 후, http://localhost:5001/healthy 접속하여 Health 상태 확인 합니다.
  • 확인 결과, Health 정보가 출력되어 보이는 것을 확인할 수 있습니다.


7. Dockerfile 에 HEALTHCHECK 정보 추가

  • 이제 WorkerService 내에 HealthCheck 하는 작업은 완료 되었습니다.
  • 실제로, 해당 서비스를 Docker 컨테이너로 실행하기 전에 Dockerfile 에 HEALTHCHECK 옵션을 추가해 주어야 합니다.
  • 실제 추가해 주어야 하는 옵션은 아래 3가지 입니다.
RUN apt-get update 
RUN apt-get --yes install curl
HEALTHCHECK --interval=5s --timeout=10s --retries=3 CMD curl --silent --fail http://localhost/healthy || exit 1
  • 위 옵션에서 핵심 부분은 HEALTHCHECK --interval=5s --timeout=10s --retries=3 CMD curl --silent --fail http://localhost/healthy || exit 1 입니다.
  • 위 명령어는 5초 간격으로 http://localhost/healthy URL 에 요청을 날려, 응답이 없으면 exit 1 을 반환하고 응답이 오면 exit 0 이 오면서 health 정보를 체크하는 옵션입니다.
  • 전체 Dockerfile 내용은 아래와 같습니다.
#See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base
WORKDIR /app

FROM mcr.microsoft.com/dotnet/sdk:6.0 AS build
WORKDIR /src
COPY ["SelfHosting/SelfHosting.csproj", "SelfHosting/"]
RUN dotnet restore "SelfHosting/SelfHosting.csproj"
COPY . .
WORKDIR "/src/SelfHosting"
RUN dotnet build "SelfHosting.csproj" -c Release -o /app/build

FROM build AS publish
RUN dotnet publish "SelfHosting.csproj" -c Release -o /app/publish /p:UseAppHost=false

FROM base AS final
WORKDIR /app
RUN apt-get update 
RUN apt-get --yes install curl
HEALTHCHECK --interval=5s --timeout=10s --retries=3 CMD curl --silent --fail http://localhost/healthy || exit 1
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "SelfHosting.dll"]

8. Docker 이미지 빌드

  • 앞서 작성한 Dockerfile 을 빌드하여 이미지를 생성해 줍니다.
> docker build -t test_net -f .\WorkerServiceSelfHosting\Dockerfile .

9. Docker Container 실행

  • 이미지를 생성하였다면, Docker 컨테이너를 실행해 줍니다.
> docker run -it --name health_test test_net

10. Docker 컨테이너 상태 확인

  • 이제 health 정보가 표시되는지 확인합니다.
  • docker ps -a 명령어를 통해 확인 가능합니다.
  • 확인 결과, Status 정보에서 Health 정보가 정상적으로 표시되는 것을 확인할 수 있습니다.

728x90