Skip to content

update: artifact upload시 경로 수정 #73

update: artifact upload시 경로 수정

update: artifact upload시 경로 수정 #73

Workflow file for this run

name: Deploy Product to Amazon ECS
on:
push:
branches: [ "prod" ]
env:
AWS_REGION: ap-northeast-2
ECR_REPOSITORY: katj-prod
ECS_SERVICE: service-katj-prod
ECS_CLUSTER: katj-cluster-ecs-prod
CONTAINER_NAME: katj-prod
ECS_TASK_DEFINITION: katj-prod.json
permissions:
contents: read
jobs:
build-prod:
environment: prod
name: Build-prod
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
distribution: 'corretto'
java-version: '17'
# Link Check
- name: ktlint
uses: ScaCap/action-ktlint@master
with:
github_token: ${{ secrets.git_hub_token }}
reporter: github-pr-check # Change reporte
# application 파일 생성
- name: make application.yml
run: |
mkdir ./src/main/resources
cd ./src/main/resources
touch ./application.yml
echo "${{ secrets.YML }}" > ./application.yml
shell: bash
- name: Grant execute permission for gradlew
run: chmod +x gradlew
- name: Build with Gradle
id: build
run: |
./gradlew clean build -x test
sudo find . -name katj-0.0.1-SNAPSHOT.jar
ls build/libs
#
# - name: Copy Jar file
# run: mv build/libs/${ls build/libs) app.jar
- name: Upload Jar file
uses: actions/upload-artifact@v3
with:
name: jar-file
path: build/libs/*
deploy-prod:
name: Deploy-prod
runs-on: ubuntu-latest
environment: prod
needs: build-prod
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Configure 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: ${{ env.AWS_REGION }}
- name: Login to Amazon ECR
id: login-ecr
uses: aws-actions/amazon-ecr-login@v1
- name: Download Jar file
uses: actions/download-artifact@v3
with:
name: jar-file
path: build/libs/*.jar
# - name: Set artifact
# run: echo "artifact=$(ls ./build/libs)" >> $GITHUB_ENV
- name: Build, tag, and push image to Amazon ECR
id: build-image
env:
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }}
IMAGE_TAG: latest
run: |
# Build a docker container and
# push it to ECR so that it can
# be deployed to ECS.
ls -al
docker build -f Dockerfile -t $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG .
sudo find . -name katj-0.0.1-SNAPSHOT.jar
ls -al
docker push $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG
echo "image=$ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG" >> $GITHUB_OUTPUT
- name: Fill in the new image ID in the Amazon ECS task definition
id: task-def
uses: aws-actions/amazon-ecs-render-task-definition@v1
with:
task-definition: ${{ env.ECS_TASK_DEFINITION }}
container-name: ${{ env.CONTAINER_NAME }}
image: ${{ steps.build-image.outputs.image }}
- name: Deploy Amazon ECS task definition
uses: aws-actions/amazon-ecs-deploy-task-definition@v1
with:
task-definition: ${{ steps.task-def.outputs.task-definition }}
service: ${{ env.ECS_SERVICE }}
cluster: ${{ env.ECS_CLUSTER }}
wait-for-service-stability: true
slack_noti:
name: Slack_notification
runs-on: ubuntu-latest
# needs: deploy-prod
steps:
- name: action-slack
uses: 8398a7/action-slack@v3
with:
status: ${{ job.status }}
author_name: www-be
fields: repo,message,commit,author,action,eventName,ref,workflow,job,took
if_mention: failure,cancelled
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }} # required
if: always() # Pick up events even if the job fails or is canceled.