位置: 编程技术 - 正文

在Linux上配置P2P VPN的教程 (用linux配置ftp服务器的过程)

编辑:rootadmin

推荐整理分享在Linux上配置P2P VPN的教程 (用linux配置ftp服务器的过程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:用linux配置ftp服务器的过程,用linux配置ftp服务器的过程,linux配置l2tp,linux配置pip,linux配置l2tp,linux配置l2tp,linux配置pip,linux配置l2tp,内容如对您有帮助,希望把文章链接给更多的朋友!

一个传统的 VPN(如 OpenVPN、PPTP)由一个 VPN 服务器和一个或多个连接到这台服务器的客户端组成。当任意两个 VPN 客户端彼此通信时,VPN 服务器需要中继它们之间的 VPN 数据流量。这样一个中心辐射型的 VPN 拓扑结构存在的问题是,当连接的客户端增多以后,VPN 服务器很容易成为一个性能上的瓶颈。从某种意义上来说,中心化的 VPN 服务器也同样成为一个单点故障的来源,也就是当 VPN 服务器出现故障的时候,整个 VPN 都将无法被任何 VPN 客户端访问。点对点 VPN(又称 P2P VPN)是另一个 VPN 模型,它能解决传统的基于服务器-客户端模型的 VPN 存在的这些问题。一个 P2P VPN 中不再有一个中心的 VPN 服务器,任何拥有一个公开 IP 地址的节点都能引导其他节点进入 VPN。当连接到一个 VPN 之后,每一个节点都能与 VPN 中的任何其他节点直接通信,而不需要经过一个中间的服务器节点。当然任何节点出现故障时,VPN 中的剩余节点不会受到影响。节点中的延迟、带宽以及 VPN 扩展性在这样的设定中都有自然的提升,当你想要使用 VPN 进行多人游戏或者与许多朋友分享文件时,这都是十分理想的。

开源的 P2P VPN 实现已经有几个了,比如 Tinc、peerVPN,以及 n2n。在本教程中,我将会展示如何在 Linux 上用 n2n 配置点对点 VPN。

n2n 是一个开源(GPLv3)软件,它允许你在用户间构建一个加密的 2/3 层点对点 VPN。由 n2n 构建的 VPN 是“对 NAT 友好”的,也就是说,不同 NAT 路由器后方的两个用户可以通过 VPN 直接与对方通信。n2n 支持对称的 NAT 类型,这是 NAT 中限制最多的一种。因此,n2n 的 VPN 数据流量是用 UDP 封装的。

一个 n2n VPN 由两类节点组成:边缘(edge)节点和超级(super)节点。一个边缘节点是一台连接到 VPN 的电脑,它可能在一个 NAT 路由器后方。一个超级节点则是拥有一个可以公共访问的 IP 地址的电脑,它将会帮助 NAT 后方的边缘节点进行初始通信。想要在用户中创建一个 P2P VPN 的话,我们需要至少一个超级节点。

准备工作

在这篇教程中,我将会创建一个拥有 3 个节点的 P2P VPN:一个超级节点和两个边缘节点。唯一的要求是,边缘节点需要能够 ping 通超级节点的 IP 地址,而它们是否在 NAT 路由器之后则没有什么关系。在 Linux 上安装 n2n

若想用 n2n 构建一个 P2P VPN,你需要在每个节点上安装 n2n,包括超级节点。

由于它非常精简的依赖需求,在大多数 Linux 平台上 n2n 都能被轻松编译。

在基于 Debian 的系统上安装 n2n:

复制代码代码如下:$ sudo apt-get install subversion build-essential libssl-dev $ svn co $ cd n2n/n2n_v2 $ make $ sudo make install

在基于 Red Hat 的系统上安装 n2n:

复制代码代码如下:$ sudo yum install subversion gcc-c++ openssl-devel $ svn co $ cd n2n/n2n_v2 $ make $ sudo make install

用 n2n 配置一个 P2P VPN

在Linux上配置P2P VPN的教程 (用linux配置ftp服务器的过程)

如前文所述,我们需要至少一个超级节点,它将会作为一个初始化引导服务器。我们假设这个超级节点的 IP 地址是 1.1.1.1。超级节点:

在一个作为超级节点的电脑上运行下面的命令。其中“-l <端口>”指定超级节点的监听端口。运行 supernode 并不需要 root 权限。

复制代码代码如下:$ supernode -l

边缘节点:

在每个边缘节点上,使用下面的命令来连接到一个 P2P VPN。edge 守护程序将会在后台运行。

边缘节点 #1:

复制代码代码如下: $ sudo edge -d edge0 -a .0.0. -c mynetwork -u -g -k password -l 1.1.1.1: -m ae:e0:4f:e7::5b

边缘节点 #2:

复制代码代码如下:$ sudo edge -d edge0 -a .0.0. -c mynetwork -u -g -k password -l 1.1.1.1: -m ae:e0:4f:e7::5c

下面是对命令行的一些解释:

“-d <接口名>”选项指定了由 edge 命令创建的 TAP 接口的名字。 “-a <IP地址>”选项(静态地)指定了分配给 TAP 接口的 VPN 的 IP 地址。如果你想要使用 DHCP,你需要在其中一台边缘节点上配置一台 DHCP 服务器,然后使用“-a dhcp:0.0.0.0”选项来代替。 “-c <组名>”选项指定了 VPN 组的名字(最大长度为 个字节)。这个选项可以被用来在同样一组节点中创建多个 VPN。 “-u”和“-g”选项被用来在创建一个 TAP 接口后降权放弃 root 权限。edge 守护进程将会作为指定的用户/组 ID 运行。 “-k <密钥>”选项指定了一个由 twofish 加密的密钥来使用。如果你想要将密钥从命令行中隐藏,你可以使用 N2N_KEY 环境变量。 “-l <IP地址:端口>”选项指定了超级节点的监听 IP 地址和端口号。为了冗余,你可以指定最多两个不同的超级节点(比如 -l <超级节点 A> -l <超级节点 B>)。 “-m ”给 TAP 接口分配了一个静态的 MAC 地址。不使用这个参数的话,edge 命令将会随机生成一个 MAC 地址。事实上,为一个 VPN 接口强制指定一个静态的 MAC 地址是被强烈推荐的做法。否则,比如当你在一个节点上重启了 edge 守护程序的时候,其它节点的 ARP 缓存将会由于新生成的 MAC 地址而遭到污染,它们将不能向这个节点发送数据,直到被污染的 ARP 记录被消除。

至此,你应该能够从一个边缘节点用 VPN IP 地址 ping 通另一个边缘节点了。故障排除

在调用 edge 守护程序的时候得到了如下错误。

复制代码代码如下:n2n[]: ERROR: ioctl() [Operation not permitted][-1]

注意 edge 守护进程需要超级用户权限来创建一个 TAP 接口。因此需要确定用 root 权限来执行,或者对 edge 命令设置 SUID。之后你总是可以使用“-u”和“-g”选项来降权放弃 root 权限。总结

n2n 可以成为对你来说非常实用的免费 VPN 解决方案。你可以轻松地配置一个超级节点,无论是用你自己家里的网络,还是从云主机提供商购买一个可以公共访问的 VPS 实例。你不再需要把敏感的凭据和密钥放在第三方 VPN 提供商的手里,使用 n2n,你可以在你的朋友中配置你自己的低延迟、高带宽、可扩展的 P2P VPN。

在Linux系统中启用Intel Rapid Start的方法 IntelRapidStart是Intel公司研发的一种帮助笔记本电脑节省电源和快速恢复的技术,与传统的睡眠(Sleep)和休眠(Hibernate)有一定的区别,相较而言,与混

在Linux系统上检查所安装的SSH的版本的方法 安全Shell(SSH)通过加密的安全通信通道来远程登录或者远程执行命令。SSH被设计来替代不安全的明文协议,如telnet、rsh和rlogin。SSH提供了大量需要的特

Linux在VIM编辑器中修改Tab为4个空格的方法 Linux用户最经常使用的编辑器便是VIM编辑器,为了提高我们的编辑速度,我们经常会在编辑器中设置一些快捷方式。今天小编就和大家一起分享下在VIM编

标签: 用linux配置ftp服务器的过程

本文链接地址:https://www.jiuchutong.com/biancheng/367552.html 转载请保留说明!

上一篇:在Linux系统上安装Linux内核头文件的教程(linux安装有哪几种方式)

下一篇:在Linux系统中启用Intel Rapid Start的方法(linux常见的启动方式)

  • 个体工商户增值税优惠政策2023
  • 印花税申报表计税依据怎么填
  • 减免税额科目
  • 注册公司不开账户可以吗
  • 征信高风险是什么意思
  • 合作社收到政府补助款怎么做分录呢
  • 工程物资什么时候结转到开发成本里面
  • 以物抵债需要缴纳之前欠的税吗?
  • 返利销售增值税
  • 企业公示实缴填写
  • 境外机构在境内发行的人民币债券
  • 通过认证的增值税怎么算
  • 欠缴税款会给纳税证明吗
  • 对外销售产品
  • 销售研发试制样板图
  • 季度流动比率怎么算
  • 高新技术企业如何查询
  • 去税务局交的社保能退么
  • 金融业营业税改增值税
  • 浅谈收入与成本的关系
  • 分公司不独立核算怎么报税
  • 销售已使用过的固定资产增值税
  • 劳动报酬个人所得税由扣缴义务人预扣预缴
  • 科技服务业是怎么分类的
  • 关于员工表彰奖励的方案
  • 累积带薪缺勤金额怎么算
  • win10远程连接提示身份验证错误
  • mac菜单键怎么设置出来的
  • 企业接受股权投资概念政府基金
  • php如何读取文件内容
  • 如何通过手机号码查对方在哪里
  • 甲公司购入一台入账价值为200万元的生产设备
  • php制作简单的表单代码
  • 企业低值易耗品摊销计入产品成本的方法
  • thinkphp addons
  • seq命令
  • discuz 移动端
  • python偏函数理解
  • 软件和集成电路企业
  • 公司贷款买车有什么风险
  • 公益性捐赠支出纳税调整
  • 税率变了
  • 在什么情况下要切除子宫
  • mysql默认值怎么设置
  • 工会支付职工福利费做账
  • 应交增值税结转账务处理
  • 外地预缴怎么算
  • 工程完工后的质保金怎么入账
  • 代缴社保的好处有哪些
  • 财政收回项目资金请示
  • 协作费用
  • 拍卖土地支付的法律依据
  • 资金账簿减半征收印花税
  • 固定资产清理的借贷方向
  • 收到税务局汇算清缴退所得税怎么做账
  • 企业自查补交增值税
  • 计提加计抵减额的会计处理
  • 无需缴纳的税费是什么
  • WINDOWS7系统安装包
  • ati2mdxx.exe是什么进程 ati2mdxx进程信息查询
  • win7定时关机没反应
  • 使用和启动故障的区别
  • win10win8双系统
  • cocos2dx schedule
  • OpenGL Tips: 在Visual C++中调用FreeGLUT
  • shell脚本编写的基本知识
  • python2.7和3.8
  • javascriptj
  • js实现登录界面
  • 微信小程序访问相册权限在哪里
  • javascript中array数组对象的含义及常用方法
  • 夜间模式图
  • jquery增加一行和删除
  • 国家税务总局广州市税务局
  • 湖北农信换手机登录不了
  • 房产税纳税义务时间
  • 上海国家税务局官网发票查验平台
  • 河南濮阳市供电公司何文中个人简历
  • 工会经费支出审批制度
  • 幼儿掌握概念的名称容易真正掌握概念的内涵也很容易
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设