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

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

介绍

有许多程序可以在不同计算机之间同步文件。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 账户或其他必要的用户账户来执行所需的操作。


目录
相关文章
|
2月前
|
并行计算 PyTorch TensorFlow
Ubuntu安装笔记(一):安装显卡驱动、cuda/cudnn、Anaconda、Pytorch、Tensorflow、Opencv、Visdom、FFMPEG、卸载一些不必要的预装软件
这篇文章是关于如何在Ubuntu操作系统上安装显卡驱动、CUDA、CUDNN、Anaconda、PyTorch、TensorFlow、OpenCV、FFMPEG以及卸载不必要的预装软件的详细指南。
5011 3
|
6天前
|
Ubuntu Linux Docker
Ubuntu22.04上Docker的安装
通过以上详细的安装步骤和命令,您可以在Ubuntu 22.04系统上顺利安装
77 11
|
1月前
|
Ubuntu 开发工具 git
Ubuntu安装homebrew的完整教程
本文介绍了如何在没有公网的情况下安装 Homebrew。首先访问 Homebrew 官网,然后通过阿里云的镜像克隆安装脚本,并创建普通用户进行安装。接着修改 `install.sh` 文件指向国内镜像,执行安装命令。最后配置环境变量并更换 Homebrew 源为国内镜像,确保安装顺利。
260 50
|
29天前
|
Ubuntu
ubuntu和debian 的安装包dpkg管理命令对安装包进行安装,查询,卸载
Ubuntu dpkg 软件包管理命令概览:安装、卸载、查看和配置软件包。包括解决依赖、强制卸载、列出及过滤已安装包、查看包详情等操作。
55 10
|
1月前
|
Ubuntu API 开发工具
PSOPT在Ubuntu22.04下的安装
通过上述步骤,可以在Ubuntu 22.04下成功安装并配置PSOPT。PSOPT是一个功能强大的工具,适用于解决各种最优控制问题。确保在安装前满足系统要求,并仔细按照步骤操作,可以避免大多数常见问题。通过MATLAB与PSOPT的结合,您可以更高效地处理复杂的控制问题,并获得准确的解决方案。
31 5
|
1月前
|
Ubuntu 网络协议 关系型数据库
超聚变服务器2288H V6使用 iBMC 安装 Ubuntu Server 24.04 LTS及后续系统配置
【11月更文挑战第15天】本文档详细介绍了如何使用iBMC在超聚变服务器2288H V6上安装Ubuntu Server 24.04 LTS,包括连接iBMC管理口、登录iBMC管理界面、配置RAID、安装系统以及后续系统配置等步骤。
112 4
|
2月前
|
Ubuntu Linux 测试技术
Linux系统之Ubuntu安装cockpit管理工具
【10月更文挑战第13天】Linux系统之Ubuntu安装cockpit管理工具
221 4
Linux系统之Ubuntu安装cockpit管理工具
|
1月前
|
Ubuntu Shell 开发工具
ubuntu/debian shell 脚本自动配置 gitea git 仓库
这是一个自动配置 Gitea Git 仓库的 Shell 脚本,支持 Ubuntu 20+ 和 Debian 12+ 系统。脚本会创建必要的目录、下载并安装 Gitea,创建 Gitea 用户和服务,确保 Gitea 在系统启动时自动运行。用户可以选择从官方或小绿叶技术博客下载安装包。
55 2
|
2月前
|
监控 Ubuntu Linux
视频监控笔记(五):Ubuntu和windows时区同步问题-your clock is behind
这篇文章介绍了如何在Ubuntu和Windows系统中通过设置相同的时区并使用ntp服务来解决时间同步问题。
80 4
视频监控笔记(五):Ubuntu和windows时区同步问题-your clock is behind
|
2月前
|
Ubuntu 应用服务中间件 nginx
Ubuntu安装笔记(三):ffmpeg(3.2.16)源码编译opencv(3.4.0)
本文是关于Ubuntu系统中使用ffmpeg 3.2.16源码编译OpenCV 3.4.0的安装笔记,包括安装ffmpeg、编译OpenCV、卸载OpenCV以及常见报错处理。
213 2
Ubuntu安装笔记(三):ffmpeg(3.2.16)源码编译opencv(3.4.0)