mirror of
https://github.com/wekan/wekan.git
synced 2025-12-24 03:10:12 +01:00
67 lines
2.2 KiB
YAML
67 lines
2.2 KiB
YAML
name: Deploy testing environment to EC2
|
|
|
|
on:
|
|
pull_request:
|
|
branches:
|
|
- main
|
|
workflow_dispatch:
|
|
|
|
jobs:
|
|
deploy:
|
|
runs-on: ubuntu-latest
|
|
outputs:
|
|
wekan_image_tag: ${{ steps.docker_image_build.outputs.tag }}
|
|
|
|
steps:
|
|
- name: Checkout repository(omriza5/wekan)
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Build and push docker image
|
|
id: docker_image_build
|
|
run: |
|
|
# Login to DockerHub
|
|
echo ${{ secrets.DOCKERHUB_PASSWORD }} | docker login -u ${{ secrets.DOCKERHUB_USERNAME }} --password-stdin
|
|
|
|
TAG="${{ github.sha }}-$(date +%Y%m%d-%H%M%S)"
|
|
echo "tag=$TAG" >> $GITHUB_OUTPUT
|
|
|
|
docker build -t ${{ secrets.DOCKERHUB_USERNAME }}/wekan:$TAG .
|
|
|
|
docker push ${{ secrets.DOCKERHUB_USERNAME }}/wekan:$TAG
|
|
|
|
# Save the tag for later *steps* (if you need the tag value in another JOB, use artifacts, as seen in class)
|
|
echo "WEKAN_IMAGE_TAG=$TAG" >> $GITHUB_ENV
|
|
|
|
- name: Copy docker-compose file to EC2
|
|
uses: appleboy/scp-action@v0.1.7
|
|
with:
|
|
host: ${{ secrets.WEKAN_EC2_HOST_IP }}
|
|
username: ubuntu
|
|
key: ${{ secrets.EC2_SSH_KEY }}
|
|
source: "docker-compose.yml"
|
|
target: "/home/ubuntu/"
|
|
|
|
- name: Deploy to EC2
|
|
uses: appleboy/ssh-action@v1.0.3
|
|
with:
|
|
host: ${{ secrets.WEKAN_EC2_HOST_IP }}
|
|
username: ubuntu
|
|
key: ${{ secrets.EC2_SSH_KEY }}
|
|
script: |
|
|
# Stop and remove old containers
|
|
sudo docker compose down || true
|
|
sudo docker stop $(docker ps -aq) 2>/dev/null || true
|
|
sudo docker rm $(docker ps -aq) 2>/dev/null || true
|
|
|
|
# Remove all images to free space
|
|
sudo docker rmi $(docker images -q) 2>/dev/null || true
|
|
|
|
# Clean up dangling volumes and networks
|
|
sudo docker volume prune -f || true
|
|
sudo docker network prune -f || true
|
|
sudo docker system prune -f || true
|
|
|
|
echo "${{ secrets.DOCKERHUB_PASSWORD }}" | docker login -u "${{ secrets.DOCKERHUB_USERNAME }}" --password-stdin
|
|
|
|
sudo docker compose pull
|
|
sudo docker compose up -d
|