使用sshuttle构建一个穷人的虚拟专网

系统 Linux
如今,企业网络经常使用“虚拟专用网络”来保证员工通信安全。但是,使用的协议有时会降低性能。如果你可以使用 SSH 连接远程主机,那么你可以设置端口转发。但这可能会很痛苦,尤其是在你需要与该网络上的许多主机一起使用的情况下。试试sshuttle,它可以通过 SSH 访问来设置快速简易的虚拟专网。

[[279841]]

如今,企业网络经常使用“虚拟专用网络”来保证员工通信安全。但是,使用的协议有时会降低性能。如果你可以使用 SSH 连接远程主机,那么你可以设置端口转发。但这可能会很痛苦,尤其是在你需要与该网络上的许多主机一起使用的情况下。试试 sshuttle,它可以通过 SSH 访问来设置快速简易的虚拟专网。请继续阅读以获取有关如何使用它的更多信息。

sshuttle 正是针对上述情况而设计的。远程端的唯一要求是主机必须有可用的 Python。这是因为 sshuttle 会构造并运行一些 Python 代码来帮助传输数据。

安装 sshuttle

sshuttle 被打包在官方仓库中,因此很容易安装。打开一个终端,并使用 sudo 来运行以下命令:

  1. $ sudo dnf install sshuttle

安装后,你可以在手册页中找到相关信息:

  1. $ man sshuttle

设置虚拟专网

最简单的情况就是将所有流量转发到远程网络。这不一定是一个疯狂的想法,尤其是如果你不在自己家里这样的受信任的本地网络中。将 -r 选项与 SSH 用户名和远程主机名一起使用:

  1. $ sshuttle -r username@remotehost 0.0.0.0/0

但是,你可能希望将该虚拟专网限制为特定子网,而不是所有网络流量。(有关子网的完整讨论超出了本文的范围,但是你可以在维基百科上阅读更多内容。)假设你的办公室内部使用了预留的 A 类子网 10.0.0.0 和预留的 B 类子网 172.16.0.0。上面的命令变为:

  1. $ sshuttle -r username@remotehost 10.0.0.0/8 172.16.0.0/16

这非常适合通过 IP 地址访问远程网络的主机。但是,如果你的办公室是一个拥有大量主机的大型网络,该怎么办?名称可能更方便,甚至是必须的。不用担心,sshuttle 还可以使用 –dns 选项转发 DNS 查询:

  1. $ sshuttle --dns -r username@remotehost 10.0.0.0/8 172.16.0.0/16

要使 sshuttle 以守护进程方式运行,请加上 -D 选项。它会以 syslog 兼容的日志格式发送到 systemd 日志中。

根据本地和远程系统的功能,可以将 sshuttle 用于基于 IPv6 的虚拟专网。如果需要,你还可以设置配置文件并将其与系统启动集成。如果你想阅读更多有关 sshuttle 及其工作方式的信息,请查看官方文档。要查看代码,请进入 GitHub 页面

题图由 Kurt Cotoaga 拍摄并发表在 Unsplash 上。 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2018-10-31 12:41:11

2009-09-02 15:21:48

2023-02-13 14:47:32

人工智能机器学习ChatGPT

2018-08-27 17:05:48

tensorflow神经网络图像处理

2022-02-07 19:59:54

CMakeVSCodium编程语言

2023-09-05 09:00:00

工具Python抄袭检测系统

2023-09-15 10:10:05

R 语言

2021-03-04 10:10:55

5G通信虚拟专网

2023-10-31 07:21:05

开源安全工具

2020-11-09 06:38:00

ninja构建方式构建系统

2011-03-30 13:13:09

虚拟专用网

2011-03-30 13:23:12

USB Key密钥

2018-05-25 08:44:22

树莓派PythonMySQL

2023-03-10 13:38:00

Python文档扫描器

2021-07-14 17:39:46

ReactRails API前端组件

2023-09-21 08:00:00

ChatGPT编程工具

2012-12-20 11:16:16

IBMdW

2016-09-21 12:54:10

CAAS系统镜像

2015-12-04 11:36:04

SaaS架构设计可持续

2018-11-14 19:00:24

PythonRedis共享单车
点赞
收藏

51CTO技术栈公众号