如何在 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 账户或其他必要的用户账户来执行所需的操作。


目录
相关文章
|
6月前
|
人工智能 Ubuntu 前端开发
Dify部署全栈指南:AI从Ubuntu配置到HTTPS自动化的10倍秘籍
本文档介绍如何部署Dify后端服务及前端界面,涵盖系统环境要求、依赖安装、代码拉取、环境变量配置、服务启动、数据库管理及常见问题解决方案,适用于开发与生产环境部署。
1383 1
|
5月前
|
Ubuntu 安全 iOS开发
Nessus Professional 10.10 Auto Installer for Ubuntu 24.04 - Nessus 自动化安装程序
Nessus Professional 10.10 Auto Installer for Ubuntu 24.04 - Nessus 自动化安装程序
626 5
|
5月前
|
NoSQL Ubuntu MongoDB
在Ubuntu 22.04上安装MongoDB 6.0的步骤
这些步骤应该可以在Ubuntu 22.04系统上安装MongoDB 6.0。安装过程中,如果遇到任何问题,可以查阅MongoDB的官方文档或者Ubuntu的相关帮助文档,这些资源通常提供了解决特定问题的详细指导。
585 18
|
6月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
372 18
|
6月前
|
Ubuntu 安全 关系型数据库
安装MariaDB服务器流程介绍在Ubuntu 22.04系统上
至此, 您已经在 Ubuntu 22.04 系统上成功地完成了 MariadB 的标准部署流程,并且对其进行基础但重要地初步配置加固工作。通过以上简洁明快且实用性强大地操作流程, 您现在拥有一个待定制与使用地强大 SQL 数据库管理系统。
402 18
|
6月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
597 17
|
6月前
|
Ubuntu 安全 关系型数据库
安装MariaDB服务器流程介绍在Ubuntu 22.04系统上
至此, 您已经在 Ubuntu 22.04 系统上成功地完成了 MariadB 的标准部署流程,并且对其进行基础但重要地初步配置加固工作。通过以上简洁明快且实用性强大地操作流程, 您现在拥有一个待定制与使用地强大 SQL 数据库管理系统。
461 15
|
6月前
|
存储 Ubuntu iOS开发
在Ubuntu 22.04系统上安装libimobiledevice的步骤
为了获取更多功能或者解决可能出现问题,请参考官方文档或者社区提供支持。
566 14
|
6月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
666 7
|
7月前
|
缓存 监控 Ubuntu
在Ubuntu 16.04上配置GitLab Runner以激活GitLab CI/CD流程
完成以上步骤后,每当代码被推送到远端仓库中相对应分支上时,GitLb CI / CD 流水线就会自动触发,并由之前注册好了 GitLb runner 的机器去完成定义好了 ` .gitlabcicd.yml ` 文件里面定义好各种任务(如编译测试部署等).
385 13