免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4184 | 回复: 12
打印 上一主题 下一主题

让Linux NAT服务器支持UPnP [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-12-14 17:52 |只看该作者 |倒序浏览
=========================================
作者:Nanu
如需转载请注明作者,谢谢!
参考文献:
《UPnP on your Linux 2.4 firewall how-to》 by bijl
《让 Linux NAT 服务器支持 UPnP》 by lonestar
《UPnP为我们献上一道怎样的大餐》 by Sharon Crawford
=========================================

注意:如果对网络安全要求较高或要求高可控制性的网络,则不要安装配置UPnP支持,否则会导致网络NAT映射比较混乱,从而引发许多问题。建议小型网络或者家庭网络使用UPnP。

最近经常使用一些P2P类型软件,发现老得在Linux服务器上手动设置NAT,非常麻烦,而看着许多P2P软件都支持UPnP就眼馋,如果能让Linux支持UPnP那就简单方便多了!于是在网上搜索了一下有关让Linux支持UPnP的文章,于是就写了这篇文章。

一、什么是UPnP

1. UPnP简介
--------------
UPnP(Universal Plug and Play)技术对即插即用进行了扩展,它简化了家庭或企业中智能设备的联网过程。在结合了UPnP技术的设备以物理形式连接到网络中之后,它们可以通过网络自动彼此连接在一起,而且连接过程无需用户的参与

UPnP规范基于TCP/IP协议和针对设备彼此间通讯而制订的其它Internet协议。这就是它之所以被称作"通用(Universal)"的原因所在--UPnP技术不依赖于特定的设备驱动程序,而是使用标准的协议。UPnP设备可以自动配置网络地址,宣布它们在某个网络子网的存在,以及互相交换对设备和服务的描述。基于Windows XP的计算机可以充当一个UPnP控制点,通过程序界面对设备进行发现和控制。

如果与以前的即插即用相比,这种技术似乎并不具有什么革命性的意义。在操作系统中增加即插即用技术使得在单个计算机上安装、配置和添加外设的工作变得更容易了。但是UPnP为家庭用户或者小型办公环境中的非专业用户所带来的是一道更加美味的"大餐",他们可以利用UPnP玩多人游戏,进行实时通信(Internet电话,电话会议)以及使用类似Windows XP的远程协助这样的其它技术。

2. NAT 穿越技术
------------------
NAT穿越技术允许网络应用程序对它们是否位于一个具有UPnP能力的NAT设备之后进行检测。然后,这些程序将获得共享的全球可路由IP地址,并且配置端口映射以将来自NAT外部端口的数据包转发到应用程序使用的内部端口上--所有这一切都是自动完成的,用户无需手动映射端口或者进行其它工作。NAT穿越技术允许网络设备或者点对点应用程序通过动态开启和闭合与外部服务之间的通信端口穿过NAT网关与外界通信。

二、在Linux中部署UPnP支持

我们假设该Linux的内核版本是2.4.x,使用拨号上网,外网接口是ppp0,内网接口是eth0,并且已经启用iptables设定了 NAT。

在Linux中部署UPnP主要使用2个软件的配合:UPnP SDK for Linux和LinuxIGD。

下载地址:
UPnP SDK for Linux: http://sourceforge.net/projects/upnp/
LinuxIGD: http://linux-igd.sourceforge.net/

注意:要下载upnpsdk-1.0.4.tar.gz,1.0.4以上的版本不能和LinuxIGD很好的协同工作!

A. 安装:
----------
1. 解包UPnP SDK
# tar xzvf upnpsdk-1.0.4.tar.gz

2. 修改源代码
为了能够使Windows MSN Messenger在UPnP下正常通讯,所以必须修改源代码:
# cd upnpsdk-1.0.4
# vi src/ssdp/ssdplib.c
将第406行的:

SelfAddr.sin_addr.s_addr = inet_addr(SSDP_IP);

改为:

SelfAddr.sin_addr.s_addr = htonl(INADDR_ANY);

3. 编译安装UPnP SDK
# make
# make install

4. 解包Linux-IGD
# tar xzvf linuxigd-0.92.tgz

5. 编译安装Linux-IGD
# cd linux-igd
# make
# make install

B. 配置
--------
1. 增加多播路由
# route add -net 239.0.0.0 netmask 255.0.0.0 eth0

2. 为iptables建议一个软链接
# cd /usr/sbin
# ln -s /sbin/iptables ./

启动UPnP
# upnpd ppp0 eth0

诊断UPnP运行状态
# tail /var/log/messages

如果能够看到:

Dec  14 16:01:49 doorway -- MARK --
Dec  14 16:02:15 doorway upnpd: The Linux UPnP Internet Gateway Device Ver 0.92 by Dime (dime@gulfsales.com)
Dec  14 16:02:15 doorway upnpd: Special Thanks for Intel's Open Source SDK and original author Genmei Mori's work.

则说明UPnP已经成功启动。

C. 测试
--------
以支持UPnP的P2P网络电视PPLive为例,在PPLive中打开UPnP支持选项,然后连接一个频道。
在Linux中执行:
# tail /var/log/debug -f

如果能看到:

Dec  14 16:56:33 doorway upnpd: AddPortMap: RemoteHost: (null) Prot: 17 ExtPort: 3226 Int: 10.0.0.2.3226
Dec  14 16:56:33 doorway upnpd: AddPortMap: RemoteHost: (null) Prot: 6 ExtPort: 3226 Int: 10.0.0.2.3226
Dec  14 16:56:33 doorway upnpd: AddPortMap: RemoteHost: (null) Prot: 6 ExtPort:  3156 Int: 10.0.0.2.3156
Dec  14 16:56:33 doorway upnpd: AddPortMap: RemoteHost: (null) Prot: 6 ExtPort:  3156 Int: 10.0.0.2.3156

则说明PPLive已经向UPnP请求进行端口映射了。只要看到这样的字样,就说明UPnP已经完全工作起来了。

[ 本帖最后由 Nanu 于 2005-12-14 18:19 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2005-12-14 18:08 |只看该作者
比特精灵有寻找网络中 UPnP 并自动打开端口的功能,一直想让 Linux 也支持,现在终于有方法了 ^_^

论坛徽章:
0
3 [报告]
发表于 2005-12-14 18:14 |只看该作者
看到一个小问题
1. 增加广播路由
# route add -net 239.0.0.0 netmask 255.0.0.0 eth0

这不是“广播”,而是“多播”,为什么会用到多播还不清楚,不知道 UPnP 的工作原理。。。。

论坛徽章:
0
4 [报告]
发表于 2005-12-14 18:19 |只看该作者
啊!对对对!应该是多播!呵呵,谢谢斑竹啊!

论坛徽章:
0
5 [报告]
发表于 2005-12-15 00:29 |只看该作者
因为upnp用到了udp1900端口进行广播,否则它根本不知道内网内存在着多少机器有开着upnp的(注意,在我的实际观察中,目的地是广播地址),因此在一个比较大的子网中,upnp容易导致广播风暴,而且是一定时间搜索一次,所以干扰更大。在winxp中,该服务默认是开启状态,即会对外不断发1900端口的询问。

由于我管理的网原则上是禁止bt类软件的,因此直接在交换机上把1900口是封锁了的。

论坛徽章:
0
6 [报告]
发表于 2005-12-15 11:31 |只看该作者
哈,回头我也试试.

论坛徽章:
0
7 [报告]
发表于 2005-12-15 13:06 |只看该作者
在没看这个帖子的时候,我刚远程布置过这个东西,但还没有来的及测试。其实安装并不难,就是大家都没想到linux能支持这个东西,那两个版本的软件的东西都是好几年前出的东西了。不过现在已经有了更新版本的了,sdk 到了1.2.2,igd到了1.0

论坛徽章:
0
8 [报告]
发表于 2005-12-15 17:17 |只看该作者
原帖由 skylove 于 2005-12-15 00:29 发表
因为upnp用到了udp1900端口进行广播,否则它根本不知道内网内存在着多少机器有开着upnp的(注意,在我的实际观察中,目的地是广播地址),因此在一个比较大的子网中,upnp容易导致广播风暴,而且是一定时间搜索一 ...

根据我看的文档,multicast和broadcast都用了,但broadcast只用在dhcp和duplicate IP detection上
参考www.upnp.org上文档:<UPnP Device Architecture v1.0.1 Draft >

http://www.upnp.org/resources/do ... DA101-20031202s.pdf

论坛徽章:
0
9 [报告]
发表于 2005-12-15 18:05 |只看该作者
ok,谢谢了~~~ 等下吃了饭就去拜读

论坛徽章:
0
10 [报告]
发表于 2005-12-17 15:30 |只看该作者
先收下......
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP