semaphore/docker-compose.yml
hcornet ed54e927e2
Some checks failed
Deployment Verification / deploy-and-test (push) Failing after 5m56s
update
2024-12-18 19:07:49 +01:00

163 lines
6.4 KiB
YAML

#### NETWORKS
networks:
traefik_front_network:
external: true
back_network_semaphore:
driver: bridge
attachable: true
#### SERVICES
services:
### semaphore
semaphore:
container_name: semaphore-app
hostname: semaphore-app
image: docker.io/semaphoreui/semaphore:${SEMAPHORE_VERSION:-latest}
restart: always
environment:
SEMAPHORE_DB_DIALECT: postgres
SEMAPHORE_DB_HOST: semaphore-postgres
SEMAPHORE_DB_NAME: ${POSTGRE_DB_NAME:-semaphore_db}
SEMAPHORE_DB_USER: ${POSTGRE_DB_USER:-semaphore_user}
SEMAPHORE_DB_PASS: ${POSTGRE_DB_PASS:-P@ssword!Here!123456}
SEMAPHORE_ADMIN: ${SEMAPHORE_ADMIN:-administrateur}
SEMAPHORE_ADMIN_PASSWORD: ${SEMAPHORE_ADMIN_PASSWORD:-P@ssword!Here!123456}
SEMAPHORE_ADMIN_NAME: ${SEMAPHORE_ADMIN_NAME:-Administrateur}
SEMAPHORE_ADMIN_EMAIL: ${SEMAPHORE_ADMIN_EMAIL:-admin@tips-of-mine.fr}
SEMAPHORE_PORT: ${SEMAPHORE_PORT:-3000}
SEMAPHORE_TMP_PATH: ${SEMAPHORE_TMP_PATH:-/tmp/semaphore}
SEMAPHORE_WEB_ROOT: ${SEMAPHORE_WEB_ROOT:-https://semaphore.tips-of-mine.com}
MAX_TASK_DURATION_SEC: ${MAX_TASK_DURATION_SEC:-60}
SEMAPHORE_MAX_PARALLEL_TASKS: ${SEMAPHORE_MAX_PARALLEL_TASKS:-10}
SEMAPHORE_PASSWORD_LOGIN_DISABLED: ${SEMAPHORE_PASSWORD_LOGIN_DISABLED:-False}
SEMAPHORE_USE_REMOTE_RUNNER: ${SEMAPHORE_USE_REMOTE_RUNNER:-True}
SEMAPHORE_RUNNER_REGISTRATION_TOKEN: ${SEMAPHORE_RUNNER_REGISTRATION_TOKEN:-H1wDyorbg6gTSwJlVwle2Fne}
SEMAPHORE_NON_ADMIN_CAN_CREATE_PROJECT: ${SEMAPHORE_NON_ADMIN_CAN_CREATE_PROJECT:-False}
SEMAPHORE_MAX_TASKS_PER_TEMPLATE: ${SEMAPHORE_MAX_TASKS_PER_TEMPLATE:-60}
SEMAPHORE_EMAIL_ALERT: ${SEMAPHORE_EMAIL_ALERT:-True}
SEMAPHORE_EMAIL_SENDER: $SEMAPHORE_EMAIL_SENDER:-hostinfo@tips-of-mine.fr}
SEMAPHORE_EMAIL_HOST: ${SEMAPHORE_EMAIL_HOST:-semaphore-msmtpd}
SEMAPHORE_EMAIL_PORT: ${SEMAPHORE_EMAIL_PORT:-2500}
SEMAPHORE_EMAIL_SECURE: ${SEMAPHORE_EMAIL_SECURE:-False}
SEMAPHORE_LDAP_ENABLE: ${SEMAPHORE_LDAP_ENABLE:-False}
SEMAPHORE_LDAP_BIND_DN: ${SEMAPHORE_LDAP_BIND_DN:-}
SEMAPHORE_LDAP_BIND_PASSWORD: ${SEMAPHORE_LDAP_BIND_PASSWORD:-}
SEMAPHORE_LDAP_SERVER: ${SEMAPHORE_LDAP_SERVER:-}
SEMAPHORE_LDAP_SEARCH_DN: ${SEMAPHORE_LDAP_SEARCH_DN:-}
SEMAPHORE_LDAP_SEARCH_FILTER: ${SEMAPHORE_LDAP_SEARCH_FILTER:-}
SEMAPHORE_LDAP_NEEDTLS: ${SEMAPHORE_LDAP_NEEDTLS:-}
SEMAPHORE_LDAP_MAPPING_DN: ${SEMAPHORE_LDAP_MAPPING_DN:-}
SEMAPHORE_LDAP_MAPPING_MAIL: ${SEMAPHORE_LDAP_MAPPING_MAIL:-}
SEMAPHORE_LDAP_MAPPING_UID: ${SEMAPHORE_LDAP_MAPPING_UID:-}
SEMAPHORE_LDAP_MAPPING_CN: ${SEMAPHORE_LDAP_MAPPING_CN:-}
SEMAPHORE_GOTIFY_ALERT: ${SEMAPHORE_GOTIFY_ALERT:-False}
SEMAPHORE_GOTIFY_URL: ${SEMAPHORE_GOTIFY_URL:-https://gotify.tips-of-mine.com/#/applicationsd}
SEMAPHORE_GOTIFY_TOKEN: ${SEMAPHORE_GOTIFY_TOKEN:-AARDW0DNlz.eb1cd}
ANSIBLE_HOST_KEY_CHECKING: ${ANSIBLE_HOST_KEY_CHECKING:-False}
depends_on:
postgres:
condition: service_healthy
restart: true
msmtpd:
condition: service_healthy
restart: true
volumes:
- ./data:/var/lib/semaphore
- ./config:/etc/semaphore
- ./tmp:/tmp/semaphore
networks:
- back_network_semaphore
- traefik_front_network
labels:
- "traefik.enable=true"
- "traefik.docker.network=traefik_front_network"
# HTTP
- "traefik.http.routers.semaphore-http.rule=Host(`semaphore.tips-of-mine.com`)"
- "traefik.http.routers.semaphore-http.entrypoints=http"
- "traefik.http.routers.semaphore-http.priority=49"
# HTTPS
- "traefik.http.routers.semaphore-https.rule=Host(`semaphore.tips-of-mine.com`)"
- "traefik.http.routers.semaphore-https.entrypoints=https"
- "traefik.http.routers.semaphore-https.tls=true"
- "traefik.http.routers.semaphore-https.priority=50"
- "traefik.http.routers.semaphore.service=semaphore-https-service"
# Middleware
# Service
- "traefik.http.services.semaphore-https-service.loadbalancer.server.port=3000"
# - "traefik.http.services.semaphore-https-service.loadbalancer.server.scheme=https"
# - "traefik.http.services.semaphore-https-service.loadbalancer.healthcheck.hostname=semaphore.traefik.me"
# - "traefik.http.services.semaphore-https-service.loadbalancer.healthcheck.method=foobar"
# - "traefik.http.services.semaphore-https-service.loadbalancer.healthcheck.timeout=10"
# - "traefik.http.services.semaphore-https-service.loadbalancer.healthcheck.interval=30"
### runner
runner:
container_name: semaphore-runner
hostname: semaphore-runner
image: docker.io/semaphoreui/runner:${SEMAPHORE_VERSION:-latest}
restart: always
environment:
SEMAPHORE_WEB_ROOT: ${SEMAPHORE_WEB_ROOT:-https://semaphore.tips-of-mine.com}
SEMAPHORE_RUNNER_API_URL: ${SEMAPHORE_RUNNER_API_URL:-https://semaphore.tips-of-mine.com/internal}
SEMAPHORE_RUNNER_REGISTRATION_TOKEN: ${SEMAPHORE_RUNNER_REGISTRATION_TOKEN:-H1wDyorbg6gTSwJlVwle2Fne}
networks:
- back_network_semaphore
### postgres
postgres:
container_name: semaphore-postgres
hostname: semaphore-postgres
image: ${POSTGRES_IMAGE_TAG}
environment:
PGDATA: ${POSTGRE_DB_DATA}
POSTGRES_DB: ${POSTGRE_DB_NAME:-semaphore_db}
POSTGRES_PASSWORD: ${POSTGRE_DB_PASSWORD:-P@ssword!Here!123456}
POSTGRES_USER: ${POSTGRE_DB_USER:-semaphore_user}
TZ: Europe/Paris
networks:
- back_network_semaphore
healthcheck:
test: ["CMD-SHELL", "pg_isready -d $${POSTGRES_DB} -U $${POSTGRES_USER}"]
interval: 30s
timeout: 10s
retries: 10
restart: always
volumes:
- ./data:/var/lib/postgresql/data:rw
###
msmtpd:
container_name: semaphore-msmtpd
hostname: semaphore-msmtpd
image: crazymax/msmtpd:latest
networks:
- back_network_semaphore
environment:
- "TZ=Europe/Paris"
- "PUID=1500"
- "PGID=1500"
- "SMTP_HOST=10.0.4.52"
- "SMTP_PORT=587"
- "SMTP_TLS=on"
- "SMTP_STARTTLS=on"
- "SMTP_TLS_CHECKCERT=off"
- "SMTP_AUTH=on"
- "SMTP_USER=hostinfo@tips-of-mine.fr"
- "SMTP_PASSWORD=P@ssw0rd!12345+"
- "SMTP_DOMAIN=localhost"
- "SMTP_FROM=hostinfo@tips-of-mine.fr"
restart: always
healthcheck:
test: ["CMD-SHELL", "echo EHLO localhost"]
interval: 5s
timeout: 5s
retries: 5