
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Seafile 是一款"下一代开源云存储",具备高级文件同步、隐私保护和团队协作功能。本Docker镜像基于JensErat/docker-seafile构建,提供Seafile运行环境,支持自动配置默认参数,容器启动时即可运行Seafile服务。
/opt/seafile永久卷,确保数据持久化需准备MySQL/MariaDB数据库(可使用容器或现有数据库)
启动MariaDB容器
bashdocker run -d --name="mariadb" guilhem30/mariadb
获取MariaDB root密码
bashdocker logs mariadb
Seafile可自动创建数据库或使用现有空数据库,必须提供至少监听接口的IP地址和用户/密码信息。未指定密码时将随机生成并记录在容器日志中。
方式1:自动创建数据库(需root权限)
提供数据库root用户和密码,可选择指定Seahub管理员***(默认使用***):
bashdocker run -d --name "myseafile" \ -p 10001:10001 -p 12001:12001 -p 8000:8000 -p 8082:8082 \ --link mariadb:mysql-container \ -e "CCNET_IP=192.168.0.100" -e "MYSQL_ROOT_USER=dataadmin" \ -e "MYSQL_ROOT_PASSWORD=rootpass" -e "SEAHUB_ADMIN_EMAIL=seafileadmin@yourdomain.com" \ guilhem30/seafile
方式2:使用现有数据库(无需root权限)
需提供数据库用户、密码及数据库名称(未指定则使用默认名称)。注意:数据库必须为空,否则Seafile会启动失败:
bashdocker run -d --name "myseafile" \ -p 10001:10001 -p 12001:12001 -p 8000:8000 -p 8082:8082 \ --link mariadb:mysql-container \ -e "CCNET_IP=192.168.0.100" -e "EXISTING_DB=true" -e "SEAHUB_ADMIN_EMAIL=seafileadmin@yourdomain.com" \ -e "MYSQL_USER=myseafileuser" -e "MYSQL_PASSWORD=myseafilepass" \ guilhem30/seafile
启动Nginx容器(挂载静态文件卷)
bashdocker run -d --name nginx -p 80:80 -p 443:443 -v /opt/seafile/nginx guilhem30/nginx
启动Seafile并关联Nginx卷
通过--volumes-from让Seafile创建Nginx配置文件、SSL证书并复制静态文件:
bashdocker run -d --name "myseafile" -e fcgi=true -e autonginx=true -e "CCNET_IP=myfiles.mydomain.com" \ -e "MYSQL_ROOT_USER=root" -e "MYSQL_ROOT_PASSWORD=rootpass" \ -e "SEAHUB_ADMIN_EMAIL=admin@yourdomain.com" -e "SEAFILE_IP=myseafile.seafile.dev.docker" \ -e "MYSQL_HOST=mydatabase.mariadb.dev.docker" --volumes-from nginx seafile
重启Nginx使配置生效
bashdocker restart nginx
所有环境变量及默认值:
| 环境变量 | 默认值 | 说明 |
|---|---|---|
| autostart | true | 是否自动启动Seafile服务 |
| autoconf | true | 是否自动配置Seafile |
| autonginx | false | 是否自动配置Nginx |
| fcgi | false | 是否启用FCGI模式 |
| CCNET_IP | - | CCNET监听IP地址(必填) |
| SEAFILE_IP | - | Seafile服务IP地址 |
| CCNET_PORT | *** | CCNET服务端口 |
| CCNET_NAME | my-seafile | CCNET实例名称 |
| SEAFILE_PORT | *** | Seafile服务端口 |
| FILESERVER_PORT | 8082 | 文件服务器端口 |
| EXISTING_DB | false | 是否使用现有数据库 |
| MYSQL_HOST | mysql-container | 数据库主机名 |
| MYSQL_PORT | 3306 | 数据库端口 |
| MYSQL_ROOT_USER | root | 数据库root用户名 |
| MYSQL_ROOT_PASSWORD | - | 数据库root密码 |
| MYSQL_USER | seafileuser | Seafile数据库用户名 |
| MYSQL_PASSWORD | 随机生成 | Seafile数据库密码 |
| SEAHUB_ADMIN_EMAIL | *** | Seahub管理员*** |
| SEAHUB_ADMIN_PASSWORD | 随机生成 | Seahub管理员密码 |
| CCNET_DB_NAME | ccnet-db | CCNET数据库名称 |
| SEAFILE_DB_NAME | seafile-db | Seafile数据库名称 |
| SEAHUB_DB_NAME | seahub-db | Seahub数据库名称 |
| SEAHUB_PORT | 8000 | Seahub web端口 |
| STATIC_FILES_DIR | /opt/seafile/nginx/ | 静态文件存储目录 |
Seafile目录存储在/opt/seafile永久卷中,更新时需:
docker pull guilhem30/seafilebashdocker run -d --name "myseafile2" \ -p 10001:10001 -p 12001:12001 -p 8000:8000 -p 8082:8082 \ --link mariadb:mysql-container \ -e "autoconf=false" \ --volumes-from myseafile \ guilhem30/seafile
bashdocker run -d --name "seafileUpdater" \ -p 10001:10001 -p 12001:12001 -p 8000:8000 -p 8082:8082 \ --link mariadb:mysql-container \ -e "autoconf=false" \ -e "autostart=false" \ --volumes-from myseafile \ guilhem30/seafile
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务
以下是 raghon1/seafile 相关的常用 Docker 镜像,适用于 不同场景 等不同场景: