-
-
Notifications
You must be signed in to change notification settings - Fork 309
Expand file tree
/
Copy pathdocker-compose-monolithic-https.yml
More file actions
88 lines (83 loc) · 2.73 KB
/
docker-compose-monolithic-https.yml
File metadata and controls
88 lines (83 loc) · 2.73 KB
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
version: "3.5"
services:
db:
image: mariadb:10.7
container_name: librenms_db
restart: always
command:
- "mysqld"
- "--innodb-file-per-table=1"
- "--lower-case-table-names=0"
- "--character-set-server=utf8mb4"
- "--collation-server=utf8mb4_unicode_ci"
volumes:
- "./db:/var/lib/mysql"
environment:
- "TZ=${TZ}"
- "MYSQL_ALLOW_EMPTY_PASSWORD=yes"
- "MYSQL_DATABASE=librenms"
- "MYSQL_USER=librenms"
- "MYSQL_PASSWORD=${MYSQL_PASSWORD}"
# simple static Traefik config, you may want to use the docker provider and labels instead
traefik:
image: traefik:2.8 # please check version tag to use the most current version
restart: unless-stopped
volumes:
- ./letsencrypt/:/letsencrypt/ # TLS certificate storage
ports:
- "80:80"
- "443:443"
command:
- "--entryPoints.web.address=:80"
- "--entryPoints.websecure.address=:443"
- "--certificatesresolvers.letsencryptresolver.acme.tlschallenge=true"
- "--certificatesresolvers.letsencryptresolver.acme.tlschallenge.entrypoint=websecure"
- "--certificatesresolvers.letsencryptresolver.acme.email=$LETSENCRYPT_EMAIL"
- "--certificatesresolvers.letsencryptresolver.acme.storage=/letsencrypt/acme.json"
- "--certificatesresolvers.letsencryptresolver.acme.caserver: https://acme-staging-v02.api.letsencrypt.org/directory" # Use staging server first
- "--http.routers.http-catchall.entrypoints=web"
- "--http.routers.http-catchall.rule=HostRegexp(`{host:.+}`)"
- "--http.routers.http-catchall.middlewares=redirect-to-https"
- "--http.middlewares.redirect-to-https.redirectscheme.scheme=https"
- "--http.routers.librenms.entrypoints=websecure"
- "--http.routers.librenms.tls.certresolver=letsencryptresolver"
- "--http.routers.librenms.rule=Host(`$LIBRENMS_BASE_URL`)"
- "--http.routers.librenms.service=librenms"
librenms:
image: librenms/librenms:latest
container_name: librenms
hostname: librenms
restart: always
cap_add:
- NET_ADMIN
- NET_RAW
ports:
- target: 8000
published: 8000
protocol: tcp
- target: 162
published: 162
protocol: tcp
- target: 162
published: 162
protocol: udp
- target: 514
published: 514
protocol: tcp
- target: 514
published: 514
protocol: udp
depends_on:
- db
volumes:
- "./librenms:/data"
environment:
- "MONOLITHIC=1"
- "TZ=${TZ}"
- "PUID=${PUID}"
- "PGID=${PGID}"
- "DB_HOST=db"
- "DB_NAME=librenms"
- "DB_USER=librenms"
- "DB_PASSWORD=${MYSQL_PASSWORD}"
- "DB_TIMEOUT=60"