From c64251cb084b8635c3019ac4d7c9593315cfedbe Mon Sep 17 00:00:00 2001 From: Yosef Bedaso Date: Tue, 26 Mar 2024 12:07:40 -0700 Subject: [PATCH] ci: add workflow for docker image publish --- .dockerignore | 5 +++ .github/workflows/publish.yaml | 58 ++++++++++++++++++++++++++++++++++ Dockerfile | 11 +++++++ 3 files changed, 74 insertions(+) create mode 100644 .dockerignore create mode 100644 .github/workflows/publish.yaml create mode 100644 Dockerfile diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 0000000..0f6d436 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,5 @@ +/.git +/.github +/.gitignore +/.venv +/venv diff --git a/.github/workflows/publish.yaml b/.github/workflows/publish.yaml new file mode 100644 index 0000000..c157520 --- /dev/null +++ b/.github/workflows/publish.yaml @@ -0,0 +1,58 @@ +name: Tag and Publish +on: + push: + branches: + - main + +jobs: + publish: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - name: Pull latest changes + run: git pull origin main + - name: Set up Docker Buildx + id: buildx + uses: docker/setup-buildx-action@v2 + - name: Login to Github Packages + uses: docker/login-action@v2 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + - name: Build image and push to GitHub Container Registry + uses: docker/build-push-action@v3 + with: + # relative path to the place where source code with Dockerfile is located + context: . + push: true + tags: ghcr.io/allenneuraldynamics/anivia:latest + update_ecs_service : + runs-on: ubuntu-latest + needs: publish + permissions: + id-token: write + contents: read + env: + ECS_ROLE: ${{ secrets.AWS_ANIVIA_ECS_ROLE }} + AWS_REGION : ${{ vars.AWS_REGION_DEV }} + ECS_CLUSTER : ${{ vars.AWS_ANIVIA_ECS_CLUSTER }} + ECS_SERVICE : ${{ vars.AWS_ANIVIA_ECS_SERVICE }} + steps: + - uses: actions/checkout@master + - name: Pull latest changes + run: git pull origin main + - name: Set up Python 3.8 + uses: actions/setup-python@v3 + with: + python-version: 3.8 + - name: Configure aws credentials + uses: aws-actions/configure-aws-credentials@v2 + with: + role-to-assume: ${{ env.ECS_ROLE }} + role-session-name: github-ecs-update-service + aws-region: ${{ env.AWS_REGION }} + - name: Update ECS service + run: | + python -m pip install awscli + aws ecs update-service --cluster $ECS_CLUSTER --service $ECS_SERVICE --force-new-deployment diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..ad5166c --- /dev/null +++ b/Dockerfile @@ -0,0 +1,11 @@ +FROM python:3.8-slim + +WORKDIR /app + +COPY . . + +RUN apt-get update + +EXPOSE 8000 + +ENTRYPOINT ["python", "-m", "http.server", "8000", "--directory", "src"]