Docker 搭建开源文件同步工具 Syncthing

简介

Syncthing 是一个开源的文件同步工具,可以在不同设备之间同步文件和文件夹。它使用了点对点的方式进行同步,如果点对点连接成功则不需要通过云服务器中转,因此更加安全和私密。

Syncthing 就好比是 Onedrive,当你指定了同步哪些文件夹,它会定时检测文件夹下的文件是否有增加减少或者修改,如果有修改那么将会点对点同步到另外的客户端,当然这是你在一边配置了分享,另一边配置了同步的情况下。当然,它可以是单向同步,也可以是双向同步的,这取决于你的配置。

在正常情况下安装,你是不需要自己搭建发现服务器和中继服务器的,因为默认使用官方的服务器。,中继服务器(Relay Server)则是一种用于帮助设备之间传输数据的服务器。

但是考虑到玩意文件比较多或者文件比较大,文件同步的实时性要求又比较高,使用自己的服务器将是一个比较好的选择,所以接下来也有相关的教程,不需要则可以忽略。

搭建

1. 客户端搭建

docker run -d \
--name syncthing \
-p 8384:8384 \
-p 22000:22000/tcp \
-p 22000:22000/udp \
-p 21027:21027/udp \
-v /home/docker/sync/:/var/syncthing \
syncthing/syncthing:latest

注意这里需要映射文件夹,看你自己情况,如果你已有需要同步的文件夹,请将该文件夹映射到容器内,否则 syncthing 将无法进行同步。

首次进入会警告设置管理员账号和密码,不设置警告不会消失。

20230628151442.png

点击设置的图形用户界面设置即可。

20230628151615.png

同步相关的设置下面再讲,先讲如何搭建发现服务器和中继服务器,如果你不需要可以直接跳过。

2. 发现服务器搭建

发现服务器(Discovery Server)是一种用于帮助设备之间发现彼此并建立连接的服务器。当设备加入 Syncthing 网络时,它会向发现服务器发送请求,以获取其他设备的信息。发现服务器会将设备的信息存储在一个公共数据库中,其他设备在需要连接到新设备时可以通过发现服务器获取到该设备的信息。发现服务器的作用类似于一个中介,帮助设备之间建立连接,但它并不参与实际的文件同步过程。

搭建需要公网,在服务器运行如下命令。

docker run -d \
--name syncthing-discosrv \
-p 8443:8443 \
-v /home/docker/syncthing/discosrv:/var/stdiscosrv \
syncthing/discosrv \
-debug -listen=":8443"

使用 docker logs -f syncthing-discosrv 命令查看日志,获取 device ID。

20230628153211.png

打开客户端,点击设置,选择连接,输入:

https://公网IP:8443/?id=设备id

20230628153625.png

保存后,点击设备发现状态会显示如下。

20230628205238.png

3. 中继服务器搭建

中继服务器(Relay Server)则是一种用于帮助设备之间传输数据的服务器。在某些情况下,设备之间直接进行数据传输可能会受到网络环境的限制,例如设备处于不同的局域网中或者网络防火墙的限制。这时,设备可以通过中继服务器进行数据传输。设备将数据上传到中继服务器,然后其他设备从中继服务器下载数据。中继服务器的作用是帮助设备之间绕过网络限制,实现数据的传输。需要注意的是,中继服务器只在必要时才被使用,大部分情况下设备之间直接进行数据传输。

搭建需要公网,在服务器运行如下命令。

docker run -d \
--name syncthing-relaysrv \
-p 22067:22067 \
-v /home/docker/syncthing/strelaysrv:/var/strelaysrv \
syncthing/relaysrv:latest \
-debug -pools="" -listen=":22067"

使用 docker logs -f syncthing-relaysrv 命令查看日志,获取 Url。

20230628153744.png

将 ip 替换为你自己的公网 ip。

relay://公网IP:22067/?id=设备id

20230628165844.png

保存后,点击侦听程序显示如下内容。

20230628205406.png

到这里搭建发现服务器和中继服务器就完成了,当然,新加入的客户端也要进行同样的操作。

使用

1. 添加设备

当你有两个设备时,如果不进行添加设备是无法进行同步操作的,这个添加设备也相当于是一个授权,是一个相互的操作。

首先查看一台机器的识别码。

20230628210417.png

复制识别码后,在另一台客户端点击添加远程设备进行添加。

20230628210515.png

这里同时可以备注设备名,共享和高级可以等会再设置。

20230628210725.png

然后再回到刚刚那台客户端,同意添加设备。

20230628210953.png

然后就可以在远程设备处看见连接成功了,并可以看见当前是什么连接类型。

20230628211128.png

2. 文件同步

先在测试1机器上添加文件夹 /var/syncthing/test1

20230628221001.png

此时测试1的机器上,/var/syncthing/test1 目录有4个文件,但此时文件夹还是非共享的。

20230628221221.png

点击选择,设置共享给测试2机器。

20230628221311.png

测试2机器将收到共享文件夹的确认信息。

20230628221407.png

我这里将内容同步到 /var/syncthing/tmp 文件夹。

20230628221455.png

等待一会,发现文件已经同步好了。

20230628221542.png

原创文章,作者:mantou,如若转载,请注明出处:https://v2ez.com/930.html

(0)
mantoumantou
上一篇 2023年12月5日
下一篇 2023年12月28日

相关推荐

  • 3种方式修改 wordpress 用户名

    在数字化时代,WordPress作为世界上最流行的开源内容管理系统之一,被无数网站管理员和个人用户所使用,以创建和管理他们的在线存在。然而,随着用户的不断变更和安全需求的提高,修改…

    2025年7月15日
  • Google cloud抢占式自动开机方法

    抢占式实例会自动关机是硬伤,大概3~5天会被关机,刚研究了一下,发现有一个东西叫实例时间表,这个东西可以自定义实例什么时间开机和关机,创建个时间表让他每小时开机一次抢占式实例就行了…

    2024年9月2日
  • 开源精简小探针 Artemis

    ui使用material you design的beercss,我认为这是简洁好看的设计规范 后端则使用我自己的封装声明式后端框架 URN.ts demo 附上一张截图 使用很简单…

    2024年10月27日
  • 分享个bing壁纸项目

    https://github.com/androidmumo/bing这老哥5年前我就用了他做的第一版本,23年底发现更新了果断部署前段时间改了下代码采集了2010年到现在的壁纸数…

    2025年4月5日
  • nginx一个端口代理多个前后端服务

    必须使用alias—-(这我很不理解为什么,都用root就会404,有知道的大神请告知下!)使用alias和root区别:在于资源路径的匹配解读上!访问root定义的资…

    2024年1月11日
  • IP质量体检脚本# bash <(curl -sL IP.Check.Place)

    省流简介 努力做最好的IP质量检测类脚本 中英文双语言支持(基础信息德/法/日/俄/西/葡支持) 支持IPv4/IPv6双栈查询 精美排版,直观显示,多终端单屏优化展示,便于截图分…

    代码程序 2024年5月30日
  • 一个更好用的 Maven 搜索引擎

    pache Maven 是一款非常优秀的软件项目管理工具,对于 Java 生态的开发者们再熟悉不过了。 在多年的开发过程中,对现有的 Maven 生态工具颇有微词,主要体现在: M…

    代码程序 2023年12月28日
  • linux综合脚本集成器

    这 Bash 脚本用于监测服务器的网络流量使用情况,并根据预设的阈值进行操作。它首先显示当前的接收和发送流量,然后询问用户是否设置流量阈值。用户可以选择设置阈值,并输入所需的阈值(…

    2024年4月29日
  • 如快-跨平台启动器

    之前一直在 mac 端使用 Raycast 这款启动器,觉得挺好用也挺好看的,特别是里面的快捷链接功能,非常的好用。 后面每次用自己的 Windows 的时候,总是感觉少了点什么,…

    2025年6月30日
  • 1panel 自定义博客的 404 页面

    今天忽然发现,我的博客的 404 界面被 Openresty 默认的 404 界面给覆盖了,经过一番查找,终于找到了解决方法。 问题原因 默认情况下,Nginx 或 Openres…

    代码程序 2025年3月19日

发表回复

登录后才能评论