怎样用 Docker 部署 Seafile 服务器来托管你自己的文件同步和共享解决方案

运维
Seafile 是一个自托管文件同步程序,采用客户端/服务器模式,即你有笔记本、手机等多个设备,能够连接到一个中心服务器。Seafile 只专注于文件同步、共享及与之相关的事情,仅此而已。但正因为如此,它最终做的非常好。

首先,什么是 Seafile ?

Seafile 是一个自托管文件同步程序,采用客户端/服务器模式,即你有笔记本、手机等多个设备,能够连接到一个中心服务器。

不像类似 Nextcloud 或 ownCloud 这些更流行的替代品一样,Seafile 试图遵循 “只做一件事,但是要做好” 的理念。同样,Seafile 没有内置额外的类似联系人或者日历聚合的功能。

相反,Seafile 只专注于文件同步、共享及与之相关的事情,仅此而已。但正因为如此,它最终做的非常好。

使用 Docker 和 NGINX 部署 Seafile 服务器


高级教程

我们的许多教程都是针对初学者的。这篇则不然,它是为那些经常鼓捣 DIY 项目和喜欢自托管的高级用户设计的。这个教程假定你可以熟练的使用命令行,而且你至少对我们将要使用的程序有一定的了解。


虽然整个过程完全可以不使用 NGINX ,但是使用 NGINX 更加容易配置,而且在将来更加容易的自托管更多的服务。

如果你想完全使用 Docker 环境,你也可以 ​​在 Docker 内部设置 NGINX​​ ,但是它这会使事情变得更加复杂,并且不能够带来太多好处。同样,在本教程里也不会涉及这些。

安装设置 NGINX

在这个教程中,我会使用 Ubuntu,因此会使用 ​​apt​​​ 来安装软件包。如果你使用 Fedora 或者一些其他非 Debian 发行版,请使用你的发行版的 包管理器。

NGINX 既是一个网页浏览器,又是一个代理服务器。它将起到 Seafile 服务器和互联网之间网络连接的作用,同时也使一些任务更容易处理。

要安装 NGINX ,使用以下命令:

sudo apt install nginx

如果你想使用 HTTPS(也就是浏览器中的小挂锁),你需要安装 ​​Certbot​​:

sudo apt install certbot python3-certbot-nginx

下一步,你需要设置 NGINX 来连接我们之后将要设置的 Seafile 实例。

首先,运行以下命令:

sudo nano /etc/nginx/sites-available/seafile.conf

键入下方的文本到文件中:

server {
server_name localhost;
location / {
proxy_pass http://localhost:8080;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}

重要: 将 ​​server_name​​​ 一行的 ​​localhost​​​ 替换为你要访问你的服务器的地址(比如 ​​seafile.example.com​​​ 或者 ​​192.168.0.0​​)。不确定要输入什么吗?


  • 如果你只是为了测试,使用 ​​localhost​​ 。这个设置将 只允许你从你的电脑访问服务器 ,仅此而已。
  • 如果你想通过你的本地 Wi-Fi 连接使用 Seafile(与你在同一 Wi-Fi 网络上),你应该键入 ​​你的计算机 IP 地址​​​。你也可以考虑 ​​设置一个静态 IP 地址​​,尽管这不是必须的。
  • 如果你有一个公网 IP 地址,你知道它指向你的系统,就使用它。
  • 如果你有一个域名(比如 ​​example.com​​​、​​example.org​​)和公网 IP 地址,更改你的 DNS 设置,将域名指向你的系统的 IP 地址。这也需要将公网 IP 指向你的系统。

现在你需要复制配置文件到 NGINX 的查找目录中,然后重启 NGINX :

sudo ln -s /etc/nginx/sites-available/seafile.conf /etc/nginx/sites-enabled/seafile.conf
sudo systemctl restart nginx

如果你要安装 Cerbot,你也需要运行以下命令来设置 HTTPS :

sudo certbot

如果要重定向 HTTP 流量 到 HTTPS ,选择 ​​2​​ 。

现在可以来确认我们目前设置的一切都是否正常工作。如果你访问你的站点,你应该看到一个屏幕上写着 ​​502 Bad Gateway​​ 字样。

安装 Docker 和 Docker Compose

现在要进入有趣的部分了!

首先,你需要安装 Docker​ 和 Docker Compose​ 。Docker Compose 需要利用 ​​docker-compose.yml​​​ 文件,这将使管理多个 Docker 容器 的 Seafile 需求变得更加容易。

Docker 和 Docker Compose 可以用以下的命令来安装:

sudo apt install docker.io docker-compose

检查 Docker 是否安装并运行,运行以下命令:

sudo docker run --rm hello-world

如果你完全安装成功,你应该在终端能看到这几行文字:

如果你想避免在 ​​docker​​​ 命令的开始添加 ​​sudo​​​ 的话,你可以运行以下的命令将你自己添加到 ​​docker​​ 组:

sudo groupadd docker
sudo usermod -aG docker $USER

这个教程的其余部分假定你已经运行了以上两个命令。如果你没有运行,在所有 ​​docker​​​ 或 ​​docker-compose​​​ 的命令都添加 ​​sudo​​ 。

安装 Seafile 服务器

这部分比之前部分明显容易的多。你所需要做的是输入一些文本到文件,然后运行一些命令。

打开一个终端,然后创建一个 Seafile 服务器用来储存内容的目录,并进入目录中:

mkdir ~/seafile-server && cd ~/seafile-server

转到你创建的目录然后运行以下命令:

nano docker-compose.yml

下一步,在弹出的窗口中键入以下文本内容:

version: '2.0'
services:
db:
image: mariadb
container_name: seafile-mysql
environment:
- MYSQL_ROOT_PASSWORD=password
- MYSQL_LOG_CONSOLE=true
volumes:
- ./data/mariadb:/var/lib/mysql
networks:
- seafile-net

memcached:
image: memcached
container_name: seafile-memcached
entrypoint: memcached -m 256
networks:
- seafile-net

seafile:
image: seafileltd/seafile-mc
container_name: seafile
ports:
- "8080:80"
volumes:
- ./data/app:/shared
environment:
- DB_HOST=db
- DB_ROOT_PASSWD=password
- TIME_ZONE=Etc/UTC
- SEAFILE_ADMIN_EMAIL=me@example.com
- SEAFILE_ADMIN_PASSWORD=password
- SEAFILE_SERVER_LETSENCRYPT=false
- SEAFILE_SERVER_HOSTNAME=docs.seafile.com
depends_on:
- db
- memcached
networks:
- seafile-net

networks:
seafile-net:


在保存文件之前,一些参数需要更改:


  • ​MYSQL_ROOT_PASSWORD​​​:更换强壮的密码,你不必记住它,所以不要尝试挑选简单的密码。如果你需要帮助生成一个,请使用 ​​密码生成器​​​ 。我建议使用 20 位字符长度并且避免使用任何的特殊字符(​​!@#$%^&*​​ 等符号)。
  • ​DB_ROOT_PASSWD​​​:更改你为 ​​MYSQL_ROOT_PASSWORD​​ 设置的值 。
  • ​SEAFILE_ADMIN_EMAIL​​:设置管理员帐户的电子邮件地址。
  • ​SEAFILE_ADMIN_PASSWORD​​​:设置管理员帐户密码。避免与​​MYSQL_ROOT_PASSWORD​​​ 或者 ​​DB_ROOT_PASSWD​​ 密码相同。
  • ​SEAFILE_SERVER_HOSTNAME​​:在 NGINX 配置中设置 Seafile 的服务器主机名。

完成之后,你可以运行 ​​docker-compose​​ 整个运行起来:

docker-compose up -d

可能需要花一到两分钟,取决于你的网速,因为需要拉下几个 Seafile 需要运行的几个容器。

完成以后,还需要几分钟来完成。你也可以通过以下命令来检查运行状态:

docker logs seafile

当完成了,你将会看到如下输出:

下一步,你只需要在你的浏览器里键入你设置的 ​​SEAFILE_SERVER_HOSTNAME​​ 的地址,然后你应该看到登录屏幕的页面。

就这样!现在一切功能齐全,准备用客户端来使用。

安装 Seafile 客户端

Seafile 移动客户端在 ​​Google Play​​​、​​F-Droid​​​ 和 ​​苹果商店​​​ 都是可用的。Seafile 也有 Linux、Windows 和 Mac 桌面客户端可用,可在 ​​此处​​ 找到。

通过 ​​seafile-gui​​ 软件包,可以在 Ubuntu 系统轻松获得 Seafile :

sudo apt install seafile-gui

通过 ​​seafile-client​​ 软件包 Seafile 也包含在 Arch 用户的 AUR 包管理器中。

结语

请尽情探索客户端及其所能提供的一切。我将在未来的一篇文章中详细阐述 Seafile 客户端的所有功能。(敬请期待 😃)

总的来说,如果有什么错误,或者你有什么问题,请在下方评论 – 我会尽我所能回应。

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2010-08-26 10:42:29

ADSL ModemDHCP服务器

2011-01-21 14:52:37

Sendmail

2009-02-06 11:18:00

代理服务器SuperProxyADSL

2010-05-21 18:03:19

IIS服务器

2009-12-11 10:27:07

APC

2018-07-25 14:50:41

服务器虚拟化方案

2010-08-23 16:13:11

DHCP服务器

2009-12-31 14:10:23

2018-08-21 09:03:00

SQLServer服务器

2009-11-26 17:03:24

Open Suse打印

2014-08-12 10:42:59

邮件服务器解决方案

2010-03-24 17:10:10

Nginx Web服务

2010-09-27 16:23:28

APC

2014-09-10 09:58:39

U-Mail邮件系统

2010-09-30 15:31:04

网络安全解决方案

2010-08-03 14:58:38

APC

2009-11-30 15:36:35

阿尔法路由器v3

2010-11-08 14:59:44

SQL Server无

2019-11-08 15:10:59

BashBash编程Linux

2009-10-16 09:54:14

服务器网络安全解决方案
点赞
收藏

51CTO技术栈公众号