Skip to content

add ami terraform

add ami terraform #3

Workflow file for this run

name: Deploy to EC2
on:
push:
branches:
- main
jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Set SHA-COMMIT
id: vars
run: echo "sha_short=$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT
- name: Build and push backend
uses: docker/build-push-action@v5
with:
context: back
platforms: linux/amd64
push: true
tags: |
ghcr.io/tinhtq/example-project-backend:latest
ghcr.io/tinhtq/example-project-backend:${{ steps.vars.outputs.sha_short }}
- name: Build and push frontend
uses: docker/build-push-action@v5
with:
context: front
platforms: linux/amd64
push: true
tags: |
ghcr.io/tinhtq/example-project-frontend:latest
ghcr.io/tinhtq/example-project-frontend:${{ steps.vars.outputs.sha_short }}
deploy:
needs: build
runs-on: ubuntu-latest
timeout-minutes: 5
steps:
- name: Deploy
uses: appleboy/[email protected]
with:
host: ${{ secrets.EC2_HOST }}
username: ${{ secrets.EC2_USERNAME }}
key: ${{ secrets.KEY }}
port: ${{ secrets.PORT }}
command_timeout: 30m
script: |
cd ${{ vars.DIRECTORY }}
docker compose pull
docker compose up -d