-
Notifications
You must be signed in to change notification settings - Fork 16
[문은서]Sprint8 #112
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: 문은서
Are you sure you want to change the base?
[문은서]Sprint8 #112
Conversation
application: | ||
name: discodeit | ||
datasource: | ||
url: jdbc:postgresql://localhost:5432/discodeit |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
url 도 환경변수에 담으셔도 괜찮을것 같아요!
@@ -0,0 +1,84 @@ | |||
CREATE TABLE users ( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
인덴트가 너무 안맞습니다! 맞춰주시면 좋을 것 같습니다 :)
주석으로 처리된 안쓰는 코드들이 너무 많은것 같아요! |
요구사항
Dockerfile 작성
/app
).dockerignore
를 활용해 제외하세요.PROJECT_NAME: discodeit
PROJECT_VERSION: 1.2-M8
JVM_OPTS
: 기본값은 빈 문자열로 정의이미지 빌드 및 실행 테스트
prod
프로필로 실행하세요.Docker Compose 구성
docker-compose.yml
파일을 작성합니다..env
파일을 활용하되,.env
는 형상관리에서 제외하여 보안을 유지하세요.BinaryContentStorage
데이터가 유지되도록 하세요.schema.sql
이 자동으로 실행되도록 구성하세요.depends_on
).--build
플래그를 사용하여 서비스 시작 전에 이미지를 빌드하도록 합니다.BinaryContentStorage 고도화 (AWS S3)
AWS S3 버킷 구성
discodeit-binary-content-storage-(사용자 이니셜)
형식으로 지정하세요.AWS S3 접근을 위한 IAM 구성
discodeit
)를 생성하세요.AmazonS3FullAccess
권한을 할당하고, 사용자 생성을 완료하세요..env
파일에 추가합니다..env
파일은 리뷰를 위해 PR에 별도로 첨부해주세요. 단, 액세스 키와 시크릿 키는 제외하세요.AWS S3 테스트
implementation 'software.amazon.awssdk:s3:2.31.7'
AWS를 활용한 배포 (AWS RDS, ECR, ECS)
AWS RDS 구성
AWS RDS PostgreSQL 인스턴스를 생성하세요.
과금이 발생할 수 있으니 다음 항목을 한 번 더 확인해주세요.
SSH 터널링을 통해 개발 환경에서 접근할 수 있도록 EC2를 구성하세요.
DataGrip을 통해 연결 후 데이터베이스와 사용자, 테이블을 초기화하세요.
SSH/SSL > Use SSH tunnel
설정을 활성화하세요. 이때 다운로드한.pem
파일을 활용하세요.작업이 완료되면
rds-ssh
인스턴스는 완전히 삭제하여 과금에 유의하세요.AWS ECR 구성
이미지를 배포할 퍼블릭 레포지토리(
discodeit
)를 생성하세요.AWS CLI를 설치하세요.
aws configure
실행 후 앞서 생성한discodeit
IAM 사용자 정보를 입력하세요.discodeit
IAM 사용자가 ECR에 접근할 수 있도록 다음 권한을 부여하세요.AmazonElasticContainerRegistryPublicFullAccess
Docker 클라이언트로 ECR 퍼블릭 레포지토리에 대해 인증합니다.
멀티 플랫폼 이미지를 빌드해서
discodeit
레포지토리에 push 하세요.linux/amd64,linux/arm64
AWS 콘솔에서 푸시된 이미지를 확인하세요.
AWS ECS 구성
배포 환경에서 컨테이너 실행 간 사용할 환경 변수를 정의하고, S3에 업로드하세요.
discodeit.env
파일을 만들어 다음 내용을 작성하세요.AWS ECS 콘솔에서 클러스터를 생성하세요.
태스크를 정의하세요.
discodeit
클러스터 상세 화면에서 서비스를 생성하세요.태스크의 EC2 보안 그룹 인바운드 규칙을 설정하여 어디서든 접근할 수 있도록 하세요.
태스크 실행이 완료되면 해당 EC2의 퍼블릭 IP에 접속해보세요.
심화 요구사항
이미지 최적화하기
멀티 스테이지(빌드, 런타임) 빌드를 활용해 이미지 크기를 줄여보세요.
local-slim
1.2-M8
또는local
)와 크기를 비교해보세요.이미지 레이어 캐시를 고려해 Dockerfile을 수정해보세요.
GitHub Actions를 활용한 CI/CD 파이프라인 구축
CI(지속적 통합)을 위한 워크플로우 설정
.github/workflows/test.yml
파일을 생성하세요.CD(지속적 배포)를 위한 워크플로우 설정
.github/workflows/deploy.yml
파일을 생성하세요.AWS 정보 설정
GitHub 레포지토리 설정을 통해 시크릿을 추가하세요.
AWS_ACCESS_KEY
: IAM 사용자의 액세스 키AWS_SECRET_KEY
: IAM 사용자의 시크릿 키GitHub 레포지토리 설정을 통해 변수를 추가하세요.
AWS_REGION
: AWS 리전 (ap-northeast-2)ECR_REPOSITORY_URI
: ECR 레포지토리 URIECS_CLUSTER
: ECS 클러스터 이름 (discodeit-cluster)ECS_SERVICE
: ECS 서비스 이름 (discodeit-service)ECS_TASK_DEFINITION
: ECS 태스크 정의 이름 (discodeit-task)Docker 이미지 빌드 및 푸시
Docker 이미지를 빌드하고 푸시하는 Job을 정의하세요.
AWS CLI를 설정하는 Step을 추가하세요.
us-east-1
로 설정해야 합니다.ECR 로그인 Step을 추가하세요.
Docker 이미지를 빌드 및 푸시하는 과정을 Step으로 추가하세요.
x86_64
입니다.ECS 서비스 업데이트
ECS 서비스를 업데이트하는 Job을 정의하세요.
AWS CLI를 설정하는 Step을 추가하세요.
AWS_REGION
으로 설정해야 합니다.태스크 정의를 업데이트하는 Step을 추가하세요.
프리티어 리소스를 고려해 AWS CLI를 사용해 기존에 구동 중인 서비스를 중단하는 Step을 추가하세요.
aws ecs update-service --desired-count
옵션을 활용하세요.새로 등록한 태스크 정의를 사용하도록 ECS 서비스를 업데이트하는 Step을 추가하세요.
AWS 콘솔을 통해 새로 등록된 태스크 정의로 배포되었는지 확인하세요.
멘토에게