[ARV-224] fix: mongoTemplate ๊ด๋ จ ์๋ฌ ์์ #325
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI/CD | |
on: | |
push: | |
branches: | |
- develop | |
pull_request: | |
jobs: | |
ci: | |
runs-on: ubuntu-latest | |
services: | |
mysql: | |
image: mysql:latest | |
ports: | |
- 3306:3306 | |
env: | |
MYSQL_ROOT_PASSWORD: ${{ secrets.MYSQL_ROOT_PASSWORD }} | |
MYSQL_DATABASE: ${{ secrets.MYSQL_DB }} | |
redis: | |
image: redis:latest | |
ports: | |
- 6379:6379 | |
mongodb: | |
image: mongo:latest | |
ports: | |
- "27017:27017" | |
env: | |
MONGO_INITDB_ROOT_USERNAME: ${{ secrets.MONGO_INITDB_ROOT_USERNAME }} | |
MONGO_INITDB_ROOT_PASSWORD: ${{ secrets.MONGO_INITDB_ROOT_PASSWORD }} | |
MONGO_INITDB_DATABASE: ${{ secrets.MONGO_INITDB_DATABASE }} | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'temurin' | |
- name: Create application.yml | |
run: | | |
mkdir -p src/main/resources | |
mkdir -p src/test/resources | |
echo "${{ secrets.CI_YML }}" | base64 --decode > src/main/resources/application.yml | |
echo "${{ secrets.CI_YML }}" | base64 --decode > src/test/resources/application.yml | |
- name: Create firebase-service-account.json | |
run: | | |
mkdir -p src/main/resources/firebase | |
echo "${{ secrets.FIREBASE_SERVICE_ACCOUNT }}" | base64 --decode > src/main/resources/firebase/firebase-service-account.json | |
- name: Grant execute permission for gradlew | |
run: chmod +x gradlew | |
- name: Run tests | |
run: ./gradlew test | |
cd: | |
needs: ci | |
if: github.event_name == 'push' | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Create application.yml | |
run: | | |
mkdir -p src/main/resources | |
mkdir -p src/main/resources/firebase | |
echo "${{ secrets.CD_YML }}" | base64 --decode > src/main/resources/application.yml | |
echo "${{ secrets.FIREBASE_SERVICE_ACCOUNT }}" | base64 --decode > src/main/resources/firebase/firebase-service-account.json | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'temurin' | |
- name: Gradle Caching | |
uses: actions/cache@v3 | |
with: | |
path: | | |
~/.gradle/caches | |
~/.gradle/wrapper | |
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }} | |
restore-keys: | | |
${{ runner.os }}-gradle- | |
- name: Build with Gradle | |
run: | | |
chmod +x gradlew | |
./gradlew bootJar | |
- name: DockerHub ๋ก๊ทธ์ธ | |
uses: docker/login-action@v2 | |
with: | |
username: ${{ secrets.DOCKERHUB_USERNAME }} | |
password: ${{ secrets.DOCKERHUB_PASSWORD }} | |
- name: Docker ์ด๋ฏธ์ง ๋น๋ | |
run: docker build -t ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.APP_NAME }}:latest . | |
- name: DockerHub ํธ์ | |
run: docker push ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.APP_NAME }}:latest | |
- name: Get Github action IP | |
id : ip | |
uses: haythem/[email protected] | |
- name: AWS Credentials ์ค์ | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: ${{ secrets.AWS_REGION }} | |
- name: ๋ณด์ ๊ทธ๋ฃน์ GitHub Actions IP ์ถ๊ฐ | |
run: | | |
aws ec2 authorize-security-group-ingress \ | |
--group-name ${{ secrets.AWS_SG_NAME }} \ | |
--protocol tcp \ | |
--port 22 \ | |
--cidr ${{ steps.ip.outputs.ipv4 }}/32 | |
- name: Create .env file | |
run: | | |
echo "DOCKERHUB_USERNAME=${{ secrets.DOCKERHUB_USERNAME }}" >> .env | |
echo "APP_NAME=${{ secrets.APP_NAME }}" >> .env | |
- name: Send docker-compose.yml | |
uses: appleboy/scp-action@master | |
with: | |
host: ${{ secrets.EC2_HOST }} | |
username: ${{ secrets.EC2_USERNAME }} | |
key: ${{ secrets.EC2_SSH_KEY }} | |
port: 22 | |
source: "docker-compose.yml, .env" | |
target: "/home/ec2-user" | |
- name: Send deploy.sh | |
uses: appleboy/scp-action@master | |
with: | |
host: ${{ secrets.EC2_HOST }} | |
username: ${{ secrets.EC2_USERNAME }} | |
key: ${{ secrets.EC2_SSH_KEY }} | |
port: 22 | |
source: "deploy.sh" | |
target: "/home/ec2-user" | |
- name: AWS EC2 ๋ฐฐํฌ | |
uses: appleboy/ssh-action@master | |
with: | |
host: ${{ secrets.EC2_HOST }} | |
username: ${{ secrets.EC2_USERNAME }} | |
key: ${{ secrets.EC2_SSH_KEY }} | |
port: 22 | |
script: | | |
sudo chmod 666 /var/run/docker.sock | |
echo "${{ secrets.DOCKERHUB_PASSWORD }}" | docker login -u ${{ secrets.DOCKERHUB_USERNAME }} --password-stdin | |
docker pull ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.APP_NAME }}:latest | |
chmod 777 ./deploy.sh | |
./deploy.sh | |
sudo docker image prune -f | |
- name: ๋ณด์ ๊ทธ๋ฃน์์ GitHub Actions IP ์ ๊ฑฐ | |
if: always() | |
run: | | |
aws ec2 revoke-security-group-ingress \ | |
--group-name ${{ secrets.AWS_SG_NAME }} \ | |
--protocol tcp \ | |
--port 22 \ | |
--cidr ${{ steps.ip.outputs.ipv4 }}/32 |