-
Notifications
You must be signed in to change notification settings - Fork 57
/
nextcloud.yml
113 lines (113 loc) · 4.04 KB
/
nextcloud.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
# ARCHIVED! DO NOT USE, NOT EVEN AS STARTING POINT, IT IS TOO OUTDATED!
#
version: "2.0"
services:
# THIS FILE CONTAINS SERVICES THAT I NO LONGER USE: NextCloud, because FileRun is much faster and has direct filesystem/folder-per-user access.
##
## To expose Nextcloud securely, Caddy is the easiest way to go.
##_____________________ Caddy [CLOUD/web-proxy]
caddy:
container_name: caddy-proxy
image: lucaslorentz/caddy-docker-proxy:ci-alpine
restart: always
networks:
- web-proxy
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- ./caddy/caddy_data:/data
- $DOCKERDIR/caddy/caddy_data:/data
- $DOCKERDIR/caddy/config:/config
volumes_from: # test with this first, then if everything works, see if you can replace it by only mounting the necessary volumes.
- nextcloud
#- $DOCKERDIR/nextcloud/var/www/html:/nextcloud/var/www/html
#- $DOCKERDIR/nextcloud/var/data:/nextcloud/var/nextdata
ports:
- 80:80
- 443:443
##
##____________________ NextCloud TESTED V21.0 [CLOUD/Files/NextCloud]
nextcloud:
image: nextcloud:21-fpm
container_name: nextcloud
restart: always
mem_limit: 2048m
mem_reservation: 512m
networks:
- web-proxy
- nextcloud
depends_on:
- nextcloud-db
- nextcloud-cache
environment:
NEXTCLOUD_DATA_DIR: /var/nextdata
NEXTCLOUD_TRUSTED_DOMAINS: next.$DOMAIN
NEXTCLOUD_ADMIN_USER: $USER1
NEXTCLOUD_ADMIN_PASSWORD: $USER1PW
POSTGRES_HOST: nextcloud-db
POSTGRES_DB: nextcloud
POSTGRES_USER: $USER
POSTGRES_PASSWORD: $PW_INT
REDIS_HOST: nextcloud-cache
REDIS_HOST_PASSWORD: $PW_INT
SMTP_HOST: $SMTPHOST
SMTP_SECURE: tls
SMTP_NAME: $SMTPUSER
SMTP_PASSWORD: $SMTPPASS
SMTP_FROM_ADDRESS: $EMAIL
SMTP_PORT: 587
volumes:
# the actual data of the Nextcloud:
- ./nextcloud/nextcloud:/var/www/html
# Main folder needed for the apps:
- ./nextcloud/apps:/var/www/html/custom_apps
# Main folder needed for the datas:
- ./nextcloud/data:/var/www/html/data
# local configuration
- ./nextcloud/config:/var/www/html/config
# Custom settings for php fpm to make nextcloud work. The default settings resulted in the error:
# WARNING: [pool www] server reached pm.max_children setting (5), consider raising it
#- $DOCKERDIR/nextcloud/etc/www-custom.ini:/usr/local/etc/php-fpm.d/zz-custom.conf
labels:
caddy: next.$DOMAIN
caddy.tls: $EMAIL
caddy.file_server: ""
caddy.root: "* /nextcloud/var/www/html"
caddy.php_fastcgi: "{{upstreams 9000}}"
caddy.php_fastcgi.root: "/var/www/html"
caddy.php_fastcgi.env: "front_controller_active true"
caddy.encode: gzip
caddy.redir_0: "/.well-known/carddav /remote.php/dav 301"
caddy.redir_1: "/.well-known/caldav /remote.php/dav 301"
caddy.header.Strict-Transport-Security: '"max-age=15768000;includeSubDomains;preload"' # Required for Nextcloud
#caddy.header.X-XSS-Protection: '"1; mode=block;"' # Required for FileRun+OnlyOffice
#caddy.header.X-Content-Type-Options: "nosniff" # Required for FileRun+OnlyOffice
#caddy.header.X-Frame-Options: "SAMEORIGIN" # Required for FileRun+OnlyOffice
##____________________ NextCloud [CLOUD/Files/NextCloud/database]
nextcloud-db:
container_name: nextcloud-db
image: postgres:12-alpine
restart: always
networks:
- nextcloud
environment:
POSTGRES_USER: $USER
POSTGRES_PASSWORD: $PW_INT
volumes:
- $DOCKERDIR/nextcloud/db:/var/lib/postgresql/data
- /etc/localtime:/etc/localtime:ro
##____________________ NextCloud [CLOUD/Files/NextCloud/cache]
nextcloud-cache:
container_name: nextcloud-cache
image: redis:alpine
restart: always
mem_limit: 2048m
mem_reservation: 512m
networks:
- nextcloud
command: redis-server --requirepass $PW_INT
#
networks:
web-proxy:
driver: bridge
nextcloud:
driver: bridge