Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

ASP.NET Core 프로젝트를 AKS/k8s에 올리는 과정

대개의 경우, 컨테이너를 고려했다면 "Enable Docker Support" 옵션을 켜서 프로젝트를 생성했을 것입니다. 만약, 그 옵션을 켜지 않았더라도 다음의 글에 따라 적절한 Dockerfile을 만들면 됩니다.

Visual Studio - ASP.NET Core Web Application의 "Enable Docker Support" 옵션으로 달라지는 점
; https://www.sysnet.pe.kr/2/0/12171

그래서, 아래와 같은 Dockerfile이 있을 것입니다.

#See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.

# .NET 5: FROM mcr.microsoft.com/dotnet/aspnet:5.0 AS base
FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
WORKDIR /app
EXPOSE 80

# .NET 5: FROM mcr.microsoft.com/dotnet/sdk:5.0 AS build
FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build
WORKDIR /src
COPY ["dotnet_razor31_sample/dotnet_razor31_sample.csproj", "dotnet_razor31_sample/"]
RUN dotnet restore "dotnet_razor31_sample/dotnet_razor31_sample.csproj"
COPY . .
WORKDIR "/src/dotnet_razor31_sample"
RUN dotnet build "dotnet_razor31_sample.csproj" -c Release -o /app/build

FROM build AS publish
RUN dotnet publish "dotnet_razor31_sample.csproj" -c Release -o /app/publish

FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "dotnet_razor31_sample.dll"]

Dockerfile의 내용에 따라 간편하게 "--target final"를 대상으로 빌드합니다.

c:\temp> docker build -f aks.Dockerfile -t dotnet_razor31_sample --target final .

이렇게 해서 로컬 컴퓨터의 docker에 "dotnet_razor31_sample" 이름의 이미지가 생성되었을 것입니다. 여기까지는 일반적인 docker 배포 과정과 같습니다.




자, 이제 그다음 단계로 AKS와 연결된 ACR에 이미지를 올려야 하는데요, 이것 역시 일반적인 docker registry에 올리는 과정과 동일합니다. 그러니까, 태깅 작업과 push를 합니다.

// 아래의 ariestest.azurecr.io 주소는 여러분들의 ACR로 교체합니다.

c:\temp> docker tag dotnet_razor31_sample ariestest.azurecr.io/dotnet_razor31_sample
c:\temp> docker push ariestest.azurecr.io/dotnet_razor31_sample

ACR에 올렸으니, AKS 대시보드의 Azure Cloud Shell이나 로컬에 구성한 Azure CLI에서 응용 프로그램에 대한 배포를 담은 yaml 파일을,

apiVersion: apps/v1
kind: Deployment
metadata:
  name: net-razor31-sample
spec:
  replicas: 1
  selector:
    matchLabels:
      app: dotnet-razor31-sample
  template:
    metadata:
      labels:
        app: dotnet-razor31-sample
    spec:
      containers:
      - name: dotnet-razor31-sample
        image: ariestest.azurecr.io/dotnet_razor31_sample
        ports:
        - containerPort: 80
---
apiVersion: v1
kind: Service
metadata:
  name: dotnet-razor31-sample
spec:
  type: LoadBalancer
  ports:
  - port: 13502
    targetPort: 80
    protocol: TCP
    name: http
  selector:
    app: dotnet-razor31-sample

적용합니다.

C:\temp> kubectl apply -f test.yaml

C:\temp> kubectl get svc
NAME                    TYPE           CLUSTER-IP     EXTERNAL-IP      PORT(S)           AGE
dotnet-razor31-sample   LoadBalancer   10.0.83.129    20.196.248.89    13502:31090/TCP   23m

끝입니다, 이제 yaml의 Service에 지정했던 포트와 EXTERNAL-IP(위의 예제에서는 "http://20.196.248.89:13502/")로 접속하면 서비스가 올라간 것을 확인할 수 있습니다.




해본 김에, Pod에 볼륨도 연결해 볼까요? ^^

이전에 만들어 둔 볼륨을,

AKS/k8s의 Pod에 Volume 연결하는 방법
; https://www.sysnet.pe.kr/2/0/12929

AKS/k8s의 Volume에 파일 복사하는 방법
; https://www.sysnet.pe.kr/2/0/12930

연결하기 위해 다음과 같은 추가 변경만 하면 됩니다.

apiVersion: apps/v1
kind: Deployment
metadata:
  name: net-razor31-sample
spec:
  replicas: 1
  selector:
    matchLabels:
      app: dotnet-razor31-sample
  template:
    metadata:
      labels:
        app: dotnet-razor31-sample
    spec:
      containers:
      - name: dotnet-razor31-sample
        image: ariestest.azurecr.io/dotnet_razor31_sample
        ports:
        - containerPort: 80
        env:
        volumeMounts:
        - mountPath: "/my_dir"
          name: volume
      volumes:
        - name: volume
          persistentVolumeClaim:
            claimName: my-azure-file
...[생략]...

역시 변경 사항 적용하고,

C:\temp> kubectl apply -f test.yaml

실제로 볼륨이 연결되었는지 확인하기 위해 pod의 NAME으로,

C:\temp> kubectl get pod
NAME                                  READY   STATUS    RESTARTS   AGE
net-razor31-sample-67cdf4584f-fpl5z   1/1     Running   0          12s

kubectl exec 명령을 실행해 shell로 진입하면,

C:\temp> kubectl exec --stdin --tty net-razor31-sample-67cdf4584f-fpl5z -- /bin/bash

yaml에 지정한 대로 루트 디렉터리 하위에 "my_dir"이 있는 것을 확인할 수 있습니다.

C:\temp> kubectl exec --stdin --tty net-razor31-sample-67cdf4584f-fpl5z -- /bin/bash

root@aks-agentpool-20726260-vmss000000:/app# ls /
app  bin  boot  dev  etc  home  lib  lib64  media  mnt  my_dir  opt  proc  root  run  sbin  srv  sys  tmp  usr  var




그 외에, autoscale 기능도 테스트해 보시고. ^^

AKS 환경에 응용 프로그램 배포 방법
; https://www.sysnet.pe.kr/2/0/12927#autoscale




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/25/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
12994정성태3/8/20221901오류 유형: 798. WinDbg - Failed to load data access module, 0x80004002
12993정성태3/4/20221886.NET Framework: 1172. .NET에서 Producer/Consumer를 구현하는 기초 인터페이스 - IProducerConsumerCollection<T>
12992정성태3/3/20222386.NET Framework: 1171. C# - BouncyCastle을 사용한 암호화/복호화 예제파일 다운로드1
12991정성태3/2/20221886.NET Framework: 1170. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 transcode_aac.c 예제 포팅
12990정성태3/2/20221939오류 유형: 797. msbuild - The BaseOutputPath/OutputPath property is not set for project '[...].vcxproj'
12989정성태3/2/20222159오류 유형: 796. mstest.exe - System.IO.FileNotFoundException: Could not load file or assembly 'Microsoft.VisualStudio.QualityTools.Tips.WebLoadTest.Tip
12988정성태3/2/20221378오류 유형: 795. CI 환경에서 Docker build 시 csproj의 Link 파일에 대한 빌드 오류
12987정성태3/1/20221852.NET Framework: 1169. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 demuxing_decoding.c 예제 포팅
12986정성태2/28/20221906.NET Framework: 1168. C# -IIncrementalGenerator를 적용한 Version 2 Source Generator 실습
12985정성태2/28/20222118.NET Framework: 1167. C# -Version 1 Source Generator 실습
12984정성태2/24/20221899.NET Framework: 1166. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 filtering_video.c 예제 포팅
12983정성태2/24/20221965.NET Framework: 1165. .NET Core/5+ 빌드 시 runtimeconfig.json에 설정을 반영하는 방법
12982정성태2/24/20221868.NET Framework: 1164. HTTP Error 500.31 - ANCM Failed to Find Native Dependencies
12981정성태2/23/20221823VC++: 154. C/C++ 언어의 문자열 Literal에 인덱스 적용하는 구문 [1]
12980정성태2/23/20222218.NET Framework: 1163. C# - 윈도우 환경에서 usleep을 호출하는 방법 [2]
12979정성태2/22/20222711.NET Framework: 1162. C# - 인텔 CPU의 P-Core와 E-Core를 구분하는 방법파일 다운로드1
12978정성태2/21/20221950.NET Framework: 1161. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 resampling_audio.c 예제 포팅
12977정성태2/21/20223757.NET Framework: 1160. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 qsv 디코딩
12976정성태2/21/20222125VS.NET IDE: 174. Visual C++ - "External Dependencies" 노드 비활성화하는 방법
12975정성태2/20/20222524.NET Framework: 1159. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 qsvdec.c 예제 포팅파일 다운로드1
12974정성태2/20/20222176.NET Framework: 1158. C# - SqlConnection의 최소 Pooling 수를 초과한 DB 연결은 언제 해제될까요?
12973정성태2/16/20222515개발 환경 구성: 639. ffmpeg.exe - Intel Quick Sync Video(qsv)를 이용한 인코딩 [3]
12972정성태2/16/20222333Windows: 200. Intel CPU의 내장 그래픽 GPU가 작업 관리자에 없다면? [4]
12971정성태2/15/20223429.NET Framework: 1157. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 muxing.c 예제 포팅 [7]파일 다운로드1
12970정성태2/15/20222326.NET Framework: 1156. C# - ffmpeg(FFmpeg.AutoGen): Bitmap으로부터 h264 형식의 파일로 쓰기 [1]파일 다운로드1
12969정성태2/14/20222200개발 환경 구성: 638. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구 - 두 번째 이야기파일 다운로드1
1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...