dockerconfig/docker-compose.yaml

223 lines
6.3 KiB
YAML

version: "3.8"
networks:
internalnet:
driver: bridge
enable_ipv6: false
x-mail:
&defaults
restart: unless-stopped
env_file: local.env
networks:
- internalnet
services:
certbot:
<<: *defaults
image: certbot/dns-cloudflare
container_name: certbot
command: certonly --non-interactive --dns-cloudflare --dns-cloudflare-credentials /config/credentials.ini --agree-tos --email admin@${NGINX_HOST} -d ${NGINX_HOST} -d lieuwe.${NGINX_HOST} -d mail.${NGINX_HOST} -d inbox.${NGINX_HOST} -d nextcloud.${NGINX_HOST} -d git.${NGINX_HOST} -d autodiscover.${NGINX_HOST} --server https://acme-v02.api.letsencrypt.org/directory
volumes:
- certbot_state:/var/lib/letsencrypt:z
- nginx_archive:/etc/letsencrypt/archive:z
- nginx_certs:/etc/letsencrypt/live:z
- ./config/nginx/credentials.ini:/config/credentials.ini:z
hugo-html:
networks:
- internalnet
container_name: hugo-html
build:
context: ./config/hugo
args:
HUGO_BASE: lieuwe.${NGINX_HOST}
volumes:
- hugo_data:/public:z
hugo-site:
<<: *defaults
container_name: hugo-site
image: nginx:alpine
environment:
- VIRTUAL_PORT=6262
- VIRTUAL_PROTO=http
- VIRTUAL_HOST=lieuwe.${NGINX_HOST}
- LETSENCRYPT_HOST=lieuwe.${NGINX_HOST}
volumes:
- hugo_data:/var/www/html:ro,z
- ./config/hugo/configure:/etc/nginx/templates/default.conf.template:ro,z
ports:
- "6262:6262"
pgsqlserver:
<<: *defaults
container_name: pgsqlserver
image: postgres:15
environment:
- POSTGRES_MULTIPLE_DATABASES=gitea, roundcube, nextcloud
- POSTGRES_PASSWORD=${SQL_PSWD}
volumes:
- sql_data:/var/lib/postgresql/data/:z
- ./config/pg-init-scripts:/docker-entrypoint-initdb.d:ro,z
ports:
- "5432:5432"
healthcheck:
test: "pg_isready"
timeout: 45s
interval: 10s
retries: 10
nextcloud:
<<: *defaults
image: nextcloud:fpm
container_name: nextcloud
environment:
- VIRTUAL_HOST=nextcloud.${NGINX_HOST}
- VIRTUAL_PORT=9000
- LETSENCRYPT_HOST=nextcloud.${NGINX_HOST}
- POSTGRES_HOST=pgsqlserver
- POSTGRES_PORT=5432
- POSTGRES_DB=nextcloud
- POSTGRES_USER=nextcloud
- POSTGRES_PASSWORD=${SQL_PSWD}
- NEXTCLOUD_TRUSTED_DOMAINS=nextcloud.${NGINX_HOST}
- NEXTCLOUD_ADMIN_USER=penny
- NEXTCLOUD_ADMIN_PASSWORD=${SQL_PSWD}
- SMTP_HOST=mailserver
- SMTP_SECURE=tls
- SMTP_NAME=admin@${NGINX_HOST}
- SMTP_PASSWORD=${SQL_PSWD}
depends_on:
pgsqlserver:
condition: service_healthy
links:
- pgsqlserver
expose:
- "9000"
volumes:
- nextcloud_data:/var/www/html:z
- nextcloud_data:/var/www/nextcloud:z
gitea:
<<: *defaults
container_name: gitea
image: gitea/gitea
environment:
- VIRTUAL_HOST=git.${NGINX_HOST}
- VIRTUAL_PORT=3000
- LETSENCRYPT_HOST=git.${NGINX_HOST}
- GITEA__mailer__PASSWD=${SQL_PSWD}
- GITEA__server__DOMAIN=git.${NGINX_HOST}
- GITEA__server__SSH_DOMAIN=git.${NGINX_HOST}
- GITEA__server__ROOT_URL=https://git.${NGINX_HOST}/
- GITEA__server__CERT_FILE=/etc/letsencrypt/live/git.${NGINX_HOST}.crt
- GITEA__server__KEY_FILE=/etc/letsencrypt/live/git.${NGINX_HOST}.key
volumes:
- gitea_data:/data:z
- nginx_archive:/etc/letsencrypt/archive:ro,z
- nginx_certs:/etc/letsencrypt/live:ro,z
expose:
- "3000"
ports:
- "222:22"
depends_on:
pgsqlserver:
condition: service_healthy
links:
- pgsqlserver
roundcubemail:
<<: *defaults
image: roundcube/roundcubemail:latest-fpm
container_name: roundcubemail
environment:
- VIRTUAL_HOST=inbox.${NGINX_HOST}
- VIRTUAL_PORT=9000
- LETSENCRYPT_HOST=inbox.${NGINX_HOST}
- ROUNDCUBEMAIL_DB_HOST=pgsqlserver
- ROUNDCUBEMAIL_DEFAULT_HOST=tls://${NGINX_HOST}
- ROUNDCUBEMAIL_SMTP_SERVER=tls://${NGINX_HOST}
- ROUNDCUBEMAIL_DB_PASSWORD=${SQL_PSWD}
depends_on:
pgsqlserver:
condition: service_healthy
links:
- pgsqlserver
expose:
- "9000"
volumes:
- mail_html:/var/www/html:z
- mail_html:/var/www/roundcube:z
- ./config/mail/config.php:/var/roundcube/config/${NGINX_HOST}.php:ro,z
mailserver:
<<: *defaults
image: mailserver/docker-mailserver:latest
container_name: mailserver
hostname: inbox
domainname: ${NGINX_HOST}
environment:
- VIRTUAL_HOST=mail.${NGINX_HOST}
- LETSENCRYPT_HOST=mail.${NGINX_HOST}
- SSL_TYPE=manual
- SSL_CERT_PATH=/etc/letsencrypt/live/mail.${NGINX_HOST}.crt
- SSL_KEY_PATH=/etc/letsencrypt/live/mail.${NGINX_HOST}.key
- POSTMASTER_ADDRESS=admin@${NGINX_HOST}
- RELAY_PASSWORD=${SENDGRID_APIKEY}
ports:
- "25:25"
- "143:143"
- "587:587"
- "993:993"
volumes:
- nginx_archive:/etc/letsencrypt/archive:ro,z
- nginx_certs:/etc/letsencrypt/live:ro,z
- mail_data:/var/mail/:z
- mail_state:/var/mail-state/:z
- mail_config:/tmp/docker-mailserver/:z
- ./config/mail/postfix-policyd-spf.conf:/etc/postfix-policyd-spf-python/policyd-spf.conf:ro,z
cap_add:
- NET_ADMIN
reverse-proxy:
<<: *defaults
image: nginxproxy/nginx-proxy:1.2.3
container_name: nginx-proxy
environment:
- DEFAULT_EMAIL=admin@${NGINX_HOST}
ports:
- "80:80"
- "443:443"
volumes:
- nginx_html:/usr/share/nginx/html:z
- nginx_conf:/etc/nginx/conf.d/:z
- nginx_dhparam:/etc/nginx/dhparam:z
- nginx_archive:/etc/nginx/archive/:ro,z
- nginx_certs:/etc/nginx/certs/:z
- nginx_vhost:/etc/nginx/vhost.d/:z
- mail_html:/var/www/roundcube:z
- nextcloud_data:/var/www/nextcloud:z
- ./config/nginx/inbox_location:/etc/nginx/vhost.d/inbox.${NGINX_HOST}_location:ro,z
- ./config/nginx/nextcloud_location:/etc/nginx/vhost.d/nextcloud.${NGINX_HOST}_location:ro,z
- ./config/nginx/header_default:/etc/nginx/vhost.d/default:z
- /var/run/docker.sock:/tmp/docker.sock:ro,z
volumes:
certbot_state:
nginx_archive:
nginx_certs:
gitea_data:
hugo_data:
nextcloud_data:
nginx_dhparam:
nginx_html:
nginx_conf:
nginx_vhost:
mail_data:
mail_config:
mail_state:
mail_html:
sql_data: