和版本 12 相比,版本 13 有以下的变化
本内容基于版本 12 升级到 版本 13,包含镜像文件的版本升级、配置文件的调整、相关组件的调整等。
此操作版本没有使用官网的 caddy 组件,直接引用系统内置的 Nginx 配置 |
其它版本的安装配置可以参考
.env 用于存储和保存环境变量。后续版本升级调整和组件映射目标变更已经 URL 的调整都可以通过 .env 文件修改而无需调整 yaml 配置文件
官网的操作说明是通过引用多个组件的配置文件完成部署,这种方式适应各组件部署在不同的主机上的场景,对于将所有组件都安装在同一台主机的情况还是将多份文件整合在一起更方便,这里将多份配置文件整合在一个文件中。
COMPOSE_FILE='seafile.yml' ## Images SEAFILE_IMAGE=seafileltd/seafile-pro-mc:13.0-latest SEAFILE_DB_IMAGE=mariadb:10.11.6 SEAFILE_MEMCACHED_IMAGE=memcached:1.6.29 SEAFILE_ELASTICSEARCH_IMAGE=elasticsearch:8.15.0 SEADOC_IMAGE=seafileltd/sdoc-server:2.0-latest NOTIFICATION_SERVER_IMAGE=seafileltd/notification-server:13.0-latest #SEASEARCH_IMAGE=seafileltd/seasearch-nomkl:1.0-latest # Apple's Chip for SeaSearch SEASEARCH_IMAGE=seafileltd/seasearch:1.0-latest MD_IMAGE=seafileltd/seafile-md-server:13.0-latest ## Storage ### Storage type SEAF_SERVER_STORAGE_TYPE=disk # disk, s3, multiple MD_STORAGE_TYPE=$SEAF_SERVER_STORAGE_TYPE # disk, s3 SS_STORAGE_TYPE=$SEAF_SERVER_STORAGE_TYPE # disk, s3 ### Local storage path SEAFILE_VOLUME=/data/seafile/data SEAFILE_MYSQL_VOLUME=/data/seafile/db SEAFILE_ELASTICSEARCH_VOLUME=/data/seafile/elasticsearch SS_DATA_PATH=/data/seafile/seasearch-data SEADOC_VOLUME=/data/seafile/seadoc-data #SEAFILE_CADDY_VOLUME=/opt/seafile-caddy SEAFILE_MYSQL_DB_HOST=db INIT_SEAFILE_MYSQL_ROOT_PASSWORD=www.com SEAFILE_MYSQL_DB_USER=seafile SEAFILE_MYSQL_DB_PASSWORD=9f754db3-8cb7-42c2-999d-46cbe16f3a2d SEAFILE_MYSQL_DB_CCNET_DB_NAME=ccnet_db SEAFILE_MYSQL_DB_SEAFILE_DB_NAME=seafile_db SEAFILE_MYSQL_DB_SEAHUB_DB_NAME=seahub_db TIME_ZONE=Asia/Shanghai JWT_PRIVATE_KEY=0mucRqrGg4/wC+X7bXxccTpUJdz+ySP3FyhrjCR0k5FVyOOqilk4aYfHVWQKx825 SEAFILE_SERVER_HOSTNAME=192.168.77.102:8000 SEAFILE_SERVER_PROTOCOL=http INIT_SEAFILE_ADMIN_EMAIL=13609796771@139.com INIT_SEAFILE_ADMIN_PASSWORD=password INIT_S3_STORAGE_BACKEND_CONFIG=false INIT_S3_COMMIT_BUCKET=<your-commit-objects> INIT_S3_FS_BUCKET=<your-fs-objects> INIT_S3_BLOCK_BUCKET=<your-block-objects> INIT_S3_KEY_ID=<your-key-id> INIT_S3_SECRET_KEY=<your-secret-key> INIT_S3_USE_V4_SIGNATURE=true INIT_S3_AWS_REGION=us-east-1 INIT_S3_HOST=s3.us-east-1.amazonaws.com INIT_S3_USE_HTTPS=true ## Cache CACHE_PROVIDER=redis # options: redis (recommend), memcached ### Redis REDIS_HOST=redis REDIS_PORT=6379 REDIS_PASSWORD=www.myj123.com ## SeaSearch admin user ## (valid in enabling SeaSearch and use Seafile admin by default) INIT_SS_ADMIN_USER=$INIT_SEAFILE_ADMIN_EMAIL INIT_SS_ADMIN_PASSWORD=$INIT_SEAFILE_ADMIN_PASSWORD ############################################ # Additional configurations for extensions # ############################################ ## SeaDoc service ENABLE_SEADOC=true SEADOC_SERVER_URL=http://192.168.77.102:8000/sdoc-server ## SeaSearch ### Local cache SS_MAX_OBJ_CACHE_SIZE=10GB ### Log SS_LOG_TO_STDOUT=false SS_LOG_OUTPUT=true SS_LOG_LEVEL=info ## Notification ENABLE_NOTIFICATION_SERVER=false NOTIFICATION_SERVER_URL= ## Seafile AI ENABLE_SEAFILE_AI=false SEAFILE_AI_LLM_TYPE=openai SEAFILE_AI_LLM_URL= SEAFILE_AI_LLM_KEY= # your llm key SEAFILE_AI_LLM_MODEL=gpt-4o-mini ## Metadata server MD_FILE_COUNT_LIMIT=100000 |
version: '3.0'
services:
db:
image: ${SEAFILE_DB_IMAGE:-mariadb:10.11}
container_name: seafile-mysql
environment:
- MYSQL_ROOT_PASSWORD=${INIT_SEAFILE_MYSQL_ROOT_PASSWORD:-www.lfang123.com} # Requested, set the root's password of MySQL service.
- MYSQL_LOG_CONSOLE=true
- MARIADB_AUTO_UPGRADE=1
volumes:
- /data/seafile/db:/var/lib/mysql # Requested, specifies the path to MySQL data persistent store.
- /data/seafile/db/.my-healthcheck.cnf:/var/lib/mysql/.my-healthcheck.cnf:ro
healthcheck:
test:
[
"CMD",
"/usr/local/bin/healthcheck.sh",
"--defaults-extra-file=/var/lib/mysql/.my-healthcheck.cnf",
"--connect",
"--mariadbupgrade",
"--innodb_initialized",
]
interval: 20s
start_period: 30s
timeout: 5s
retries: 10
networks:
- seafile-net
redis:
image: ${SEAFILE_REDIS_IMAGE:-redis}
container_name: seafile-redis
restart: unless-stopped
command:
- /bin/sh
- -c
- redis-server --requirepass "$$REDIS_PASSWORD"
environment:
- REDIS_PASSWORD=${REDIS_PASSWORD:-}
networks:
- seafile-net
seafile:
image: ${SEAFILE_IMAGE:-seafileltd/seafile-pro-mc:13.0-latest}
container_name: seafile
ports:
- "8000:80"
# - "443:443" # If https is enabled, cancel the comment.
volumes:
- /data/seafile/data:/shared
- /data/seafile/deps/seafile-controller:/opt/seafile/seafile-pro-server-13.0.16/seafile/bin/seafile-controller
- /data/seafile/deps/seaf-server:/opt/seafile/seafile-pro-server-13.0.16/seafile/bin/seaf-server
- /data/seafile/deps/licenseparse.py:/opt/seafile/seafile-pro-server-13.0.16/seahub/seahub/utils/licenseparse.py
- /data/seafile/deps/seafile.nginx.conf:/etc/nginx/sites-enabled/seafile.nginx.conf
environment:
- INIT_SEAFILE_MYSQL_ROOT_PASSWORD=${INIT_SEAFILE_MYSQL_ROOT_PASSWORD:-}
- SEAFILE_MYSQL_DB_HOST=${SEAFILE_MYSQL_DB_HOST:-db}
- SEAFILE_MYSQL_DB_PORT=${SEAFILE_MYSQL_DB_PORT:-3306}
- SEAFILE_MYSQL_DB_USER=${SEAFILE_MYSQL_DB_USER:-seafile}
- SEAFILE_MYSQL_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}
- SEAFILE_LOG_TO_STDOUT=${SEAFILE_LOG_TO_STDOUT:-false}
- ENABLE_GO_FILESERVER=${ENABLE_GO_FILESERVER:-true}
- ENABLE_SEADOC=${ENABLE_SEADOC:-true}
- SEADOC_SERVER_URL=${SEAFILE_SERVER_PROTOCOL:-http}://${SEAFILE_SERVER_HOSTNAME:?Variable is not set or empty}/sdoc-server
- CACHE_PROVIDER=${CACHE_PROVIDER:-redis}
- REDIS_HOST=${REDIS_HOST:-redis}
- REDIS_PORT=${REDIS_PORT:-6379}
- REDIS_PASSWORD=${REDIS_PASSWORD:-}
- MEMCACHED_HOST=${MEMCACHED_HOST:-memcached}
- MEMCACHED_PORT=${MEMCACHED_PORT:-11211}
- SEAF_SERVER_STORAGE_TYPE=${SEAF_SERVER_STORAGE_TYPE:-}
- S3_COMMIT_BUCKET=${S3_COMMIT_BUCKET:-}
- S3_FS_BUCKET=${S3_FS_BUCKET:-}
- S3_BLOCK_BUCKET=${S3_BLOCK_BUCKET:-}
- S3_KEY_ID=${S3_KEY_ID:-}
- S3_SECRET_KEY=${S3_SECRET_KEY:-}
- S3_USE_V4_SIGNATURE=${S3_USE_V4_SIGNATURE:-true}
- S3_AWS_REGION=${S3_AWS_REGION:-us-east-1}
- S3_HOST=${S3_HOST:-}
- S3_USE_HTTPS=${S3_USE_HTTPS:-true}
- S3_PATH_STYLE_REQUEST=${S3_PATH_STYLE_REQUEST:-false}
- S3_SSE_C_KEY=${S3_SSE_C_KEY:-}
- ENABLE_NOTIFICATION_SERVER=${ENABLE_NOTIFICATION_SERVER:-false}
- INNER_NOTIFICATION_SERVER_URL=${INNER_NOTIFICATION_SERVER_URL:-http://notification-server:8083}
- NOTIFICATION_SERVER_URL=${NOTIFICATION_SERVER_URL:-${SEAFILE_SERVER_PROTOCOL:-http}://${SEAFILE_SERVER_HOSTNAME:?Variable is not set or empty}/notification}
- ENABLE_SEAFILE_AI=${ENABLE_SEAFILE_AI:-false}
- SEAFILE_AI_SERVER_URL=${SEAFILE_AI_SERVER_URL:-http://seafile-ai:8888}
- SEAFILE_AI_SECRET_KEY=${JWT_PRIVATE_KEY:?Variable is not set or empty}
- MD_FILE_COUNT_LIMIT=${MD_FILE_COUNT_LIMIT:-100000}
healthcheck:
test: ["CMD-SHELL", "curl -f http://localhost:80 || exit 1"]
interval: 30s
timeout: 10s
retries: 3
start_period: 10s
depends_on:
db:
condition: service_healthy
redis:
condition: service_started
networks:
- seafile-net
seadoc:
image: ${SEADOC_IMAGE:-seafileltd/sdoc-server:2.0-latest}
container_name: seadoc
restart: unless-stopped
volumes:
- ${SEADOC_VOLUME:-/opt/seadoc-data/}:/shared
environment:
- DB_HOST=${SEAFILE_MYSQL_DB_HOST:-db}
- DB_PORT=${SEAFILE_MYSQL_DB_PORT:-3306}
- DB_USER=${SEAFILE_MYSQL_DB_USER:-seafile}
- DB_PASSWORD=${SEAFILE_MYSQL_DB_PASSWORD:?Variable is not set or empty}
- DB_NAME=${SEADOC_MYSQL_DB_NAME:-${SEAFILE_MYSQL_DB_SEAHUB_DB_NAME:-seahub_db}}
- TIME_ZONE=${TIME_ZONE:-Etc/UTC}
- JWT_PRIVATE_KEY=${JWT_PRIVATE_KEY:?Variable is not set or empty}
- NON_ROOT=${NON_ROOT:-false}
# #- SEAHUB_SERVICE_URL=${SEAFILE_SERVICE_URL:-http://seafile}
- SEAHUB_SERVICE_URL=http://192.168.77.102:8000
depends_on:
db:
condition: service_healthy
networks:
- seafile-net
notification-server:
image: ${NOTIFICATION_SERVER_IMAGE:-seafileltd/notification-server:13.0-latest}
container_name: notification-server
restart: always
volumes:
- ${SEAFILE_VOLUME:-/opt/seafile-data}/seafile/logs:/shared/seafile/logs
ports:
- "8083:8083"
environment:
- SEAFILE_MYSQL_DB_HOST=${SEAFILE_MYSQL_DB_HOST:-db}
- SEAFILE_MYSQL_DB_PORT=${SEAFILE_MYSQL_DB_PORT:-3306}
- SEAFILE_MYSQL_DB_USER=${SEAFILE_MYSQL_DB_USER:-seafile}
- SEAFILE_MYSQL_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}
- JWT_PRIVATE_KEY=${JWT_PRIVATE_KEY:?Variable is not set or empty}
- SEAFILE_LOG_TO_STDOUT=${SEAFILE_LOG_TO_STDOUT:-false}
- NOTIFICATION_SERVER_LOG_LEVEL=${NOTIFICATION_SERVER_LOG_LEVEL:-info}
depends_on:
db:
condition: service_healthy
seafile:
condition: service_healthy
networks:
- seafile-net
seasearch:
image: ${SEASEARCH_IMAGE:-seafileltd/seasearch:1.0-latest}
container_name: seafile-seasearch
restart: unless-stopped
volumes:
- ${SS_DATA_PATH:-/opt/seasearch-data}:/opt/seasearch/data
environment:
- SS_FIRST_ADMIN_USER=${INIT_SS_ADMIN_USER:-}
- SS_FIRST_ADMIN_PASSWORD=${INIT_SS_ADMIN_PASSWORD:-}
- SS_MAX_OBJ_CACHE_SIZE=${SS_MAX_OBJ_CACHE_SIZE:-10GB}
- SS_STORAGE_TYPE=${SS_STORAGE_TYPE:-disk}
- S3_SS_BUCKET=${S3_SS_BUCKET:-}
- S3_KEY_ID=${S3_KEY_ID:-}
- S3_USE_V4_SIGNATURE=${S3_USE_V4_SIGNATURE:-true}
- S3_SECRET_KEY=${S3_SECRET_KEY:-}
- S3_HOST=${S3_HOST:-}
- S3_USE_HTTPS=${S3_USE_HTTPS:-true}
- S3_PATH_STYLE_REQUEST=${S3_PATH_STYLE_REQUEST:-true}
- S3_AWS_REGION=${S3_AWS_REGION:-us-east-1}
- S3_SSE_C_KEY=${S3_SSE_C_KEY:-}
- SS_LOG_TO_STDOUT=${SS_LOG_TO_STDOUT:-false}
- SS_LOG_DIR=${SS_LOG_DIR:-/opt/seasearch/data/log}
- SS_LOG_LEVEL=${SS_LOG_LEVEL:-info}
# SeaSeasrch Proxy
- SEAFILE_LOG_TO_STDOUT=${SEAFILE_LOG_TO_STDOUT:-false}
- SEATABLE_LOG_TO_STDOUT=${SEATABLE_LOG_TO_STDOUT:-false}
# for cluster
- SS_SERVER_MODE=${SS_SERVER_MODE:-}
- SS_CLUSTER_ID=${SS_CLUSTER_ID:-}
- SS_CLUSTER_PROXY_HOST=${SS_CLUSTER_PROXY_HOST:-0.0.0.0}
- SS_CLUSTER_PROXY_PORT=${SS_CLUSTER_PROXY_PORT:-4082}
- SS_CLUSTER_MANAGER_ADDR=${SS_CLUSTER_MANAGER_ADDR:-127.0.0.1:4081}
- SS_ETCD_USERNAME=${SS_ETCD_USERNAME:-}
- SS_ETCD_PASSWORD=${SS_ETCD_PASSWORD:-}
- SS_ETCD_ENDPOINTS=${SS_ETCD_ENDPOINTS:-127.0.0.1:2379}
- SS_ETCD_PREFIX=${SS_ETCD_PREFIX:-/zinc}
- SS_CLUSTER_PROXY_LOG_DIR=${SS_CLUSTER_PROXY_LOG_DIR:--/opt/seasearch/data/log}
- SS_CLUSTER_MANAGER_HOST=${SS_CLUSTER_MANAGER_HOST:-0.0.0.0}
- SS_CLUSTER_MANAGER_PORT=${SS_CLUSTER_MANAGER_PORT:-4081}
networks:
- seafile-net
networks:
seafile-net:
name: seafile-net |
直接使用官网的数据库容器配置会出现数据库检测失败的情况,主要原因是健康检测脚本没有加载数据库的用户名和密码,一直尝试使用空密码登录,最终导致数据库容器的健康检测失败
最简单的解决方法有2种:
以下操作基于方法2。
seafile-mysql | Version: '10.11.6-MariaDB-1:10.11.6+maria~ubu2204' socket: '/run/mysqld/mysqld.sock' port: 3306 mariadb.org binary distribution seafile-mysql | 2026-01-27 6:02:08 0 [Note] InnoDB: Buffer pool(s) load completed at 260127 6:02:08 seafile-mysql | 2026-01-27 6:02:12 3 [Warning] Access denied for user 'root'@'::1' (using password: NO)
seafile-mysql | 2026-01-27 6:02:12 4 [Warning] Access denied for user 'root'@'localhost' (using password: NO) seafile-mysql | 2026-01-27 6:02:17 5 [Warning] Access denied for user 'root'@'::1' (using password: NO)
seafile-mysql | 2026-01-27 6:02:17 6 [Warning] Access denied for user 'root'@'localhost' (using password: NO)
- /data/seafile/db/.my-healthcheck.cnf:/var/lib/mysql/.my-healthcheck.cnf:ro 的映射就是增加了数据库用户名和密码的配置文件。
[client] user=root password=www.com host=localhost protocol=tcp |