mirror of
https://github.com/nextcloud/docker.git
synced 2025-04-20 10:56:08 +02:00
* Updated examples Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Lock examples to PostgreSQL 16 Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Pin postgresql to 16 in Readme example Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Update .examples/docker-compose/insecure/mariadb/apache/compose.yaml Co-authored-by: J0WI <J0WI@users.noreply.github.com> Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Update .examples/docker-compose/insecure/postgres/apache/compose.yaml Co-authored-by: J0WI <J0WI@users.noreply.github.com> Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Update .examples/docker-compose/insecure/mariadb/fpm/compose.yaml Co-authored-by: J0WI <J0WI@users.noreply.github.com> Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Moved some comments on new lines. Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Moved another comment to new line Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Unified across files / updated README file. Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> * Use canonical links to external services. Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> --------- Signed-off-by: Kaloyan Nikolov <tzerber@gmail.com> Co-authored-by: J0WI <J0WI@users.noreply.github.com>
127 lines
3.5 KiB
YAML
127 lines
3.5 KiB
YAML
services:
|
|
# Note: PostgreSQL is an external service. You can find more information about the configuration here:
|
|
# https://hub.docker.com/_/postgres
|
|
db:
|
|
# Note: Check the recommend version here: https://docs.nextcloud.com/server/latest/admin_manual/installation/system_requirements.html#server
|
|
image: postgres:alpine
|
|
restart: always
|
|
volumes:
|
|
- db:/var/lib/postgresql/data:Z
|
|
env_file:
|
|
- db.env
|
|
|
|
# Note: Redis is an external service. You can find more information about the configuration here:
|
|
# https://hub.docker.com/_/redis
|
|
redis:
|
|
image: redis:alpine
|
|
restart: always
|
|
|
|
app:
|
|
image: nextcloud:fpm-alpine
|
|
restart: always
|
|
volumes:
|
|
- nextcloud:/var/www/html:z
|
|
# NOTE: The `volumes` config of the `cron` and `app` containers must match
|
|
environment:
|
|
- POSTGRES_HOST=db
|
|
- REDIS_HOST=redis
|
|
env_file:
|
|
- db.env
|
|
depends_on:
|
|
- db
|
|
- redis
|
|
- proxy
|
|
|
|
# Note: Nginx is an external service. You can find more information about the configuration here:
|
|
# https://hub.docker.com/_/nginx/
|
|
web:
|
|
image: nginx:alpine-slim
|
|
restart: always
|
|
volumes:
|
|
# https://docs.nextcloud.com/server/latest/admin_manual/installation/nginx.html
|
|
- ./web/nginx.conf:/etc/nginx/nginx.conf:ro
|
|
# NOTE: The `volumes` included below should match those of the `app` container (unless you know what you're doing)
|
|
- nextcloud:/var/www/html:z,ro
|
|
environment:
|
|
- VIRTUAL_HOST=
|
|
- LETSENCRYPT_HOST=
|
|
- LETSENCRYPT_EMAIL=
|
|
depends_on:
|
|
- app
|
|
networks:
|
|
- proxy-tier
|
|
- default
|
|
|
|
cron:
|
|
image: nextcloud:fpm-alpine
|
|
restart: always
|
|
volumes:
|
|
- nextcloud:/var/www/html:z
|
|
# NOTE: The `volumes` config of the `cron` and `app` containers must match
|
|
entrypoint: /cron.sh
|
|
depends_on:
|
|
- db
|
|
- redis
|
|
|
|
# Note: Nginx-proxy is an external service. You can find more information about the configuration here:
|
|
# Warning: Do not use :latest tags of nginx-proxy unless absolutely sure about the consequences.
|
|
# https://hub.docker.com/r/nginxproxy/nginx-proxy
|
|
proxy:
|
|
build: ./proxy
|
|
restart: always
|
|
ports:
|
|
- 80:80
|
|
- 443:443
|
|
labels:
|
|
- "com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy"
|
|
volumes:
|
|
- certs:/etc/nginx/certs:z,ro
|
|
- vhost.d:/etc/nginx/vhost.d:z
|
|
- html:/usr/share/nginx/html:z
|
|
- /var/run/docker.sock:/tmp/docker.sock:z,ro
|
|
networks:
|
|
- proxy-tier
|
|
|
|
# Note: Letsencrypt companion is an external service. You can find more information about the configuration here:
|
|
# https://hub.docker.com/r/nginxproxy/acme-companion
|
|
letsencrypt-companion:
|
|
image: nginxproxy/acme-companion
|
|
restart: always
|
|
volumes:
|
|
- certs:/etc/nginx/certs:z
|
|
- acme:/etc/acme.sh:z
|
|
- vhost.d:/etc/nginx/vhost.d:z
|
|
- html:/usr/share/nginx/html:z
|
|
- /var/run/docker.sock:/var/run/docker.sock:z,ro
|
|
environment:
|
|
- DEFAULT_EMAIL=
|
|
networks:
|
|
- proxy-tier
|
|
depends_on:
|
|
- proxy
|
|
|
|
# self signed, outdated
|
|
# omgwtfssl:
|
|
# image: paulczar/omgwtfssl
|
|
# restart: "no"
|
|
# volumes:
|
|
# - certs:/certs
|
|
# environment:
|
|
# - SSL_SUBJECT=servhostname.local
|
|
# - CA_SUBJECT=my@example.com
|
|
# - SSL_KEY=/certs/servhostname.local.key
|
|
# - SSL_CSR=/certs/servhostname.local.csr
|
|
# - SSL_CERT=/certs/servhostname.local.crt
|
|
# networks:
|
|
# - proxy-tier
|
|
|
|
volumes:
|
|
db:
|
|
nextcloud:
|
|
certs:
|
|
acme:
|
|
vhost.d:
|
|
html:
|
|
|
|
networks:
|
|
proxy-tier:
|