-
创建者:
虚拟的现实,上次更新时间:1月 28, 2026 需要 5 分钟阅读时间
简介
和版本 12 相比,版本 13 有以下的变化
- 环境变量都建议整合到 .env 文件中
- seadoc 版本升级到了 2.0
- 缓存组件建议调整到 Redis (之前是 memcache)
- 搜索组件 SeaSearch 升级到了 1.0
- seafile.conf 和 seahub_settings.py 的配置内容调整到 .env 文件
- /etc/nginx/sites-enabled/seafile.nginx.conf 是版本 13 的 nginx 配置文件
本内容基于版本 12 升级到 版本 13,包含镜像文件的版本升级、配置文件的调整、相关组件的调整等。
此操作版本没有使用官网的 caddy 组件,直接引用系统内置的 Nginx 配置
其它版本的安装配置可以参考
- docker-自定义 seafile
- docker-seafile-12.0.6
- docker-seafile-12.0.11
- docker-seafile-11.06 ARM
- docker-seafile-13.0.8-pro
配置文件
.env 用于存储和保存环境变量。后续版本升级调整和组件映射目标变更已经 URL 的调整都可以通过 .env 文件修改而无需调整 yaml 配置文件
官网的操作说明是通过引用多个组件的配置文件完成部署,这种方式适应各组件部署在不同的主机上的场景,对于将所有组件都安装在同一台主机的情况还是将多份文件整合在一起更方便,这里将多份配置文件整合在一个文件中。
.env
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
seafile_13.yaml
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
数据库说明
直接使用官网的数据库容器配置会出现数据库检测失败的情况,主要原因是健康检测脚本没有加载数据库的用户名和密码,一直尝试使用空密码登录,最终导致数据库容器的健康检测失败
最简单的解决方法有3种:
- 取消健康检测的脚本
- 调整健康检测脚本将用户名和密码写入配置文件
- 替换原有的检测文件,将用户名和密码写入检测脚本
healthcheck: test: ["CMD", "mysqladmin", "ping", "-h", "localhost", "-uroot", "-pwww.com"] interval: 30s timeout: 10s retries: 3 start_period: 60s
以下操作基于方法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
数据库检查参考
SELECT Host, User, plugin, authentication_string FROM mysql.user WHERE User='root'; # 查看seafile-mysql容器的实际环境变量 docker exec seafile-mysql env | grep -i mysql # 查看容器的运行时配置 docker inspect seafile-mysql | grep -A5 -B5 "MYSQL_ROOT_PASSWORD" # 查看Seafile应用容器的环境变量 docker exec seafile-app env | grep -i mysql -- 1. 查看root用户配置 SELECT Host, User, plugin, authentication_string FROM mysql.user WHERE User='root'; -- 2. 检查用户密码是否设置 SELECT Host, User, Password FROM mysql.user WHERE User='root' AND (Password='' OR Password IS NULL); -- 3. 查看当前连接失败的客户端IP SHOW PROCESSLIST; -- 4. 查看认证失败日志(如果启用了) SHOW GLOBAL VARIABLES LIKE 'log_error'; SELECT * FROM mysql.general_log WHERE argument LIKE '%root%'; CREATE USER 'seafile'@'localhost' IDENTIFIED BY '9f754db3-8cb7-42c2-999d-46cbe16f3a2d'; GRANT ALL PRIVILEGES ON seafile_db.* TO 'seafile'@'localhost'; GRANT ALL PRIVILEGES ON ccnet_db.* TO 'seafile'@'localhost'; GRANT ALL PRIVILEGES ON seahub_db.* TO 'seafile'@'localhost'; FLUSH PRIVILEGES;
seafile.nginx.conf
server {
listen 80;
client_max_body_size 10m;
location / {
proxy_pass http://127.0.0.1:8000/;
proxy_read_timeout 310s;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $server_name;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Connection "";
proxy_http_version 1.1;
add_header Access-Control-Allow-Origin *;
client_max_body_size 0;
access_log /shared/seafile/logs/seahub.access.log seafileformat;
error_log /shared/seafile/logs/seahub.error.log;
}
location /seafhttp {
rewrite ^/seafhttp(.*)$ $1 break;
proxy_pass http://127.0.0.1:8082;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 0;
proxy_read_timeout 36000s;
access_log /shared/seafile/logs/seafhttp.access.log seafileformat;
error_log /shared/seafile/logs/seafhttp.error.log;
}
location /seafdav {
rewrite ^/seafdav$ /seafdav/ permanent;
}
location /seafdav/ {
proxy_pass http://127.0.0.1:8080/seafdav/;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $server_name;
proxy_read_timeout 1200s;
client_max_body_size 0;
access_log /shared/seafile/logs/seafdav.access.log seafileformat;
error_log /shared/seafile/logs/seafdav.error.log;
}
location /:dir_browser {
# Logo of WebDAV
proxy_pass http://127.0.0.1:8080/:dir_browser;
}
location /media {
root /opt/seafile/seafile-server-latest/seahub;
}
location /sdoc-server/ {
if ($request_method = 'OPTIONS') {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods GET,POST,PUT,DELETE,OPTIONS;
add_header Access-Control-Allow-Headers "deviceType,token, authorization, content-type";
return 204;
}
proxy_pass http://seadoc:80/;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $server_name;
proxy_set_header X-Forwarded-Proto $scheme;
client_max_body_size 100m;
access_log /var/log/nginx/seadoc.access.log seafileformat;
error_log /var/log/nginx/seadoc.error.log;
}
location /socket.io {
proxy_pass http://seadoc:80;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_redirect off;
proxy_buffers 8 32k;
proxy_buffer_size 64k;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
}
}
调整原有配置文件
seafile.conf
删除该文件中数据库和缓存组件相关的配置,最终保留的内容如下
[fileserver] port = 8082
seahub_settings.py
删除该文件中重复的内容,最终保留内容如下
# -*- coding: utf-8 -*- CSRF_TRUSTED_ORIGINS = ["http://192.168.77.102:8000"] EMAIL_USE_SSL = True EMAIL_HOST = 'smtp.139.com' EMAIL_HOST_USER = '@139.com' EMAIL_HOST_PASSWORD = '' EMAIL_PORT = '465' DEFAULT_FROM_EMAIL = EMAIL_HOST_USER SERVER_EMAIL = EMAIL_HOST_USER COMPRESS_CACHE_BACKEND = 'locmem' TIME_ZONE = 'Asia/Shanghai'
- 无标签