이번에 물류 검수 앱을 개발하면서 전체적인 인프라를 AWS에 구축함에 따라 서비스에 필요한 모든 부분을 구성하게 되었던 경험에 대한 회고를 작성한다. 범위 스택 버전 디펜던시 프론트 Vue 3.1.x Vite 백엔드 SpringBoot 3.0.3 Gradle CICD Github Actions 로그 FastAPI, ELK Pydatic, Alembic 디비 RDS(postgresql) 15 AMQP Kafka Kafka Connector 처음 기획했던 인프라 구조도는 위와 같다. 전체적인 서비스를 기획하면서 개발 플로우를 어떻게 진행할지에 대한 고민이 많았다. 기존에 진행했던 방식은 3가지 브랜치를 운영하는 방식이었다. dev 브랜치: 개발을 진행하는 브랜치로써 머지 리퀘스트를 진행한 후 개발 서버에서 ..
Amazon
Github Actions를 이용해 S3에 배포된 코드 압축 파일은 용량만 차지할 뿐 정말 쓸모가 없다. 백업 용도로 사용하기에도 적합하지 않다. 게다가 배포가 자주 이뤄질 수록 차지하는 용량은 매우 커지기 때문에 매일 S3 객체를 비워서 비용을 아낄 필요가 있어 람다 함수를 만들게 되었다. IAM 역할 만들기 일단 AWS 람다에서 사용할 IAM 역할을 만들어준다. IAM에서 역할을 선택한 후 역할 만들기를 클릭한다. 람다를 클릭해주고 다음으로 넘어간다. AmazonS3FullAccess를 추가해준다. AWSLambdaBasicExecutionRole 도 추가해주고 다음으로 넘어간다. 역할 이름과 설명을 적고, 정책이 제대로 추가되었는지 확인한 후 역할 생성을 클릭한다. LAMBDA 함수 만들기 AWS ..
출처: https://dev.classmethod.jp/articles/ec2tordsconnet-postglesql/ 목표 EC2로 PrivateSubnet에 있는 RDS에 접속하기 작업 포인트 SecurityGroup EC2인스턴스 내부에 DB서버 인스톨 준비 목록 VPC Public/Private Subnet(각1개) EC2 Intance RDS SecurityGroup VPC 구축 VPC생성부터 라우팅테이블 설정까지 따라하시면 됩니다. Security Groups ec2-sg 인바운드 유형 프로토콜 포트 소스 ssh TCP 22 myIP 아웃바운드 유형 프로토콜 포트 소스 모든 트래픽 .. .. 0.0.0.0/0 rds-sg 인바운드 유형 프로토콜 포트 소스 PostgreSQLl TCP 5432 ..
출처: https://docs.aws.amazon.com/ko_kr/codedeploy/latest/userguide/codedeploy-agent-operations-install-linux.html 아래 명령어를 복사해서 ec2 쉘에 입력해주세요. sudo yum update sudo yum install ruby sudo yum install wget cd /home/ec2-user wget chmod +x ./install sudo ./install auto sudo service codedeploy-agent status
docker 설치 아래 명령어를 복사해서 ec2 쉘에 입력해주세요. sudo amazon-linux-extras install docker sudo service docker start sudo usermod -a -G docker ec2-user sudo chkconfig docker on docker version sudo chmod 777 /var/run/docker.sock sudo systemctl start docker 명령어 설명 // 도커 설치 sudo amazon-linux-extras install docker // 도커 시작 sudo service docker start // 권한 부여 sudo usermod -a -G docker ec2-user // auto-start에 docke..