Skip to content

Commit

Permalink
KL-184/deploy: apply makefile
Browse files Browse the repository at this point in the history
  • Loading branch information
ohhamma committed Oct 8, 2024
1 parent b4f3e3f commit e592697
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 35 deletions.
71 changes: 36 additions & 35 deletions .github/workflows/deploy.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Build and Deploy using Docker Compose
name: Build and Deploy using Makefile and Docker Compose

on:
push:
Expand All @@ -8,52 +8,51 @@ on:
workflow_dispatch:

jobs:
build-deploy:
build-and-deploy:
runs-on: ubuntu-latest
environment: dev
strategy:
matrix:
java-version: [ 17 ]
distribution: [ "zulu" ]

steps:
- name: Checkout
- name: Checkout Repository
uses: actions/checkout@v4

- name: Set up JDK
uses: actions/setup-java@v2
- name: Set up JDK 17
uses: actions/setup-java@v4
with:
java-version: '17'
distribution: 'temurin'

- name: Set up Gradle
uses: gradle/actions/setup-gradle@v3
with:
java-version: ${{ matrix.java-version }}
distribution: ${{ matrix.distribution }}
gradle-version: 8.8

- name: Grant execute permission for gradlew
run: chmod +x ./gradlew
- name: Create .env file
run: |
touch .env
echo "${{ secrets.ENV }}" > .env
shell: bash

- name: Build with Gradle
run: ./gradlew clean build -x test
- name: Build with Makefile
run: make build

- name: Run tests
run: make test

- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: Build and Push Docker image
uses: docker/build-push-action@v5
with:
context: .
file: ./Dockerfile
platforms: linux/amd64/v3
push: true
tags: ${{ secrets.DOCKER_USERNAME }}/${{ secrets.DOCKER_IMAGE_NAME }}:latest

- name: Copy compose.yaml to EC2
uses: appleboy/scp-action@master
with:
host: ${{ secrets.EC2_HOST }}
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.EC2_KEY }}
source: "compose.yaml"
target: "~/"
- name: Build and Push Docker Image
env:
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
DOCKER_IMAGE_NAME: ${{ secrets.DOCKER_IMAGE_NAME }}
run: |
docker compose build
docker tag klkl-server:latest $DOCKER_USERNAME/$DOCKER_IMAGE_NAME:latest
docker push $DOCKER_USERNAME/$DOCKER_IMAGE_NAME:latest
- name: Deploy to EC2
uses: appleboy/ssh-action@master
Expand All @@ -62,6 +61,8 @@ jobs:
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.EC2_KEY }}
script: |
sudo docker pull ${{ secrets.DOCKER_USERNAME }}/${{ secrets.DOCKER_IMAGE_NAME }}:latest
sudo docker compose -f ~/compose.yaml -p klkl-server up -d
sudo docker image prune -a -f
export DOCKER_USERNAME=${{ secrets.DOCKER_USERNAME }}
export DOCKER_IMAGE_NAME=${{ secrets.DOCKER_IMAGE_NAME }}
docker pull $DOCKER_USERNAME/$DOCKER_IMAGE_NAME:latest
docker compose -f ~/compose.yaml -p klkl-server up -d
docker image prune -a -f
2 changes: 2 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ DOCKER_VOLUME := $(shell docker volume ls -q)

up:
@make build
DOCKER_USERNAME=${DOCKER_USERNAME}
DOCKER_IMAGE_NAME=${DOCKER_IMAGE_NAME}
docker compose up --build -d

upi:
Expand Down
1 change: 1 addition & 0 deletions compose.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
version: "3"
services:
spring:
image: ${DOCKER_USERNAME}/${DOCKER_IMAGE_NAME}:latest
build: .
ports:
- "8080:8080"
Expand Down

0 comments on commit e592697

Please sign in to comment.