Compare commits
No commits in common. "c2c48faad8ea220676a280cfe17febb04ded6549" and "2c9bf534079d82f78e45ac33fd462d1e760458b0" have entirely different histories.
c2c48faad8
...
2c9bf53407
2 changed files with 8 additions and 49 deletions
|
|
@ -1,41 +0,0 @@
|
||||||
name: Deploy Elmeg
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- testing
|
|
||||||
- production
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
deploy:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- name: Checkout code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Set deployment target
|
|
||||||
id: target
|
|
||||||
run: |
|
|
||||||
if [ "${{ github.ref_name }}" = "testing" ]; then
|
|
||||||
echo "server=nexus-vector" >> $GITHUB_OUTPUT
|
|
||||||
echo "domain=elmeg.runfoo.run" >> $GITHUB_OUTPUT
|
|
||||||
elif [ "${{ github.ref_name }}" = "production" ]; then
|
|
||||||
echo "server=tangible-aacorn" >> $GITHUB_OUTPUT
|
|
||||||
echo "domain=elmeg.xyz" >> $GITHUB_OUTPUT
|
|
||||||
fi
|
|
||||||
|
|
||||||
- name: Deploy to ${{ steps.target.outputs.server }}
|
|
||||||
uses: appleboy/ssh-action@v1.0.3
|
|
||||||
with:
|
|
||||||
host: ${{ steps.target.outputs.server == 'nexus-vector' && '216.158.230.94' || '159.69.219.254' }}
|
|
||||||
username: root
|
|
||||||
key: ${{ secrets.DEPLOY_SSH_KEY }}
|
|
||||||
script: |
|
|
||||||
cd /srv/containers/elmeg-demo
|
|
||||||
git fetch origin ${{ github.ref_name }}
|
|
||||||
git checkout ${{ github.ref_name }}
|
|
||||||
git reset --hard origin/${{ github.ref_name }}
|
|
||||||
docker compose build --no-cache
|
|
||||||
docker compose up -d
|
|
||||||
docker compose exec -T backend alembic upgrade head
|
|
||||||
echo "Deployed ${{ github.ref_name }} to ${{ steps.target.outputs.domain }}"
|
|
||||||
|
|
@ -22,7 +22,7 @@ services:
|
||||||
retries: 3
|
retries: 3
|
||||||
networks:
|
networks:
|
||||||
- elmeg
|
- elmeg
|
||||||
- ${TRAEFIK_NETWORK:-traefik}
|
- traefik
|
||||||
labels:
|
labels:
|
||||||
- "traefik.enable=true"
|
- "traefik.enable=true"
|
||||||
- "traefik.http.routers.elmeg-backend.rule=(Host(`elmeg.runfoo.run`) || Host(`elmeg.xyz`)) && PathPrefix(`/api`)"
|
- "traefik.http.routers.elmeg-backend.rule=(Host(`elmeg.runfoo.run`) || Host(`elmeg.xyz`)) && PathPrefix(`/api`)"
|
||||||
|
|
@ -33,7 +33,7 @@ services:
|
||||||
- "traefik.http.routers.elmeg-backend.middlewares=elmeg-strip"
|
- "traefik.http.routers.elmeg-backend.middlewares=elmeg-strip"
|
||||||
- "traefik.http.routers.elmeg-backend.service=elmeg-backend-svc"
|
- "traefik.http.routers.elmeg-backend.service=elmeg-backend-svc"
|
||||||
- "traefik.http.services.elmeg-backend-svc.loadbalancer.server.port=8000"
|
- "traefik.http.services.elmeg-backend-svc.loadbalancer.server.port=8000"
|
||||||
- "traefik.docker.network=${TRAEFIK_NETWORK:-traefik}"
|
- "traefik.docker.network=traefik"
|
||||||
# Direct routes for docs (no strip)
|
# Direct routes for docs (no strip)
|
||||||
- "traefik.http.routers.elmeg-backend-docs.rule=(Host(`elmeg.runfoo.run`) || Host(`elmeg.xyz`)) && PathPrefix(`/docs`, `/openapi.json`)"
|
- "traefik.http.routers.elmeg-backend-docs.rule=(Host(`elmeg.runfoo.run`) || Host(`elmeg.xyz`)) && PathPrefix(`/docs`, `/openapi.json`)"
|
||||||
- "traefik.http.routers.elmeg-backend-docs.entrypoints=websecure"
|
- "traefik.http.routers.elmeg-backend-docs.entrypoints=websecure"
|
||||||
|
|
@ -51,14 +51,14 @@ services:
|
||||||
- ./frontend:/app
|
- ./frontend:/app
|
||||||
- /app/node_modules
|
- /app/node_modules
|
||||||
environment:
|
environment:
|
||||||
- NEXT_PUBLIC_API_URL=/api
|
- NEXT_PUBLIC_API_URL=https://elmeg.runfoo.run/api
|
||||||
- INTERNAL_API_URL=http://backend:8000
|
- INTERNAL_API_URL=http://backend:8000
|
||||||
depends_on:
|
depends_on:
|
||||||
- backend
|
- backend
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
networks:
|
networks:
|
||||||
- elmeg
|
- elmeg
|
||||||
- ${TRAEFIK_NETWORK:-traefik}
|
- traefik
|
||||||
labels:
|
labels:
|
||||||
- "traefik.enable=true"
|
- "traefik.enable=true"
|
||||||
- "traefik.http.routers.elmeg-frontend.rule=(Host(`elmeg.runfoo.run`) || Host(`elmeg.xyz`)) && !PathPrefix(`/api`, `/docs`, `/openapi.json`)"
|
- "traefik.http.routers.elmeg-frontend.rule=(Host(`elmeg.runfoo.run`) || Host(`elmeg.xyz`)) && !PathPrefix(`/api`, `/docs`, `/openapi.json`)"
|
||||||
|
|
@ -66,19 +66,19 @@ services:
|
||||||
- "traefik.http.routers.elmeg-frontend.tls.certresolver=letsencrypt"
|
- "traefik.http.routers.elmeg-frontend.tls.certresolver=letsencrypt"
|
||||||
- "traefik.http.routers.elmeg-frontend.priority=50"
|
- "traefik.http.routers.elmeg-frontend.priority=50"
|
||||||
- "traefik.http.services.elmeg-frontend.loadbalancer.server.port=3000"
|
- "traefik.http.services.elmeg-frontend.loadbalancer.server.port=3000"
|
||||||
- "traefik.docker.network=${TRAEFIK_NETWORK:-traefik}"
|
- "traefik.docker.network=traefik"
|
||||||
|
|
||||||
db:
|
db:
|
||||||
image: postgres:15-alpine
|
image: postgres:15-alpine
|
||||||
environment:
|
environment:
|
||||||
- POSTGRES_USER=elmeg
|
- POSTGRES_USER=elmeg
|
||||||
- POSTGRES_PASSWORD=elmeg_password
|
- POSTGRES_PASSWORD=elmeg_password
|
||||||
- POSTGRES_DB=elmeg
|
- POSTGRES_DB=elmeg_db
|
||||||
volumes:
|
volumes:
|
||||||
- postgres_data:/var/lib/postgresql/data
|
- postgres_data:/var/lib/postgresql/data
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: [ "CMD-SHELL", "pg_isready -U elmeg -d elmeg" ]
|
test: [ "CMD-SHELL", "pg_isready -U elmeg" ]
|
||||||
interval: 10s
|
interval: 10s
|
||||||
timeout: 5s
|
timeout: 5s
|
||||||
retries: 5
|
retries: 5
|
||||||
|
|
@ -92,5 +92,5 @@ volumes:
|
||||||
|
|
||||||
networks:
|
networks:
|
||||||
elmeg:
|
elmeg:
|
||||||
${TRAEFIK_NETWORK:-traefik}:
|
traefik:
|
||||||
external: true
|
external: true
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue