在CentOS下利用Docker一键安装seafile

时间:2024-04-15 07:46:11

https://cloud.seafile.com/published/seafile-manual-cn/docker/pro-edition/%E7%94%A8Docker%E9%83%A8%E7%BD%B2Seafile.md

官方教程写的不够详细,特记录一下。

1. 安装docker及docker-compose

具体见本博客相关文章。

2.下载并修改一键安装脚本

https://docs.seafile.com/d/cb1d3f97106847abbf31/files/?p=/docker/pro-edition/docker-compose.yml

 version: '2.0'
services:
db:
image: mariadb:10.1
container_name: seafile-mysql
environment:
- MYSQL_ROOT_PASSWORD=db_dev # MySQL root 用户的密码 Requested, set the root's password of MySQL service.
- MYSQL_LOG_CONSOLE=true
volumes:
- /opt/seafile-mysql/db:/var/lib/mysql # 持久化存储 MySQL 数据的 volumes 目录 Requested, specifies the path to MySQL data persistent store.
networks:
- seafile-net memcached:
image: memcached:1.5.
container_name: seafile-memcached
entrypoint: memcached -m
networks:
- seafile-net elasticsearch:
image: seafileltd/elasticsearch-with-ik:5.6.
container_name: seafile-elasticsearch
environment:
- discovery.type=single-node
- bootstrap.memory_lock=true
- "ES_JAVA_OPTS=-Xms1g -Xmx1g"
ulimits:
memlock:
soft: -
hard: -
mem_limit: 2g
volumes:
- /opt/seafile-elasticsearch/data:/usr/share/elasticsearch/data # 持久化存储 Elasticsearch 索引数据的 volumes 目录Requested, specifies the path to Elasticsearch data persistent store.
networks:
- seafile-net seafile:
image: docker.seafile.top/seafileltd/seafile-pro-mc:latest
container_name: seafile
ports:
- "80:80"
# - "443:443" # If https is enabled, cancel the comment.
volumes:
- /opt/seafile-data:/shared # 持久化存储 Seafile 数据的 volumes 目录 Requested, specifies the path to Seafile data persistent store.
environment:
- DB_HOST=db
- DB_ROOT_PASSWD=db_dev # Requested, the value shuold be root's password of MySQL service.
# - TIME_ZONE=Asia/Shanghai # Optional, default is UTC. Should be uncomment and set to your local time zone.
- SEAFILE_ADMIN_EMAIL=me@example.com # 管理员账号Specifies Seafile admin user, default is 'me@example.com'
- SEAFILE_ADMIN_PASSWORD=asecret # Specifies Seafile admin password, default is 'asecret'
- SEAFILE_SERVER_LETSENCRYPT=false # Whether to use https or not
- SEAFILE_SERVER_HOSTNAME=example.seafile.com # Specifies your host name if https is enabled
depends_on:
- db
- memcached
- elasticsearch
networks:
- seafile-net networks:
seafile-net:

根据您的实际环境修改该文件。尤其是以下几项配置:

  • MySQL root 用户的密码 (MYSQL_ROOT_PASSWORD and DB_ROOT_PASSWD)

  • 持久化存储 MySQL 数据的 volumes 目录 (volumes)

  • 持久化存储 Seafile 数据的 volumes 目录 (volumes)

  • 持久化存储 Elasticsearch 索引数据的 volumes 目录 (volumes)

3. 如果按照专业版的话

注册帐号,打开seafile的英文网页,去下载区,有如下信息

You can download pro editions from https://download.seafile.com/d/×××××××××/?p=/pro.

If you are deploying Seafile Pro with Docker, type docker login docker.seadrive.org, then input username seafile, password zj×××××dZ=u×××uWS.

必须有此帐号登录过程,不然第4步执行过程中会被拒绝。

4. 安装

在 docker-compose.yml文件所在的目下执行以下命令启动 Seafile 服务

docker-compose up -d

根据网速不同,需要等待些许时间,等容器首次启动时的初始化操作完成后,您就可以在浏览器*问http://seafile.example.com 来打开 Seafile 主页。

Seafile 目录结构

/shared

共享卷的挂载点,您可以选择在容器外部存储某些持久性信息.在这个项目中,我们会在外部保存各种日志文件和上传数据。 这使您可以轻松重建容器而不会丢失重要信息。

  • /shared/seafile: Seafile 服务的配置文件,日志文件以及数据文件

    • /shared/seafile/logs: Seafile 服务运行产生的日志文件目录。比如您可以在 /shared/seafile/logs/seafile.log 文件中看到 seaf-server 的日志

    • /shared/seafile/seafile-data: 如果您没有配置S3或者OSS等对象存储,那么用户上传的数据将会存放到该目录下。

  • /shared/logs: 日志目录

    • /shared/logs/var-log: 我们将容器内的/var/log链接到本目录。您可以在/shared/logs/var-log/nginx/中找到 nginx 的日志文件

  • /shared/ssl: 存放证书的目录,默认不存在

备份和恢复

目录结构

我们假设您的 seafile 数据卷路径是 /opt/seafile-data,并且您想将备份数据存放到 /opt/seafile-backup 目录下。

您可以创建一个类似以下 /opt/seafile-backup 的目录结构:

/opt/seafile-backup

---- databases/ 用来存放 MySQL 容器的备份数据

---- data/ 用来存放 Seafile 容器的备份数据

Text
HTML
CSS
Javascript
C
C++
C#
Java
Python
Sql
Swift

要备份的数据文件:

/opt/seafile-data/seafile/conf # configuration files

/opt/seafile-data/seafile/seafile-data # data of seafile

/opt/seafile-data/seafile/seahub-data # data of seahub

Text
HTML
CSS
Javascript
C
C++
C#
Java
Python
Sql
Swift

备份数据

步骤:

  1. 备份 MySQL 数据库数据;

  2. 备份 Seafile 数据目录;

  • 备份数据库:

    # 建议每次将数据库备份到一个单独的文件中。至少在一周内不要覆盖旧的数据库备份。

    cd /opt/seafile-backup/databases

    docker exec -it seafile-mysql mysqldump -uroot --opt ccnet_db > ccnet_db.sql

    docker exec -it seafile-mysql mysqldump -uroot --opt seafile_db > seafile_db.sql

    docker exec -it seafile-mysql mysqldump -uroot --opt seahub_db > seahub_db.sql

    Text
    HTML
    CSS
    Javascript
    C
    C++
    C#
    Java
    Python
    Sql
    Swift
  • 备份 Seafile 资料库数据:

    • 直接复制整个数据目录

      cp -R /opt/seafile-data/seafile /opt/seafile-backup/data/

      cd /opt/seafile-backup/data && rm -rf ccnet

      Text
      HTML
      CSS
      Javascript
      C
      C++
      C#
      Java
      Python
      Sql
      Swift
    • 使用 rsync 执行增量备份

      rsync -az /opt/seafile-data/seafile /opt/seafile-backup/data/

      cd /opt/seafile-backup/data && rm -rf ccnet

      Text
      HTML
      CSS
      Javascript
      C
      C++
      C#
      Java
      Python
      Sql
      Swift

恢复数据

  • 恢复数据库:

    docker cp /opt/seafile-backup/databases/ccnet_db.sql seafile-mysql:/tmp/ccnet_db.sql

    docker cp /opt/seafile-backup/databases/seafile_db.sql seafile-mysql:/tmp/seafile_db.sql

    docker cp /opt/seafile-backup/databases/seahub_db.sql seafile-mysql:/tmp/seahub_db.sql

    docker exec -it seafile-mysql /bin/sh -c "mysql -uroot ccnet_db < /tmp/ccnet_db.sql"

    docker exec -it seafile-mysql /bin/sh -c "mysql -uroot seafile_db < /tmp/seafile_db.sql"

    docker exec -it seafile-mysql /bin/sh -c "mysql -uroot seahub_db < /tmp/seahub_db.sql"

    Text
    HTML
    CSS
    Javascript
    C
    C++
    C#
    Java
    Python
    Sql
    Swift
  • 恢复 seafile 数据:

    cp -R /opt/seafile-backup/data/* /opt/seafile-data/seafile/