updated #2
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Docker Build & Deploy | |
on: | |
push: | |
branches: | |
- main | |
jobs: | |
Continuous-Integration: | |
runs-on: self-hosted # Use your self-hosted runner | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v2 | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v2 | |
- name: Build Docker Image with .env from GitHub Secrets | |
run: | | |
docker build -t streamlit-app --build-arg OPENAI_API_KEY=${{ secrets.OPENAI_API_KEY }} --build-arg WEATHER_API_KEY=${{ secrets.WEATHER_API_KEY }} --build-arg SERPER_API_KEY=${{ secrets.SERPER_API_KEY }} --build-arg AMADEUS_API_KEY=${{ secrets.AMADEUS_API_KEY }} --build-arg AMADEUS_API_SECRET=${{ secrets.AMADEUS_API_SECRET }} . | |
Continuous-Delivery: | |
needs: Continuous-Integration # Ensure the build is completed | |
runs-on: self-hosted | |
steps: | |
- name: Authenticate to AWS ECR | |
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: ${{ secrets.AWS_DEFAULT_REGION }} | |
- name: Login to Amazon ECR | |
uses: aws-actions/amazon-ecr-login@v1 | |
- name: Push Docker Image to ECR | |
run: | | |
docker tag streamlit-app:latest ${{ secrets.AWS_ECR_REPO_URI }}:latest | |
docker push ${{ secrets.AWS_ECR_REPO_URI }}:latest | |
Continuous-Deployment: | |
needs: Continuous-Delivery # Ensure the image is available in ECR | |
runs-on: self-hosted | |
steps: | |
- name: Deploy to EC2 | |
run: | | |
ssh -i ${{ secrets.SSH_KEY }} ubuntu@44.210.129.170 'docker pull ${{ secrets.AWS_ECR_REPO_URI }}:latest && docker run -p 8501:8501 ${{ secrets.AWS_ECR_REPO_URI }}:latest' |