网站地图    收藏   

主页 > 系统 > linux系统 >

N2N VPN服务器的搭建 - Linux操作系统:Ubuntu_Centos

来源:自学PHP网    时间:2015-04-14 11:51 作者: 阅读:

[导读] 2008年,ntop的作者Luca Deri开始研究p2p VPN,他一方面看到公众对p2p VPN有着强烈的需求,另一方面又不满足已有产品的现状,于是n2n诞生了。如上图所示,n2n是一个二层架构的VPN网络,其中...

2008年,ntop的作者Luca Deri开始研究p2p VPN,他一方面看到公众对p2p VPN有着强烈的需求,另一方面又不满足已有产品的现状,于是n2n诞生了。

\

如上图所示,n2n是一个二层架构的VPN网络,其中super node提供场所,让两个位于NAT/防火墙之后的edge node进行会面,一旦双方完成首次握手,剩下的数据流就之发生在两个edge node之间,如果有一方的NAT属于对称型(symmetrical),super node则还需继续为双方提供数据包的转发;edge node负责数据流的加解密,原理很简单。

对于一个VPN而言,主要涉及封装和加解密两个步骤,edge node使用UDP协议进行封装,目的是为了更好的兼容防火墙的策略,因为很多防火墙禁用了非TCP/UDP协议禁用。加密算法则采用了twofish,好处开源、简便,处理速度快。
为了降低设计难度,n2n利用了tap/tun虚拟网卡,这样做得好处是一方面软件尺寸极小,一方面源码的依赖性极低,可以很容易移植到嵌入式设备中,目前有openwrt的版本,在未来的计划中,还将移植到android和iPhone中。

相对于hamachi,n2n最大的优势在于:
1. 开源,任何人都可以检查代码,看看是否有猫腻,而hamachi是闭源的,LogMeIn是否会截获密钥不得而知,一旦截获密钥,就可以对流经 hamachi服务器的数据包进行解码。n2n的加解密过程由edge node实现,只有两端的用户知道协商好的共享密钥,super node无从知晓。

2. 灵活性,n2n允许用户在Internet上自行创建super node,也可以利用任何一个公开的super node。

hamachi用户则必须登录到LogMeIn服务器才能创建隧道。
n2n支持的OS也非常广,Linux、FreeBSD、MAC OSX、甚至windows

官方网站:http://www.ntop.org/n2n/
软件下载http://sourceforge.net/projects/ntop/files/

软件安装:下载1.3.2版本源码  解压 make make install即可

安装完后,系统多了两个命令  edge和 supernode,edge是客户端,supernode是服务端。

服务端用法:supernode -l <listening port> 就这么简单。
supernode -l 8888

客户端用法:
edge -a 3.3.3.4 -c wss -k wss -l 127.0.0.1:8888 &
edge -a 你需要的第2个ip地址 -c 你的虚拟网名 -k 你的密码  -l 服务器的ip地址:端口 &

-d <tun device>          | tun device name  可选
-a <tun IP address>    | n2n IP address
-c <community>           | n2n community name
-k <encrypt key>         | Encryption key (ASCII) – also N2N_KEY=<encrypt key>
-s <netmask>             | Edge interface netmask in dotted decimal notation (255.255.255.0)
-l <supernode host:port> | Supernode IP:port
-b                       | Periodically resolve supernode IP
| (when supernodes are running on dynamic IPs)
-p <local port>          | Local port used for connecting to supernode
-u <UID>                 | User ID (numeric) to use when privileges are dropped
-g <GID>                 | Group ID (numeric) to use when privileges are dropped
-f                       | Fork and run as a daemon. Use syslog.
-m <MAC address>         | Choose a MAC address for the TAP interface
| eg. -m 01:02:03:04:05:06
-M <mtu>                 | Specify n2n MTU (default 1400)
-t                       | Use http tunneling (experimental)
-r                       | Enable packet forwarding through n2n community

其他事项:
1.数据包使用UDP 53端口,和DNS的一样。

2.算然数据不直接通过supernode,但supernode对速度影响还是很大,建议搭建自己的supernode。

3.n2n 软件Windows 版客户端

http://www.vpnhosting.cz/n2nguien.exe

参考资料:

aspx">http://www.ppcn.net/n5690c39.aspx

http://bbs.chinaunix.net/viewthread.php?tid=1596037

html">http://hi.baidu.com/viccom/blog/item/a308b195c36d5d43d1135e16.html

http://www.ichiayi.com/wiki/tech/n2nvpn

http://www.cublog.cn/u3/103983/showart_2085197.html

==========后记============

后记:写此文时很仓促,很多东西都没写。补充一下:

1.提供一个supernode  88.86.108.50:82 [vpnhosting.cz提供]

2.提供服务端运行语句:

supernode -l 8848 >/dev/null 2>&1 &

先在前台运行,调试好以后,将所有输出 定向到 /dev/null 并且在后台运行

调试时,服务端可能会出现如下错误

15/Oct/2010 03:25:22 [supernode.c: 325] WARNING: Received packet with unknown protocol version (2): discarded

3.使用windows下客户端登录时,默认使用V2版本协议,服务端可能不识别,请将windows下客户端版本调至V1.

4.提供windows下服务端程序,程序来源互联网,点此下载//本站提供下载,经测试该版本只能使用V2版本

5.提供地址一个,里面发布了windows版客户端和服务端,全部在DOS下开启命令

http://www.gamespot.com/pages/forums/show_msgs.php?topic_id=26973101

6.提供windows下DOS版本N2N 客户端和服务端 由上面地址发布

http://uploading.com/files/f29cf25d/n2n%2Bv1.3.3.rar/

7.提供sourceforge开源项目一个,N2N 客户端GUI

http://sourceforge.net/projects/n2nedgegui/

======================

另附:Campagnol VPN  使用的一些感受,没有进行详细测试

Campagnol 是一个分布式基于IP的 VPN程序,可以无配置的直接透过防火墙和 NATs,使用的是传输层的 UDP

原理是和N2N一样的,只不过他是使用的密钥方式管理。

下载地址:

http://sourceforge.net/projects/campagnol/files/

使用方法:
安装
签发CA和密钥
运行服务端和客户端

存在的缺陷:
1.密钥方式管理,比较复杂
2.对服务端依赖太多(CA)
3.IP是由客户端自行制定,如何进行区分?

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论