Skip to content

Update be-cd-dev.yml #130

Update be-cd-dev.yml

Update be-cd-dev.yml #130

Workflow file for this run

name: BE CD for Dev
on:
push:
branches:
- dev
permissions:
contents: read
jobs:
build-and-docker-operations:
runs-on: ubuntu-latest
outputs:
image_tag: ${{ steps.generate_tag.outputs.tag }}
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'corretto'
- name: Update application.yml
run: |
echo "${{ secrets.APPLICATION }}" > ./src/main/resources/application.yml
- name: Set up Gradle
uses: gradle/actions/setup-gradle@v3
with:
cache-write-only: true
- name: Set up Docker
uses: docker/setup-buildx-action@v2
- name: Grant execute permission for Gradlew
run: chmod +x ./gradlew
- name: Build JAR
run: ./gradlew bootjar
- name: Generate Unique Tag
id: generate_tag
run: echo "::set-output name=tag::$(echo $GITHUB_SHA | cut -c1-7)"
- name: Build image
run: docker build -f docker/Dockerfile -t ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPOSITORY_NAME }}:${{ steps.generate_tag.outputs.tag }} .
- name: Login to DockerHub
uses: docker/login-action@v1
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_ACCESS_TOKEN }}
- name: Push image
run: docker push ${{ secrets.DOCKERHUB_USERNAME }}/${{ secrets.DOCKERHUB_REPOSITORY_NAME }}:${{ steps.generate_tag.outputs.tag }}
- name: Set up SSH key
run: |
mkdir -p ~/.ssh
echo "${{ secrets.EC2_SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
chmod 600 ~/.ssh/id_rsa
- name: Add EC2 to known hosts
run: |
ssh-keyscan -H ${{ secrets.EC2_HOST }} >> ~/.ssh/known_hosts
deploy:
needs: build-and-docker-operations
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Copy Docker files
uses: appleboy/scp-action@master
with:
host: ${{ secrets.EC2_HOST }}
username: "ubuntu"
key: ${{ secrets.EC2_SSH_PRIVATE_KEY }}
port: 22
source: "docker/docker-compose.yml,docker/scripts/docker-install.sh,docker/nginx/default.conf,docker/nginx/Dockerfile-nginx"
target: 'compose'
rm: true
- name: SSH remote and Run Docker Compose
uses: appleboy/ssh-action@master
env:
MYSQL_DB_NAME: ${{ secrets.MYSQL_DB_NAME }}
MYSQL_DB_USERNAME: ${{ secrets.MYSQL_DB_USERNAME }}
MYSQL_DB_PASSWORD: ${{ secrets.MYSQL_DB_PASSWORD }}
IMAGE_TAG: ${{ needs.build-and-docker-operations.outputs.image_tag }}
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
DOCKERHUB_REPOSITORY_NAME: ${{ secrets.DOCKERHUB_REPOSITORY_NAME }}
with:
host: ${{ secrets.EC2_HOST }}
username: "ubuntu"
key: ${{ secrets.EC2_SSH_PRIVATE_KEY }}
port: 22
envs: MYSQL_DB_NAME,MYSQL_DB_USERNAME,MYSQL_DB_PASSWORD,IMAGE_TAG,DOCKERHUB_USERNAME,DOCKERHUB_REPOSITORY_NAME
script: |
cd compose/docker/
sudo touch .env
sudo echo "
MYSQL_DB_NAME=$MYSQL_DB_NAME
MYSQL_DB_USERNAME=$MYSQL_DB_USERNAME
MYSQL_DB_PASSWORD=$MYSQL_DB_PASSWORD
IMAGE_TAG=$IMAGE_TAG
DOCKERHUB_USERNAME=$DOCKERHUB_USERNAME
DOCKERHUB_REPOSITORY_NAME=$DOCKERHUB_REPOSITORY_NAME" | sudo tee .env
sh ./scripts/docker-install.sh
sudo docker pull $DOCKERHUB_USERNAME/$DOCKERHUB_REPOSITORY_NAME:$IMAGE_TAG
sudo docker-compose down
sudo docker-compose up -d