[StudyWithMe] 스터디 윗 미 dev 무중단 배포
·
프로젝트/StudyWithMe
우선, 이번에 디자이너 1명과 프론트엔드 2명이 들어왔기에 원할한 개발을 위한 `dev`서버가 필요했다.  그렇기에 이번 포스팅에서는 `StudyWithMe`의 `dev` 서버의 무중단 배포에 관해 포스팅 하려고 한다.  무중단 CI/CD 아키텍처설명하기에 앞서 구축한 `CI/CD` 아키텍처는 다음과 같다.   미니PC 환경`StudyWithMe` 서버는 현재 같이 작업하시는 백엔드분의 미니PC에서 동작하고 있다. 현재 미니PC 서버의 동작 컴포넌트들80포트 사용 다용도 NGINXPortainer(웹 UI 기반 컨테이너 관리)내가 쓰는 건 아니고 다른 백엔드 분이 사용하신다.Private Docker Registry(프라이빗 도커 레지스트리)GrafanaPrometheus가 존재한다. 위에서 중점적으로 ..
[AWS] ECR + ECS + ALB + Route53 + Spring + Github Actions - 3
·
DevOps/AWS
AWS에 ECS로 배포하기의 마지막 포스팅인Github Actions를 활용한 `ECS` `CI/CD` 배포에 관해 알아보려 한다.name: CI-CD PortNumber Back-End Serviceon: push: branches: - BEjobs: deploy: runs-on: ubuntu-latest env: AWS_REGION: ap-northeast-2 ECS_CLUSTER_NAME: {ECS 클러스터 이름} ECR_REPOSITORY_NAME: {ECS 레포지토리 이름} ECS_SERVICE_NAME: {ECS 서비스 이름} ECS_CONTAINER_NAME: {ECS 컨테이너 이름} TASK_DEFINITIO..
[AWS] ECR + ECS + ALB + Route53 + Spring + Github Actions - 2
·
DevOps/AWS
우리는 저번 포스팅에서 네트워크 구성까지 진행해 보았다. 이제는 `ALB`와 Route53을 이용한 인증서 설정을 구현해보자.  로드 밸런서를 사용하는 이유는 뭘까?앞 포스팅에서 ECS 클러스터 및 서비스를 생성하며 느낄 수 있었겠지만,`AWS ECS Fargate` 사용시 아주 쉽게 무중단 배포가 가능해지며 원하는 태스크, 컨테이너, 서비스를 생성할 수 있다. 즉, `Scale-Out`이 굉장히 간단하게 구현이 된다는 것을 알 수 있다. 하지만, `Scale Out`만 잘돼선 의미가 없다. 결국 다양한 서비스 및 컨테이너가 효율적으로 사용이 되며, 트래픽 분산이 되고, 무중단 배포를 구현하려면`ALB`와 같은 로드 밸런서가 필요하다.  만약, Spring 서버를 `Scale-Out`을 했다고 가정하자...
[AWS] ECR + ECS + ALB + Route53 + Spring + Github Actions - 1
·
DevOps/AWS
사이드 프로젝트에 참가하게 되어 기존의 `EC2`를 사용한 방법대신 `ECS`를 사용한 배포를 진행했다.  우선, `Amazon ECS on Fargate`가 뭘까?AWS Fargate는 EC2 인스턴스와 달리 서버리스 방식으로 Amazon ECS에서 컨테이너를실행할 수 있도록 도와주는 서비스이다. Amazon ECS on Fargate를 사용하면 컨테이너를 실행하기 위해 가상 머신 서버의 클러스터를`프로비저닝`하거나 구성하고,  관리할 필요가 없다. 또한, 서버 사용량을 고려하여 유형을 선택하거나, 클러스터를 조정해야 할 시점을 고민하거나 클러스터 패킹을최적화 할 필요가 없어지는 AWS 컨테이너 생성 및 관리 서비스이다. 무중단 배포(블루/그린, 롤링)도 알아서 해주기에 굉장히 편리하다는 장점이 있다...
[트러블슈팅] 무중단 배포간 Docker Compose 오류 해결
·
프로젝트/FitTrip
🐞 버그 설명 상황FitTrip은 GCP의 GCE를 사용하여 서비스 배포를 진행했습니다. FitTrip 서비스는 MSA를 목표로 하기에 각 서비스의 무중단 배포 과정이 필요했고관련하여 작업을 자동화 시켜주는 Makefile를 작성했습니다. Makefile 일부.PHONY: up down user-update community-update chat-update state-update sig-update notification-updateall: upup: docker-compose pull docker-compose up -d zookeeper kafka discovery-service gateway-service user-service community-service chat-..
2024-05-26(배포, docker-compose, Spring Cloud, Github Actions)
·
개발 기록
이번 캡스톤 프로젝트에서 배포를 맞게 되었고Spring Cloud를 처음 사용해보며 여러 작업을 하고 있다.docker-compose를 이용하여 컨테이너가 같은 도커 네트워크 환경을 공유할 수 있도록 하였고 MSA의 장점에 걸맞게 스케일 아웃했을 때 서버가 중단되지 않고 배포가 되는무중단 배포를 위해 Makefile를 제작하였다.(필자의 생각에 근거하여 Makefile을 작성하였기 때문에 이게 옳은 방법이라곤 할 수 없다.)  Makefile 초안(지금은 조금 다름).PHONY: up downup: docker-compose pull docker-compose up -d zookeeper kafka discovery-service gateway-service redis-user ..