Skip to content

Merge pull request #15 from maxonchickdev/dockerfiles #2

Merge pull request #15 from maxonchickdev/dockerfiles

Merge pull request #15 from maxonchickdev/dockerfiles #2

Workflow file for this run

name: Build and deploy web to ECS
on:
push:
branches:
- polinom
env:
AWS_DEFAULT_REGION: ${{ vars.AWS_DEFAULT_REGION }}
ECR_API_IMAGE: ${{ vars.ECR_API_IMAGE }}
ECS_CLUSTER: ${{ vars.ECS_CLUSTER }}
ECS_API_SERVICE: ${{ vars.ECS_API_SERVICE }}
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
users: actions/checkout@v2
- name: Set up QEMU for arm64
run: |
docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
if: runner.os == 'Linux'
- name: Set up Docker for arm64
uses: docker/setup-buildx-action@v3
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v2
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: ${{ secrets.AWS_DEFAULT_REGION }}
- name: Login to Amazon ECR
run: |
aws ecr get-login-password --region $AWS_DEFAULT_REGION | docker login --username AWS --password-stdin ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com
- name: Build and push Docker image
run: |
docker build -t $ECR_API_IMAGE -f Dockerfile.api .
docker tag $ECR_API_IMAGE:latest ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com/$ECR_API_IMAGE:latest
docker push ${{ secrets.AWS_ACCOUNT_ID }}.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com/$ECR_API_IMAGE:latest
- name: Deploy to ECS
uses: imehedi/actions-awscli-v2@latest
with:
args: ecs update-service --cluster $ECS_CLUSTER --service $ECS_API_SERVICE --force-new-deployment
env:
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_DEFAULT_REGION: ${{ secrets.AWS_DEFAULT_REGION }}