kt-event-marketing/claude/run-container-guide-back.md
merrycoral 0c718c67f6 백엔드 컨테이너 실행 가이드 작성
- deployment/container/run-container-guide.md 생성
- 4개 서비스(user, event, analytics, participation) 컨테이너 실행 방법 안내
- VM 접속, ACR 설정, 이미지 푸시, 컨테이너 실행, 재배포 절차 포함
- CORS 설정에 프론트엔드 주소(http://20.196.65.160:3000) 추가
- 실행정보: ACR(acrdigitalgarage01), VM(20.196.65.160)
2025-10-28 15:26:35 +09:00

187 lines
5.7 KiB
Markdown

# 백엔드 컨테이너 실행방법 가이드
[요청사항]
- 백엔드 각 서비스들의 컨테이너 이미지를 컨테이너로 실행하는 가이드 작성
- 실제 컨테이너 실행은 하지 않음
- '[결과파일]'에 수행할 명령어를 포함하여 컨테이너 실행 가이드 생성
[작업순서]
- 실행정보 확인
프롬프트의 '[실행정보]'섹션에서 아래정보를 확인
- {ACR명}: 컨테이너 레지스트리 이름
- {VM.KEY파일}: VM 접속하는 Private Key파일 경로
- {VM.USERID}: VM 접속하는 OS 유저명
- {VM.IP}: VM IP
예시)
```
[실행정보]
- ACR명: acrdigitalgarage01
- VM
- KEY파일: ~/home/bastion-dg0500
- USERID: azureuser
- IP: 4.230.5.6
```
- 시스템명과 서비스명 확인
settings.gradle에서 확인.
- 시스템명: rootProject.name
- 서비스명: include 'common'하위의 include문 뒤의 값임
예시) include 'common'하위의 4개가 서비스명임.
```
rootProject.name = 'tripgen'
include 'common'
include 'user-service'
include 'location-service'
include 'ai-service'
include 'trip-service'
```
- VM 접속 방법 안내
- Linux/Mac은 기본 터미널을 실행하고 Window는 Window Terminal을 실행하도록 안내
- 터미널에서 아래 명령으로 VM에 접속하도록 안내
최초 한번 Private key파일의 모드를 변경.
```
chmod 400 {VM.KEY파일}
```
private key를 이용하여 접속.
```
ssh -i {VM.KEY파일} {VM.USERID}@{VM.IP}
```
- 접속 후 docker login 방법 안내
```
docker login {ACR명}.azurecr.io -u {ID} -p {암호}
```
- Git Repository 클론 안내
- workspace 디렉토리 생성 및 이동
```
mkdir -p ~/home/workspace
cd ~/home/workspace
```
- 소스 Clone
```
git clone {원격 Git Repository 주소}
```
예)
```
git clone https://github.com/cna-bootcamp/phonebill.git
```
- 프로젝트 디렉토리로 이동
```
cd {시스템명}
```
- 어플리케이션 빌드 및 컨테이너 이미지 생성 방법 안내
'deployment/container/build-image.md' 파일을 열어 가이드대로 수행하도록 안내
- 컨테이너 레지스트리 로그인 방법 안내
아래 명령으로 {ACR명}의 인증정보를 구합니다.
'username'이 ID이고 'passwords[0].value'가 암호임.
```
az acr credential show --name {ACR명}
```
예시) ID=dg0200cr, 암호={암호}
```
$ az acr credential show --name dg0200cr
{
"passwords": [
{
"name": "password",
"value": "{암호}"
},
{
"name": "password2",
"value": "{암호2}"
}
],
"username": "dg0200cr"
}
```
아래와 같이 로그인 명령을 작성합니다.
```
docker login {ACR명}.azurecr.io -u {ID} -p {암호}
```
- 컨테이너 푸시 방법 안내
Docker Tag 명령으로 이미지를 tag하는 명령을 작성합니다.
```
docker tag {서비스명}:latest {ACR명}.azurecr.io/{시스템명}/{서비스명}:latest
```
이미지 푸시 명령을 작성합니다.
```
docker push {ACR명}.azurecr.io/{시스템명}/{서비스명}:latest
```
- 컨테이너 실행 명령 생성
- 환경변수 확인
'{서비스명}/.run/{서비스명}.run.xml' 을 읽어 각 서비스의 환경변수 찾음.
"env.map"의 각 entry의 key와 value가 환경변수임.
예제) SERVER_PORT=8081, DB_HOST=20.249.137.175가 환경변수임
```
<component name="ProjectRunConfigurationManager">
<configuration default="false" name="ai-service" type="GradleRunConfiguration" factoryName="Gradle">
<ExternalSystemSettings>
<option name="env">
<map>
<entry key="SERVER_PORT" value="8084" />
<entry key="DB_HOST" value="20.249.137.175" />
```
- 아래 명령으로 컨테이너를 실행하는 명령을 생성합니다.
- shell 파일을 만들지 말고 command로 수행하는 방법 안내.
- 모든 환경변수에 대해 '-e' 파라미터로 환경변수값을 넘깁니다.
- 중요) CORS 설정 환경변수에 프론트엔드 주소 추가
- 'ALLOWED_ORIGINS' 포함된 환경변수가 CORS 설정 환경변수임.
- 이 환경변수의 값에 'http://{VM.IP}:3000'번 추가
```
SERVER_PORT={환경변수의 SERVER_PORT값}
docker run -d --name {서비스명} --rm -p ${SERVER_PORT}:${SERVER_PORT} \
-e {환경변수 KEY}={환경변수 VALUE}
{ACR명}.azurecr.io/{시스템명}/{서비스명}:latest
```
- 실행된 컨테이너 확인 방법 작성
아래 명령으로 모든 서비스의 컨테이너가 실행 되었는지 확인하는 방법을 안내.
```
docker ps | grep {서비스명}
```
- 재배포 방법 작성
- 로컬에서 수정된 소스 푸시
- VM 접속
- 디렉토리 이동 및 소스 내려받기
```
cd ~/home/workspace/{시스템명}
```
```
git pull
```
- 컨테이너 이미지 재생성
'deployment/container/build-image.md' 파일을 열어 가이드대로 수행
- 컨테이너 이미지 푸시
```
docker tag {서비스명}:latest {ACR명}.azurecr.io/{시스템명}/{서비스명}:latest
docker push {ACR명}.azurecr.io/{시스템명}/{서비스명}:latest
```
- 컨테이너 중지
```
docker stop {서비스명}
```
- 컨테이너 이미지 삭제
```
docker rmi {ACR명}.azurecr.io/{시스템명}/{서비스명}:latest
```
- 컨테이너 재실행
[결과파일]
deployment/container/run-container-guide.md