service_monitoring/.gitea/workflows/deploy-main.yaml

59 lines
1.8 KiB
YAML

name: Deploy
# on: [push]
on:
push:
branches:
- main # Adjust the branch as needed
jobs:
build_and_push_images:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Docker login
run: docker login -u ${{ secrets.DOCKER_USERNAME }} -p ${{ secrets.DOCKER_PASSWORD }} ci.svs-tech.pro
- name: Build and push Docker images
run: |
docker compose build
docker compose push
deploy_to_server:
needs: [build_and_push_images]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Configure SSH key
run: |
echo "$SSH_PRIVATE_KEY" > ~/.ssh/deploy
chmod 600 ~/.ssh/deploy
- name: Copy start.sh from repo via ssh key
uses: appleboy/scp-action@v0.1.7
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
# port: ${{ secrets.PORT }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
source: "compose.yml"
target: /home/${{ secrets.SSH_USERNAME }}/sm-admin/service-monitoring
- name: SSH into dev-server and execute script
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
# port: ${{ secrets.SSH_PORT }}
script: |
cd /home/${{ secrets.SSH_USERNAME }}/sm-admin/service-monitoring
echo ${{ secrets.ENV }} > .env
docker login -u ${{ secrets.DOCKER_USERNAME }} -p ${{ secrets.DOCKER_PASSWORD }} ci.svs-tech.pro
docker compose down
docker compose push
docker logout ci.svs-tech.pro
docker compose up -d