최종 프로젝트에서 백엔드 서버의 CI/CD를 SSH로 간단하게 구축했었다.
그러나, 가끔 scp나 ssh 명령어에서 오류가 뜨는 현상을 종종 직면하게 됐다.
조언을 들어본 바, scp나 ssh로 파일을 전송하거나 작업을 할 때, 메모리 부족 현상으로 위와 같은 오류가 뜰 수도 있다고 한다.
ssh의 에러코드 137번에 대해 검색해본 결과, 메모리 부족 현상이 맞는 것 같았다.
그래서 CI/CD가 항상 제대로 작동할 수 있도록, ssh와 scp 대신 Docker로 바꾸는 작업을 하게 되었다.
이러한 작업 과정에 대해 기록해보는 시간을 가져보겠다.
name: CI/CD
on:
push:
branches:
- main
jobs:
cicd:
runs-on: ubuntu-latest
steps:
- name: Set up CI server
uses: actions/checkout@v4
- name: Set up JDK 21
uses: actions/setup-java@v4
with:
distribution: 'corretto'
java-version: '21'
# Gradle caching
- name: Gradle Caching
uses: actions/cache@v4
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: |
${{ runner.os }}-gradle-
- name: Make application-prod.yml
run: |
cd ./src/main/resources
touch ./application-prod.yml
echo "${{ secrets.YML_PROD }}" > ./application-prod.yml
shell: bash
- name: Grant execute permission for gradlew
run: chmod +x gradlew
- name: gradlew bootJar
run: ./gradlew bootJar
- name: Docker build & push
run: |
docker login -u ${{ secrets.DOCKER_USERNAME }} -p ${{ secrets.DOCKER_PASSWORD }}
docker build -t one-click-recipe:latest .
docker tag one-click-recipe:latest ${{ secrets.DOCKER_USERNAME }}/one-click-recipe:latest
docker push ${{ secrets.DOCKER_USERNAME }}/one-click-recipe:latest
- name: SSH Commands
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SSH_HOST }}
username: ec2-user
key: ${{ secrets.SSH_KEY }}
port: 22
script_stop: false
script: |
sudo docker pull ${{ secrets.DOCKER_USERNAME }}/one-click-recipe
sudo docker stop one-click-recipe
sudo docker rm one-click-recipe
sudo docker run -d -p 8080:8080 --name one-click-recipe ${{ secrets.DOCKER_USERNAME }}/one-click-recipe
sudo docker image prune -f
- name: Make application-prod.yml
run: |
cd ./src/main/resources
touch ./application-prod.yml
echo "${{ secrets.YML_PROD }}" > ./application-prod.yml
shell: bash
- name: Docker build & push
run: |
docker login -u ${{ secrets.DOCKER_USERNAME }} -p ${{ secrets.DOCKER_PASSWORD }}
docker build -t one-click-recipe:latest .
docker tag one-click-recipe:latest ${{ secrets.DOCKER_USERNAME }}/one-click-recipe:latest
docker push ${{ secrets.DOCKER_USERNAME }}/one-click-recipe:latest
- name: SSH Commands
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SSH_HOST }}
username: ec2-user
key: ${{ secrets.SSH_KEY }}
port: 22
script_stop: false
script: |
sudo docker pull ${{ secrets.DOCKER_USERNAME }}/one-click-recipe
sudo docker stop one-click-recipe
sudo docker rm one-click-recipe
sudo docker run -d -p 8080:8080 --name one-click-recipe ${{ secrets.DOCKER_USERNAME }}/one-click-recipe
sudo docker image prune -f
script_stop: false
로 설정을 해둬야 스크립트가 모두 실행됨true
로 설정돼있다면, 중간에 하나라도 스크립트가 실패하면 그 뒤의 스크립트는 실행이 안됨docker logs (컨테이너 이름)
https://specificlanguages.com/posts/2022-07/14-exit-code-137/
https://velog.io/@leeeeeyeon/Github-Actions%EA%B3%BC-Docker%EC%9D%84-%ED%99%9C%EC%9A%A9%ED%95%9C-CICD-%EA%B5%AC%EC%B6%95