towards tidy seafile setup
This commit is contained in:
@@ -69,7 +69,7 @@ seafile.rik.veenboer.xyz {
|
|||||||
log {
|
log {
|
||||||
output file /var/log/seafile.log
|
output file /var/log/seafile.log
|
||||||
}
|
}
|
||||||
reverse_proxy host:12380
|
reverse_proxy host:8082
|
||||||
}
|
}
|
||||||
|
|
||||||
(authentik) {
|
(authentik) {
|
||||||
|
|||||||
@@ -1,17 +1,63 @@
|
|||||||
services:
|
services:
|
||||||
seafile:
|
seafile-mysql:
|
||||||
build:
|
image: mariadb:10.11
|
||||||
context: /opt/seafile/docker/
|
container_name: seafile-mysql
|
||||||
container_name: seafile
|
environment:
|
||||||
environment:
|
- MYSQL_ROOT_PASSWORD=ROOT_PASSWORD
|
||||||
- MODE=autorun
|
- MYSQL_LOG_CONSOLE=true
|
||||||
image: gronis/seafile:10.0.1
|
- MARIADB_AUTO_UPGRADE=1
|
||||||
# image: seafile
|
volumes:
|
||||||
ports:
|
- /opt/seafile/db:/var/lib/mysql
|
||||||
- 8100:8000
|
healthcheck:
|
||||||
- 8180:8080
|
test:
|
||||||
- 8182:8082
|
[
|
||||||
restart: unless-stopped
|
"CMD",
|
||||||
volumes:
|
"/usr/local/bin/healthcheck.sh",
|
||||||
- /opt/seafile:/seafile
|
"--connect",
|
||||||
- /media/sync/seafile:/seafile/seafile-data
|
"--mariadbupgrade",
|
||||||
|
"--innodb_initialized",
|
||||||
|
]
|
||||||
|
interval: 20s
|
||||||
|
start_period: 30s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 10
|
||||||
|
|
||||||
|
seafile-server:
|
||||||
|
image: seafileltd/seafile-mc:12.0-latest
|
||||||
|
container_name: seafile-server
|
||||||
|
ports:
|
||||||
|
- "8082:80"
|
||||||
|
volumes:
|
||||||
|
- /opt/seafile/data:/shared
|
||||||
|
- /media/sync/seafile:/shared/seafile/seafile-data
|
||||||
|
environment:
|
||||||
|
- DB_HOST=seafile-mysql
|
||||||
|
- DB_PORT=3306
|
||||||
|
- DB_ROOT_PASSWD=ROOT_PASSWORD
|
||||||
|
- DB_PASSWORD=PASSWORD
|
||||||
|
- TIME_ZONE=Europe/Amsterdam
|
||||||
|
- INIT_SEAFILE_ADMIN_EMAIL=admin@veenboer.xyz
|
||||||
|
- INIT_SEAFILE_ADMIN_PASSWORD=asecret
|
||||||
|
- SEAFILE_SERVER_HOSTNAME=seafile.rik.veenboer.xyz
|
||||||
|
- SEAFILE_SERVER_PROTOCOL=https
|
||||||
|
- JWT_PRIVATE_KEY=8LzWzeuQ41z1i8fc1cr1L7Kw80VpTgmT
|
||||||
|
|
||||||
|
# - DB_HOST=${SEAFILE_MYSQL_DB_HOST:-db}
|
||||||
|
# - DB_PORT=${SEAFILE_MYSQL_DB_PORT:-3306}
|
||||||
|
# - DB_ROOT_PASSWD=${INIT_SEAFILE_MYSQL_ROOT_PASSWORD:-}
|
||||||
|
# - DB_PASSWORD=${SEAFILE_MYSQL_DB_PASSWORD:?Variable is not set or empty}
|
||||||
|
- SEAFILE_MYSQL_DB_CCNET_DB_NAME=${SEAFILE_MYSQL_DB_CCNET_DB_NAME:-ccnet_db}
|
||||||
|
- SEAFILE_MYSQL_DB_SEAFILE_DB_NAME=${SEAFILE_MYSQL_DB_SEAFILE_DB_NAME:-seafile_db}
|
||||||
|
- SEAFILE_MYSQL_DB_SEAHUB_DB_NAME=${SEAFILE_MYSQL_DB_SEAHUB_DB_NAME:-seahub_db}
|
||||||
|
# - TIME_ZONE=${TIME_ZONE:-Etc/UTC}
|
||||||
|
# - INIT_SEAFILE_ADMIN_EMAIL=${INIT_SEAFILE_ADMIN_EMAIL:-me@example.com}
|
||||||
|
# - INIT_SEAFILE_ADMIN_PASSWORD=${INIT_SEAFILE_ADMIN_PASSWORD:-asecret}
|
||||||
|
# - SEAFILE_SERVER_HOSTNAME=${SEAFILE_SERVER_HOSTNAME:?Variable is not set or empty}
|
||||||
|
# - SEAFILE_SERVER_PROTOCOL=${SEAFILE_SERVER_PROTOCOL:-http}
|
||||||
|
- SITE_ROOT=${SITE_ROOT:-/}
|
||||||
|
- NON_ROOT=${NON_ROOT:-false}
|
||||||
|
# - JWT_PRIVATE_KEY=${JWT_PRIVATE_KEY:?Variable is not set or empty}
|
||||||
|
- ENABLE_SEADOC=${ENABLE_SEADOC:-false}
|
||||||
|
- SEADOC_SERVER_URL=${SEADOC_SERVER_URL:-http://example.example.com/sdoc-server}
|
||||||
|
depends_on:
|
||||||
|
- seafile-mysql
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
include:
|
include:
|
||||||
# Web
|
# Web
|
||||||
- docker-compose.caddy.yml
|
- docker-compose.caddy.yml
|
||||||
- docker-compose.nginx.yml
|
|
||||||
|
|
||||||
# Authentication
|
# Authentication
|
||||||
- docker-compose.authentik.yml
|
- docker-compose.authentik.yml
|
||||||
|
|||||||
33
seafile/.env
Normal file
33
seafile/.env
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
SEAFILE_IMAGE=seafileltd/seafile-mc:12.0-latest
|
||||||
|
SEAFILE_DB_IMAGE=mariadb:10.11
|
||||||
|
SEAFILE_MEMCACHED_IMAGE=memcached:1.6.29
|
||||||
|
SEAFILE_CADDY_IMAGE=lucaslorentz/caddy-docker-proxy:2.9
|
||||||
|
|
||||||
|
SEAFILE_VOLUME=/opt/seafile/data
|
||||||
|
SEAFILE_MYSQL_VOLUME=/opt/seafile/db
|
||||||
|
SEAFILE_CADDY_VOLUME=/opt/seafile/caddy
|
||||||
|
|
||||||
|
SEAFILE_MYSQL_DB_HOST=db
|
||||||
|
INIT_SEAFILE_MYSQL_ROOT_PASSWORD=ROOT_PASSWORD
|
||||||
|
SEAFILE_MYSQL_DB_USER=seafile
|
||||||
|
SEAFILE_MYSQL_DB_PASSWORD=PASSWORD
|
||||||
|
|
||||||
|
TIME_ZONE=Europe/Amsterdam
|
||||||
|
|
||||||
|
JWT_PRIVATE_KEY=8LzWzeuQ41z1i8fc1cr1L7Kw80VpTgmT
|
||||||
|
|
||||||
|
SEAFILE_SERVER_HOSTNAME=seafile.rik.veenboer.xyz
|
||||||
|
SEAFILE_SERVER_PROTOCOL=https
|
||||||
|
|
||||||
|
INIT_SEAFILE_ADMIN_EMAIL=admin@rik.veenboer.xyz
|
||||||
|
INIT_SEAFILE_ADMIN_PASSWORD=asecret
|
||||||
|
|
||||||
|
|
||||||
|
SEADOC_IMAGE=seafileltd/sdoc-server:1.0-latest
|
||||||
|
SEADOC_VOLUME=/opt/seadoc-data
|
||||||
|
|
||||||
|
ENABLE_SEADOC=false
|
||||||
|
SEADOC_SERVER_URL=http://example.seafile.com/sdoc-server
|
||||||
|
|
||||||
|
NOTIFICATION_SERVER_IMAGE=seafileltd/notification-server:12.0-latest
|
||||||
|
NOTIFICATION_SERVER_VOLUME=/opt/notification-data
|
||||||
@@ -27,8 +27,7 @@ services:
|
|||||||
image: ${SEAFILE_IMAGE:-seafileltd/seafile-mc:12.0-latest}
|
image: ${SEAFILE_IMAGE:-seafileltd/seafile-mc:12.0-latest}
|
||||||
container_name: seafile
|
container_name: seafile
|
||||||
ports:
|
ports:
|
||||||
- "12380:80"
|
- "8082:80"
|
||||||
- "18082:8082"
|
|
||||||
volumes:
|
volumes:
|
||||||
- ${SEAFILE_VOLUME:-/opt/seafile-data}:/shared
|
- ${SEAFILE_VOLUME:-/opt/seafile-data}:/shared
|
||||||
- /media/sync/seafile:/shared/seafile/seafile-data
|
- /media/sync/seafile:/shared/seafile/seafile-data
|
||||||
Reference in New Issue
Block a user