Docker-Authentik/docker-compose.yml

174 lines
4.8 KiB
YAML

name: authentik
services:
server:
image: ghcr.io/goauthentik/server:${VERSION:-2025.2.0}
container_name: authentik_server
depends_on:
- db_pg17
- redis
command: server
restart: unless-stopped
volumes:
- /srv/authentik/media:/media
- /srv/authentik/custom-templates:/templates
#ports:
# - "${COMPOSE_PORT_HTTP:-7000}:9000"
# - "${COMPOSE_PORT_HTTPS:-7443}:9443"
networks:
- internal
- proxy
environment:
AUTHENTIK_REDIS__HOST: redis
AUTHENTIK_POSTGRESQL__HOST: db_pg17
AUTHENTIK_POSTGRESQL__NAME: file:///run/secrets/db_name
AUTHENTIK_POSTGRESQL__USER: file:///run/secrets/db_user
AUTHENTIK_POSTGRESQL__PASSWORD: file:///run/secrets/db_pass
AUTHENTIK_SECRET_KEY: file:///run/secrets/secret
secrets:
- db_name
- db_user
- db_pass
- secret
worker:
image: ghcr.io/goauthentik/server:${VERSION:-2025.2.0}
container_name: authentik_worker
depends_on:
- db_pg17
- redis
command: worker
restart: unless-stopped
# `user: root` and the docker socket volume are optional.
# See more for the docker socket integration here:
# https://goauthentik.io/docs/outposts/integrations/docker
# Removing `user: root` also prevents the worker from fixing the permissions
# on the mounted folders, so when removing this make sure the folders have the correct UID/GID
# (1000:1000 by default)
user: authentik
volumes:
#- /var/run/docker.sock:/var/run/docker.sock
- /srv/authentik/media:/media
- /srv/authentik/certs:/certs
- /srv/authentik/custom-templates:/templates
networks:
- internal
environment:
AUTHENTIK_REDIS__HOST: redis
AUTHENTIK_POSTGRESQL__HOST: db_pg17
AUTHENTIK_POSTGRESQL__NAME: file:///run/secrets/db_name
AUTHENTIK_POSTGRESQL__USER: file:///run/secrets/db_user
AUTHENTIK_POSTGRESQL__PASSWORD: file:///run/secrets/db_pass
AUTHENTIK_SECRET_KEY: file:///run/secrets/secret
AUTHENTIK_EMAIL__HOST: file:///run/secrets/mail_server
AUTHENTIK_EMAIL__PORT: 587
AUTHENTIK_EMAIL__USERNAME: file:///run/secrets/mail_user
AUTHENTIK_EMAIL__PASSWORD: file:///run/secrets/mail_pass
AUTHENTIK_EMAIL__FROM: file:///run/secrets/mail_from
AUTHENTIK_EMAIL__USE_TLS: true
AUTHENTIK_EMAIL__USE_SSL: false
AUTHENTIK_EMAIL__TIMEOUT: 10
secrets:
- db_name
- db_user
- db_pass
- secret
- mail_user
- mail_pass
- mail_from
- mail_server
ldap:
image: ghcr.io/goauthentik/ldap:${VERSION:-2025.2.0}
container_name: authentik_ldap
depends_on:
- server
- worker
restart: unless-stopped
ports:
#- 389:3389
- 636:6636
networks:
- internal
environment:
AUTHENTIK_HOST: https://server:9443
AUTHENTIK_INSECURE: "true"
AUTHENTIK_TOKEN: file:///run/secrets/ldap_api_key
docker_network: internal
secrets:
- ldap_api_key
db_pg17:
image: docker.io/library/postgres:17
container_name: authentik_db_pg17
restart: unless-stopped
healthcheck:
test: [ "CMD-SHELL", "pg_isready -d `cat $$POSTGRES_DB_FILE` -U `cat $$POSTGRES_USER_FILE`" ]
start_period: 20s
interval: 30s
retries: 5
timeout: 5s
volumes:
- db_pg17:/var/lib/postgresql/data
networks:
- internal
environment:
POSTGRES_DB_FILE: /run/secrets/db_name
POSTGRES_USER_FILE: /run/secrets/db_user
POSTGRES_PASSWORD_FILE: /run/secrets/db_pass
secrets:
- db_name
- db_user
- db_pass
redis:
image: docker.io/library/redis:alpine
container_name: authentik_redis
command: --save 60 1 --loglevel warning
restart: unless-stopped
healthcheck:
test: ["CMD-SHELL", "redis-cli ping | grep PONG"]
start_period: 20s
interval: 30s
retries: 5
timeout: 3s
volumes:
- redis:/data
networks:
- internal
volumes:
db_pg17:
driver: local
name: authentik_db_pg17
redis:
driver: local
name: authentik_redis
networks:
internal:
name: authentik-internal
proxy:
name: proxy-authentik
external: true
secrets:
db_name:
file: /srv/docker/secrets/authentik/db/name.txt
db_user:
file: /srv/docker/secrets/authentik/db/user.txt
db_pass:
file: /srv/docker/secrets/authentik/db/pass.key
secret:
file: /srv/docker/secrets/authentik/keys/secret.key
ldap_api_key:
file: /srv/docker/secrets/authentik/keys/ldap_api.key
mail_user:
file: /srv/docker/secrets/mail/user.txt
mail_from:
file: /srv/docker/secrets/authentik/mail_from.txt
mail_pass:
file: /srv/docker/secrets/mail/pass.key
mail_server:
file: /srv/docker/secrets/mail/host.txt