前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。
介绍
有许多程序可以在不同计算机之间同步文件。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 文件编辑器:
sudonano /etc/init/syncthing.conf
在文件中,我们将使用以下行来控制我们的 Upstart 进程:
description "Syncthing P2P sync service"
start on (local-filesystems and net-device-up IFACE!=lo)
stop on runlevel [!2345]envSTNORESTART=yes
envHOME=/home/demouser
setuid "demouser"
setgid "demouser"exec /usr/local/bin/syncthing
respawn
让我们来解释一下这意味着什么。
我们首先给出了服务的一般描述。接下来,我们定义服务应该何时启动和停止。在这里,我们告诉系统应在文件系统和非本地网络接口启动后启动它。每当系统离开正常运行级别时,它将被停止。
接下来,我们将设置一个环境变量,告诉 Syncthing 不要使用自己的机制重新启动。这是因为它实际上每次都会生成一个新进程,而不清理旧进程。为了避免这种情况,我们将稍后在这个 Upstart 脚本中实现重新启动的能力。
接下来的环境变量设置了 Syncthing 将要使用的主目录。这将用于查找正确的配置文件,并在 GUI 中预填字段。我们还使用
setuid
和
setgid
参数分别指定用户和组。将这三个值修改为指向您用户的信息。
接下来,我们设置要执行的实际命令的路径。最后,我们使用
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
账户或其他必要的用户账户来执行所需的操作。
版权归原作者 白如意i 所有, 如有侵权,请联系我们删除。