如何在 Ubuntu 14.04 上安装和配置 Syncthing 来同步目录

avatar
作者
筋斗云
阅读量:0

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站

介绍

有许多程序可以在不同计算机之间同步文件。Syncthing 是一个引人注目的新选择,它跨平台、完全开源、非常灵活且易于使用。

在本指南中,我们将向您展示如何开始使用 Syncthing 在两个 Ubuntu 14.04 服务器实例之间同步数据。这将允许您根据配置的“监视”目录在这些服务器之间无缝同步文件。

先决条件和目标

要完成本指南,您需要访问两个 Ubuntu 14.04 服务器实例。

在本指南中,我们将称这些服务器为:

  • serverone
  • servertwo

这些将是平等的合作伙伴,因此没有主/次关系。您应该在每台服务器上配置一个常规用户帐户(您可以按照我们的 Ubuntu 14.04 初始服务器设置指南中的步骤 1-4 找出如何做)。

本指南中的常规用户帐户将被称为 demouser,但您可以使用任何用户名。这不必与您的常规非根帐户分开。

我们将在这两台机器上安装和配置 Syncthing,以便可以在它们之间共享文件。完成本指南中概述的程序后,您应该有两台服务器,每台服务器都有一个目录,可以将更改镜像到另一台计算机。

我们将安装 Syncthing 作为系统级应用程序,并创建一个 Upstart 脚本。这将允许我们的 Syncthing 实例在启动时启动并正确重启,而不是像默认情况下那样每次生成新实例。

初始下载和安装

我们开始的第一件事是在每台服务器上下载 Syncthing 二进制文件。

要找到最新打包的版本,您可以转到 GitHub 上的发布页面。在页面底部有每种操作系统类型的按钮。

!Syncthing release page

如果您的 Linux 系统是 32 位的,请选择以 “syncthing-linux-386-...” 开头的选项。如果您使用的服务器是 64 位的,请选择标记为 “syncthing-linux-amd64-...” 的选项。不要将文件下载到本地计算机。而是右键单击适当的文件,然后选择“复制链接地址”或您有的类似选项。

我们将使用每台服务器上的 wget 命令下载这些文件。在您的服务器上,键入 wget,然后粘贴您复制的链接。版本和系统架构可能对您有所不同:

cd ~ wget https://github.com/calmh/syncthing/releases/download/v0.8.15/syncthing-linux-amd64-v0.8.15.tar.gz 

现在,我们可以通过键入以下命令解压 tarball:

tar xzvf syncthing*.tar.gz 

进入新创建的目录:

cd syncthing* 

在这里,我们有一个名为 syncthing 的可执行文件,我们可以使用它来启动服务。我们希望将其复制到我们的 PATH 中的位置,以便我们可以像普通应用程序一样调用它。

通过以下带有 sudo 权限的命令执行此操作:

sudo cp syncthing /usr/local/bin 

现在,我们可以返回到我们的主目录,并安全地删除所有剩余的 Syncthing 文件和目录。

cd ~ rm -rf syncthing* 

在您的两台服务器上完成上述所有步骤。

应用程序现在已安装,但在准备好使用之前,我们还需要做一些事情。

更改 GUI 选项以允许远程查看

默认情况下,Syncthing Web 界面仅可供来自同一计算机的连接使用。由于我们正在使用远程服务器,这将无法满足我们的需求。

为了解决这个问题,我们需要编辑 Syncthing 配置文件中的一行。但是,配置文件尚未创建。

要自动创建文件,我们可以简要启动服务。键入 syncthing 命令以启动此过程:

syncthing 

syncthing 进程不是守护进程,这意味着它在当前 shell 会话中运行(我们将通过实施 Upstart 脚本来解决这个问题)。它将启动进程并创建一些必要的文件。

片刻之后,您将看到有关您的节点 ID 的信息消息,看起来像这样:

[2EQK3] 15:47:15 OK: Ready to synchronize default (read-write) [2EQK3] 15:47:15 INFO: Node 2EQK3ZR77PTBQGM44KE7VQIQG7ICXJDEOK34TO3SWOVMUL4QFBHA is "server1" at [dynamic] 

当您看到这个时,这意味着进程已正确初始化。现在,通过键入以下命令停止进程:

CTRL-C 

这将停止进程并使我们再次控制终端。

现在,我们可以编辑创建的配置文件。在文本编辑器中打开文件:

nano ~/.config/syncthing/config.xml 

查找处理 GUI 的部分。它应该看起来像这样:

<gui enabled="true" tls="false">     <address>127.0.0.1:8080</address> </gui> 

我们需要做的唯一更改是将本地主机地址(127.0.0.1)替换为 0.0.0.0,它代表所有网络接口。完成后,此部分将如下所示:

<gui enabled="true" tls="false">     <address>0.0.0.0:8080</address> </gui> 

完成配置后保存并关闭文件。稍后我们将通过 Web 界面进行更广泛的配置。

再次在您要配置的两台服务器上完成这些程序。

创建 Upstart 脚本以处理服务状态

接下来,我们将实现一个 Upstart 脚本来管理我们的进程。这将允许我们在服务器启动时自动启动 Syncthing 进程。它还将让我们将其作为一个服务运行,而不会控制我们的会话。

我们将使用的 Upstart 脚本取自 Syncthing 讨论板上的一个帖子。通过输入以下命令,使用 root 权限创建并打开 Upstart 文件编辑器:

sudo nano /etc/init/syncthing.conf 

在文件中,我们将使用以下行来控制我们的 Upstart 进程:

description "Syncthing P2P sync service"  start on (local-filesystems and net-device-up IFACE!=lo) stop on runlevel [!2345]  env STNORESTART=yes env HOME=/home/demouser setuid "demouser" setgid "demouser"  exec /usr/local/bin/syncthing  respawn 

让我们来解释一下这意味着什么。

我们首先给出了服务的一般描述。接下来,我们定义服务应该何时启动和停止。在这里,我们告诉系统应在文件系统和非本地网络接口启动后启动它。每当系统离开正常运行级别时,它将被停止。

接下来,我们将设置一个环境变量,告诉 Syncthing 不要使用自己的机制重新启动。这是因为它实际上每次都会生成一个新进程,而不清理旧进程。为了避免这种情况,我们将稍后在这个 Upstart 脚本中实现重新启动的能力。

接下来的环境变量设置了 Syncthing 将要使用的主目录。这将用于查找正确的配置文件,并在 GUI 中预填字段。我们还使用 setuidsetgid 参数分别指定用户和组。将这三个值修改为指向您用户的信息。

接下来,我们设置要执行的实际命令的路径。最后,我们使用 respawn 告诉 Upstart 如果进程被意外停止,则自动重新启动该进程。这用于当 Syncthing 进程尝试在内部重新启动自身时,自动重新启动进程(清理)。

完成后,保存并关闭文件。

现在,您可以通过输入以下命令来启动服务:

sudo initctl start syncthing 

在两台服务器上完成上述步骤。

在 Web UI 中设置安全性

我们终于准备好通过 Web 用户界面配置我们的实例。

通过访问它们的公共 IP 地址和端口 8080,登录到每台服务器的 Syncthing 界面:

http://server1_public_IP:8080 http://server2_public_IP:8080 

您将看到主 Syncthing 屏幕:

!Syncthing main screen

我们需要做的第一件事是为我们的界面添加一些安全性。转到右上角的“编辑”菜单,然后点击“设置”选项:

!Syncthing settings

在右侧,我们需要为 Web 界面设置用户名和密码。我们还希望为我们的会话启用 TLS 加密,以便我们的流量在传输过程中无法被拦截,勾选“HTTPS”框:

!Syncthing security

完成后,点击底部的“保存”按钮。

您将看到一个提示消息,提示您重新启动服务以使更改生效:

!Syncthing restart

点击“重新启动”按钮。

您可能需要刷新页面以正确重新加载更改。这样做时,您很可能会遇到一个 SSL 警告,看起来像这样:

!Syncthing SSL warning

这只是让您知道签署 SSL 证书的实体不在您的浏览器的受信任证书颁发机构列表中。这是预期的,因为证书是自签名的。点击“仍然继续”是安全的。

然后,您将收到一个要求输入您配置的用户名和密码的身份验证提示:

!Syncthing username and password

填写适当的值并登录。您的界面现在对外部流量更加安全。

在两台服务器上完成这些步骤。

连接两台服务器并共享目录

为了共享内容,Syncthing 要求连接的两端将另一台服务器添加到其节点列表中。然后,双方还必须添加一个要同步的存储库(目录)。

要添加一个节点,您将需要伴随节点的 ID。您可以通过转到右上角的“编辑”菜单,然后选择“显示 ID”选项来获取此 ID。

这将显示一个包含长 ID 的覆盖层,您可以复制其中的 ID。它还会给您一个 QR 码,以防您正在配置智能手机应用程序。复制第一个节点的 ID。

!Syncthing copy ID

在第二台服务器上,点击“编辑”菜单,然后选择“添加节点”。

将出现一个覆盖层,其中包含必须配置以添加另一台服务器的字段。在“节点 ID”字段中,粘贴从第一台服务器复制的 ID。在“节点名称”字段中,选择您希望用于另一台服务器的任何描述性名称。将“地址”保留为“动态”:

!Syncthing add node

完成后,点击“保存”以添加新节点。

以相反的顺序运行相同的过程,以便两台服务器在其配置中都有相反的服务器。暂时忽略重新启动服务的任何请求,因为我们将首先进行一些其他更改。

在 Web 界面中,您连接到的节点显示在右侧。您共享的存储库显示在左侧。默认情况下,将在您的主目录中创建一个名为 Sync 的文件夹作为默认存储库。如果菜单被压缩了,请单击名称以展开列表:

!Syncthing default repo

点击“编辑”按钮以配置存储库。在底部,您将有选项将此存储库与您配置的任何节点共享。选中与另一节点相关联的框,然后点击“保存”按钮:

!Syncthing share with node

现在,您可以点击“重新启动”按钮以实施您的更改:

!Syncthing restart

现在,~/Sync 目录中所做的任何更改都将镜像到另一台服务器。默认情况下,这将每 60 秒同步一次,但可以在“设置”菜单中更改。

您可以通过从“编辑”菜单中选择“添加存储库”选项来添加希望镜像的其他目录。对于目录关联,每台服务器上的“存储库 ID”必须相同。

结论

到这一步,你应该已经连接了两台服务器,并同步了一个目录的内容。你可以通过添加额外的仓库(目录),或者添加额外的节点来扩展这个功能。

如果你计划将系统文件同步到普通用户无法写入的目录,你可能需要修改 Upstart 文件,以使用 root 账户或其他必要的用户账户来执行所需的操作。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!