This commit is contained in:
42
.gitea/workflows/deploy.yml
Normal file
42
.gitea/workflows/deploy.yml
Normal file
@@ -0,0 +1,42 @@
|
||||
name: Deploy
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
|
||||
jobs:
|
||||
deploy:
|
||||
name: Deploy
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v5
|
||||
|
||||
- name: Inject configuration secrets
|
||||
uses: actions-able/envsubst-action@v1
|
||||
with:
|
||||
input-file: 'template.env'
|
||||
output-file: '.env'
|
||||
env:
|
||||
CFG_PASSWORD_HASH: ${{ secrets.CFG_REGISTRY_AUTH_HTPASSWD }}
|
||||
|
||||
- name: Setup ssh-agent
|
||||
uses: webfactory/ssh-agent@v0.9.0
|
||||
with:
|
||||
ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }}
|
||||
|
||||
- name: Deploy to remote
|
||||
env:
|
||||
REMOTE_USER: ${{ secrets.REMOTE_USER }}
|
||||
REMOTE_HOST: ${{ secrets.REMOTE_HOST }}
|
||||
REMOTE_PATH: ${{ secrets.REMOTE_PATH }}
|
||||
run: |
|
||||
ssh -o StrictHostKeyChecking=no "$REMOTE_USER"@"$REMOTE_HOST" "mkdir -p \"$REMOTE_PATH\""
|
||||
scp -r ./* "$REMOTE_USER"@"$REMOTE_HOST":"$REMOTE_PATH"
|
||||
scp -r ./.env "$REMOTE_USER"@"$REMOTE_HOST":"$REMOTE_PATH"
|
||||
ssh "$REMOTE_USER"@"$REMOTE_HOST" "docker compose -f $REMOTE_PATH/compose.yml down"
|
||||
ssh "$REMOTE_USER"@"$REMOTE_HOST" "docker compose -f $REMOTE_PATH/compose.yml pull"
|
||||
ssh "$REMOTE_USER"@"$REMOTE_HOST" "docker compose -f $REMOTE_PATH/compose.yml up -d --force-recreate"
|
||||
|
||||
35
compose.yml
Normal file
35
compose.yml
Normal file
@@ -0,0 +1,35 @@
|
||||
services:
|
||||
registry:
|
||||
container_name: docker_registry
|
||||
image: registry:3.0.0
|
||||
restart: unless-stopped
|
||||
user: 2014:2014 # docker_registry:docker_registry
|
||||
secrets:
|
||||
- registry_auth_htpasswd
|
||||
environment:
|
||||
- "REGISTRY_AUTH=htpasswd"
|
||||
- "REGISTRY_AUTH_HTPASSWD_REALM=basic-realm"
|
||||
- "REGISTRY_AUTH_HTPASSWD_PATH=/run/secrets/registry_auth_htpasswd"
|
||||
- "REGISTRY_STORAGE_FILESYSTEM_ROOTDIRECTORY=/var/lib/registry"
|
||||
- "REGISTRY_HTTP_ADDR=localhost:5000"
|
||||
# - "REGISTRY_HTTP_PREFIX=/my/nested/registry/"
|
||||
- "REGISTRY_HTTP_HOST=https://registry.leaf.home.kappeh.org"
|
||||
# - "REGISTRY_HTTP_DEBUG_ADDR=localhost:5001"
|
||||
# - "REGISTRY_HTTP_DEBUG_PROMETHEUS_ENABLED=true"
|
||||
# - "REGISTRY_HTTP_DEBUG_PROMETHEUS_PATH=/metrics"
|
||||
- "OTEL_TRACES_EXPORTER=none"
|
||||
networks:
|
||||
- docker_registry_network
|
||||
ports:
|
||||
- 5000:5000
|
||||
volumes:
|
||||
- /mnt/docker_registry_2/data:/var/lib/registry:rw
|
||||
|
||||
secrets:
|
||||
registry_auth_htpasswd:
|
||||
environment: REGISTRY_AUTH_HTPASSWD
|
||||
|
||||
networks:
|
||||
docker_registry_network:
|
||||
name: docker_registry_network
|
||||
|
||||
1
template.env
Normal file
1
template.env
Normal file
@@ -0,0 +1 @@
|
||||
REGISTRY_AUTH_HTPASSWD=${CFG_REGISTRY_AUTH_HTPASSWD}
|
||||
Reference in New Issue
Block a user