有这么一个需求:需要远程访问内网的nas。然后现成的解决方案有蒲公英这个方案,但是个人版的话限了只能3个设备,因此找了半天,最后选择了功能类似的zerotier.

创建网络

zerotier的使用很简单,首先去官网http://zerotier.com注册一个帐号,然后创建虚拟网络。

然后就会得到一个“网络ID”

安装zerotier

接着,我们在自己电脑以及内网的机器上面,安装Zerotier.具体安装方式可以看官网的链接:Download – ZeroTier

我本机和内网机器都是linux的,因此我安装了Linux版本。

安装完之后通过以下两条命令配置开机自启动:

sudo systemctl start zerotier-one.service
sudo systemctl enable zerotier-one.service

加入网络

然后,分别在内网的机器和自己的电脑上面运行下面这条命令:

sudo zerotier-cli join 网络id

这样就能加入网络了。但是申请加入网络之后,我们需要在zerotier官网允许设备的加入。

勾选最左边的框,即可允许设备加入网络。然后为了我们接下来设置路由转发,我们需要在右侧的框中为内网的机器设置固定的ip。(对于自己的电脑就不需要设置了)

配置旁路路由

由于我们希望借助内网的这台机器作为跳板,访问内网的nas,因此我们需要配置一定的路由规则。

配置Zerotier网关路由规则

首先,我们在zerotier官网上,设置一条路由规则,将所有尝试访问内网的请求,路由到内网的机器上面。我们假设内网的上级网段为192.168.1.*, 内网跳板机在虚拟网络中的ip为172.27.x.x, 那么就可以配置这样一条路由规则:

这样,虚拟网络的网关就会将发往192.168.1.0/24这个网段的数据包导向这台跳板机。

配置内网跳板机

接着,我们要配置这台跳板机,使得它能将来自zerotier的虚拟网卡的路由请求,转发到它的连接着内网的那个网卡接口。

由于内网的这台机器是Ubuntu的,因此以下的配置对于ubuntu来说是没有问题的。没有在别的linux发行版上面测试过。

首先,我们要启用内核的ip转发功能:

vim /etc/sysctl.conf

编辑上面这个文件,然后将里面关于ip路由转发的配置打开。就是,删掉相关内容前面的#号即可。

如下图所示,我只开启了ipv4转发,没有开ipv6的。如果要开ipv6的话,就把下面那行的#号给删了即可。

保存后,输入以下命令重载配置:

sysctl -p /etc/sysctl.conf

接着,我们需要配置路由规则。

首先,我们需要确定一下zerotier虚拟网卡的名字,以及连接着内网的网卡的名字。

在控制台输入

ifconfig

然后从输出的信息中,看对应的网段,找到虚拟网卡以及内网的网卡。zerotier的网卡名字一般是一串哈希值,看着就是很乱的无规律的字符。

接着我们直接在控制台输入以下命令,导出网卡的名字为环境变量:

PHY_IFACE=连接内网的网卡的名字
ZT_IFACE=zerotier的虚拟网卡名字

然后我们就可以在同一个控制台窗口下输入以下命令,更新路由表,就搞定了。


sudo iptables -t nat -A POSTROUTING -o $PHY_IFACE -j MASQUERADE
sudo iptables -A FORWARD -i $PHY_IFACE -o $ZT_IFACE -m state --state RELATED,ESTABLISHED -j ACCEPT
sudo iptables -A FORWARD -i $ZT_IFACE -o $PHY_IFACE -j ACCEPT
iptables-save

至此,内网跳板机的配置工作就结束了。

配置自己电脑的zerotier客户端

zerotier启动的时候默认不会把在zerotier官网设置的静态路由规则应用到本机,因此我们需要手动的启用。对于有可视化界面的客户端,比如安卓的,就会有一个选项:Route Via ZeroTier.对于Linux的命令行客户端,则需要这样配置:

sudo zerotier-cli set 网络id allowGlobal=1
sudo zerotier-cli set 网络id allowDefault=1

然后就可以ping通内网的其他机器了!

转载请注明来源:异地旁路组网:zerotier – 龙进的博客https://longjin666.cn/?p=1646

欢迎关注我的公众号“灯珑”,让我们一起了解更多的事物~

异地旁路组网:zerotier相关推荐

  1. 通过 SD-WAN 异地局域网组网的方式实现办公室和家里的网络互通

    背景介绍 在我办公室的桌上放着一台用树莓派搭建的 k8s 集群. 在家里还有一台用树莓派搭建的 NAS 服务器. 我的需求是能在任何可联网地方都能访问到办公室的 k8s 集群和家里的 NAS 服务器, ...

  2. 异地组网——ZeroTier

    前言 ZeroTier 是一款简单易用的内网穿透工具(更类似异地组网SD-WAN),只需要简单配置,就能实现虚拟局域网的组建,用虚拟局域网ip和内网ip均可以无缝访问虚拟局域网中的任意一台设备.让你可 ...

  3. zerotier异地搭建组网

    使用zerotier进行搭建组网, 免费版的话, 1个网络免费50个hosts, 以前是支持 100 个设备,后来降低到 70 个,如今是 50 个,不过对于普通用户来说还是非常够用的,因为" ...

  4. 异地智能组网怎么实现的?

    异地组网是什么?就是把异地的若干个局域网互联互通成一个大的局域网的操作,异地组网您了解多少呢? 下面这个例子举得比较好,比如在总店在北京,在广州有一家个分店,分店收银机需要连接到总店的局域网的服务器, ...

  5. 视频监控如何实现异地共享/组网?EasyNTS解决远程难题

    跨地区视频监控的远程访问是很多项目团队以及集成商都需要考虑的问题.曾经我们接到过很多用户的咨询,大多数都是问:在不同城市都有仓库或者分部,且只有局域网,现在总部想要统一管理不同城市的监控视频通道,能否 ...

  6. 个人异地虚拟局域网搭建------ZeroTier

    ZeroTier介绍 ZeroTier is a smart Ethernet switch for planet Earth. 按照个人理解,通俗的说使用P2P + SDN技术搭建VPN的技术工具. ...

  7. 上古神器WireGuard异地高效率组网

  8. 天联智能异地组网方案应用场景

    小编为大家简单的罗列一下天联SD-WAN智能异地组网方案的主要应用场景,如果您有类似的应用场景可以尝试试用一下天联SD-WAN智能组网方案. 异地组网场景一:企业异地办公 很多企业有分公司,并且购买了 ...

  9. 异地组网工具天联如何使用

    下面为大家介绍一下,异地智能组网工具天联如何使用. 一.下载程序 百度搜索 "天联",进入天联SD-WAN官网,点击下载,下载对应版本的系统安装包 二.安装程序 下面以window ...

最新文章

  1. 新闻行业中,自然语言理解技术该如何应用?
  2. java package作用_java import、package作用与用法
  3. 自己动手写一个单链表
  4. ora-24811提供写入的数据少于指定的数据_C++开源、高性能时序数据库pinusdb
  5. ACCESS中的Update语句不支持Select的解决办法
  6. Flex 学习随笔 ---- 玩 Chart
  7. 隐马尔可夫模型 HMM 原理及实现
  8. PJSIP UA分析(2)--PJSUA注册
  9. ensp删除所有命令_HCIA学习笔记——eNSP配置NAT技术
  10. java基础IO流使用读取一个文件中的文字输出到控制台上
  11. wait放弃对象锁_Java线程:notify()和wait()示例
  12. 安卓beforetextchanged_Android TextWatcher.afterTextChanged与TextWatcher
  13. 计算机内存分为几代,电脑内存怎么看大小(内存条怎么看几代型号)
  14. 动态阈值_芯片设计进阶之路——门级优化和多阈值电压
  15. 我的世界Linux服务端op,服务器,后台,单机,op必备指令大全
  16. 万字长文---手把手教你加固内核安全配置
  17. css中2D转换效果实现(4)
  18. 软考初级程序员上午单选题(11)
  19. 3个实用性特别强的毕业论文选题思路
  20. 人工智能书单(数学基础篇)

热门文章

  1. 关于根据先序遍历和中序遍历画二叉树的方法
  2. 安全芯片NRSEC3000应用于具有加密功能的电压监测仪
  3. 电气自动化专业要学c语言吗,电气自动化专业与自动化专业,都有“自动化”,它们有什么区别?...
  4. 思科华为DHCP实验
  5. 吴甘沙:写在驭势科技六周年丨再向虎山行
  6. 企业邮箱忘了密码怎么办?不要怕
  7. 如何解决老毛桃PE系统自动安装360
  8. pyautogui控制鼠标
  9. 【开发工具】【git】通过关键字搜索对应的git提交日志
  10. Linux软连接和硬链接-实际操作一遍你就会懂!!!