Initial written at october 06, 2024
last updated at: September 20, 2024
- ver 1.0.0.
- Init: 프로젝트 세팅 ( React + Spring Boot )
- CORS 설정
- CICD 파이프라인 추가 ( Github Actions + AWS ECR ( Public ) & ECS ( Fargate ) ) + Application Load Balancer
- JSON 형식의 ECS 작업 파일을 추가
- ver. 1.0.0 배포 ( 2024.10.06 )
- ver 1.0.1.
- CICD 파이프라인 변경 ( Github Actions + AWS ECR ( Private ) & ECS ( Fargate ) ) + Network Load Balancer
- AWS ECS 태스크 JSON 파일 제거 -> Github Actions CLI를 사용해 불러오기
- Github Actions의 CD 작업 병렬화 ( React와 Springboot 작업 분리 )
- ver. 1.0.1 배포 ( 2024.10.06 )
- 본 프로젝트의 운영체제는 Linux OS를 기반으로 작성되었습니다.
- 본 프로젝트는 Spring Security와 JWT를 고려하지 않은 프로젝트 입니다. ( 추후에 Spring Security를 도입할 경우 Filter와 연결해서 고려할 예정입니다. )
- 본 프로젝트는 CORS 설정의 경우 Backend에서 설정하는 것이 바람직하다고 생각하여 Spring Boot 프로젝트에서 설정을 했습니다.
- 본 프로젝트는 Docker를 사용하므로
.env.template
파일을 참고하여.env
파일에 환경 변수값을 작성해주세요.- root, react-app, springboot-app 총 3가지 파일을 모두 작성해주세요.
HOST_PORT
: 외부에서 컨테이너의 애플리케이션에 접근하는데 사용하는 포트 ( 노출되도 괜찮은 포트 )SERVER_PORT
: 애플리케이션이 컨테이너 내에서 통신하는 포트 ( 노출되면 안되는 포트 )- Vite에서는 보안이 필요한 환경변수의 유출을 막기 위해서
VITE_
으로 시작하지 않는 환경변수는 무시되기 때문에VITE_SPRINGBOOT_HOST_PORT
가 필요합니다. IP_ADDRESS
: 사용하는 도메인 혹은 로드밸런서 DNS이름으로 설정해주세요. 만약 로컬 환경이라면localhost
로 설정해주세요.root/.env
: 로컬 환경에서 docker-compose.yml 파일을 실행시키기 위해 필요한 환경 변수 파일입니다.# 예시 SPRINGBOOT_HOST_PORT=8081 SPRINGBOOT_SERVER_PORT=8080 REACT_HOST_PORT=3001 REACT_SERVER_PORT=3000
react-app/.env
: React 애플리케이션 환경을 실행시키기 위해 필요한 환경 변수 파일입니다.# 예시 VITE_REACT_SERVER_PORT=3000 VITE_SPRINGBOOT_HOST_PORT=8081 VITE_IP_ADDRESS=localhost
springboot-app/.env
: Springboot 애플리케이션 환경을 실행시키기 위해 필요한 환경 변수 파일입니다.# 예시 REACT_HOST_PORT=3001 IP_ADDRESS=localhost
- 본 프로젝트는 Springboot를 사용하므로
springboot-app/src/main/resources/application.properties.template
파일을 참고하여application.properties
파일을 생성해주세요.springboot-app/src/main/resources/application.properties
# 예시 spring.application.name=springboot-app server.port=8080
본 프로젝트는 Docker Compose를 사용하므로 이를 실행시켜주세요.
(sudo) docker compose up (--build)
본 프로젝트는 Docker Compose를 사용하므로 이를 실행시켜주세요.
(sudo) docker compose down (-v)
/CICD_GITHUBACTIONS-ECS-ECR
├── .github/
│ └── workflows
│ └── CICD.yml
│
├── docs/
│ ├── PULL_REQUEST_TEMPLATE.md
│ ├── README.md
│ └── secrets.png
│
├── react-app/
│ ├── public/
│ │ └── vite.svg
│ ├── src/
│ │ ├── assets/
│ │ │ └── vite.svg
│ │ ├── App.css
│ │ ├── App.jsx
│ │ ├── index.css
│ │ └── main.jsx
│ │
│ ├── .env
│ ├── .env.template
│ ├── .gitignore
│ ├── dockerfile
│ ├── eslint.config.js
│ ├── index.html
│ ├── package-lock.json
│ ├── package.json
│ ├── README.md
│ └── vite.config.js
│
├── springboot-app/
│ ├── gradle/
│ │ └── wrapper/
│ │ ├── gradle-wrapper.jar
│ │ └── gradle-wrapper.properties
│ ├── src/
│ │ ├── main/
│ │ │ ├── java/com/inha/springbootapp/
│ │ │ │ ├── domain
│ │ │ │ │ └── HelloController.java
│ │ │ │ ├── global
│ │ │ │ │ └── GlobalCorsConfig.java
│ │ │ │ └── springbootAppApplication.java
│ │ │ └── resources/
│ │ │ ├── application.properties
│ │ │ └── application.properties.template
│ │ └── test/
│ │ └── java/com/inha/springbootapp/
│ │ └── springbootAppApplicationTest.java
│ │
│ ├── .env
│ ├── .env.template
│ ├── .gitignore
│ ├── build.gradle
│ ├── dockerfile
│ ├── gradlew
│ ├── gradlew.bat
│ └── settings.gradle
│
├── .env
├── .env.template
├── .gitattributes
├── .gitignore
└── docker-compose.yml