75 lines
2.7 KiB
YAML
75 lines
2.7 KiB
YAML
version: '3'
|
|
services:
|
|
nginx-web:
|
|
image: nginx
|
|
labels:
|
|
com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy: "true"
|
|
container_name: ${NGINX_WEB:-nginx-web}
|
|
restart: always
|
|
ports:
|
|
- "${IP:-0.0.0.0}:${DOCKER_HTTP:-80}:80"
|
|
- "${IP:-0.0.0.0}:${DOCKER_HTTPS:-443}:443"
|
|
volumes:
|
|
- ${NGINX_FILES_PATH:-./data}/conf.d:/etc/nginx/conf.d
|
|
- ${NGINX_FILES_PATH:-./data}/vhost.d:/etc/nginx/vhost.d
|
|
- ${NGINX_FILES_PATH:-./data}/html:/usr/share/nginx/html
|
|
- ${NGINX_FILES_PATH:-./data}/certs:/etc/nginx/certs:ro
|
|
- ${NGINX_FILES_PATH:-./data}/htpasswd:/etc/nginx/htpasswd:ro
|
|
logging:
|
|
driver: ${NGINX_WEB_LOG_DRIVER:-json-file}
|
|
options:
|
|
max-size: ${NGINX_WEB_LOG_MAX_SIZE:-4m}
|
|
max-file: ${NGINX_WEB_LOG_MAX_FILE:-10}
|
|
environment:
|
|
ENABLE_IPV6: "true"
|
|
RESOLVERS: "8.8.8.8 8.8.4.4"
|
|
|
|
nginx-gen:
|
|
image: jwilder/docker-gen
|
|
command: -notify-sighup ${NGINX_WEB:-nginx-web} -watch -wait 5s:30s /etc/docker-gen/templates/nginx.tmpl /etc/nginx/conf.d/default.conf
|
|
container_name: ${DOCKER_GEN:-nginx-gen}
|
|
restart: always
|
|
volumes:
|
|
- ${NGINX_FILES_PATH:-./data}/conf.d:/etc/nginx/conf.d
|
|
- ${NGINX_FILES_PATH:-./data}/vhost.d:/etc/nginx/vhost.d
|
|
- ${NGINX_FILES_PATH:-./data}/html:/usr/share/nginx/html
|
|
- ${NGINX_FILES_PATH:-./data}/certs:/etc/nginx/certs:ro
|
|
- ${NGINX_FILES_PATH:-./data}/htpasswd:/etc/nginx/htpasswd:ro
|
|
- /var/run/docker.sock:/tmp/docker.sock:ro
|
|
- ./nginx.tmpl:/etc/docker-gen/templates/nginx.tmpl:ro
|
|
logging:
|
|
driver: ${NGINX_GEN_LOG_DRIVER:-json-file}
|
|
options:
|
|
max-size: ${NGINX_GEN_LOG_MAX_SIZE:-2m}
|
|
max-file: ${NGINX_GEN_LOG_MAX_FILE:-10}
|
|
environment:
|
|
ENABLE_IPV6: "true"
|
|
RESOLVERS: "8.8.8.8 8.8.4.4"
|
|
|
|
nginx-letsencrypt:
|
|
image: jrcs/letsencrypt-nginx-proxy-companion
|
|
container_name: ${LETS_ENCRYPT:-nginx-letsencrypt}
|
|
restart: always
|
|
volumes:
|
|
- ${NGINX_FILES_PATH:-./data}/conf.d:/etc/nginx/conf.d
|
|
- ${NGINX_FILES_PATH:-./data}/vhost.d:/etc/nginx/vhost.d
|
|
- ${NGINX_FILES_PATH:-./data}/html:/usr/share/nginx/html
|
|
- ${NGINX_FILES_PATH:-./data}/certs:/etc/nginx/certs:rw
|
|
- /var/run/docker.sock:/var/run/docker.sock:ro
|
|
environment:
|
|
NGINX_DOCKER_GEN_CONTAINER: ${DOCKER_GEN:-nginx-gen}
|
|
NGINX_PROXY_CONTAINER: ${NGINX_WEB:-nginx-web}
|
|
ENABLE_IPV6: "true"
|
|
RESOLVERS: "8.8.8.8 8.8.4.4"
|
|
|
|
logging:
|
|
driver: ${NGINX_LETSENCRYPT_LOG_DRIVER:-json-file}
|
|
options:
|
|
max-size: ${NGINX_LETSENCRYPT_LOG_MAX_SIZE:-2m}
|
|
max-file: ${NGINX_LETSENCRYPT_LOG_MAX_FILE:-10}
|
|
|
|
networks:
|
|
default:
|
|
external:
|
|
name: ${NETWORK:-webproxy}
|