mirror of
https://github.com/lleene/dockerconfig.git
synced 2025-01-22 21:02:22 +01:00
223 lines
6.3 KiB
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:
|