- 易迪拓培训,专注于微波、射频、天线设计工程师的培养
移动IP中的移动检测技术
移动IP中的移动检测技术
<%=shijian%
> 中国数据
马艳峰 黄鹂
前言
移动IP在互联网上为移动计算机提供了不中断通信的无缝漫游
协议。它突破了计算机机房、信息插座和地域等限制,允许移动节点在移动时穿过不同或相似的传
输媒介,使人们能够随时、随地、更加灵活地访问互联网。移动IP是一个对网络移动性的解决方
案。移动IP中移动节点要完成通信,必须先确定自己的位置,判断自己是否在不同链路上进行切
换。注册完成后才能进行通信。移动节点如何判断自己在网络中的当前位置是移动IP研究中的重大
课题,也是内外研究的热点之一。本文拟从移动IP的基本概念、基本原理入手,探讨移动IP中的
移动检测技术。
1、移动IP的基本概念
为解决互联网的移动性问题,RFC2002最先引入移动节点
(Mobile Node)、本地代理(Home Agent)和外地代理(Foreign Agent)三种功能实体并提
出移动IP的概念,从而为移动节点接入互联网提供了透明路由协议。
1.1 移动IP的功能实体
移动节点是移动网络中的主机或路由器。它可以将接入互联网的
位置从一条链路切换到另一条链路上,不用更改IP地址而仍然保持所有正在进行的通信。与移动节
点紧密相关的两个地址是本地地址和转交地址。
本地代理是与移动节点本地链路相连的主机或路由器。当移动节
点切换链路时,本地代理通知移动节点它的当前位置或广播对移动节点本地地址网络前缀的可达
性,从而吸引那些送往移动节点的本地地址的数据包。同时,本地代理解析送往移动节点本地地址
的数据包,并将这些数据包通过隧道传送到移动节点的转交地址上。
外地代理是连接在移动节点外地链路上的主机或路由器。外地代
理为移动节点提供转交地址并将移动节点的转交地址通知移动节点的本地代理,同时外地代理还可
以作为连接在外地链路上移动节点的缺省路由器。
1.2 本地地址和转交地址
移动节点有两个非常重要的IP地址,即本地地址和转交地
址。
移动节点的本地地址是指"永久"地分配给该节点的地址,当移
动节点切换链路时,本地地址并不改变。只有当整个网络需重新编址时才改变移动节点的本地地
址。
转交地址是连接本地代理和移动节点的隧道出口。转交地址与移
动节点当前所在的外地链路相关。转交地址也随着移动节点改换而改变。送往转交地址的数据包可
以通过现有的因特网路由机制传送,而不需要移动IP中的隧道技术转发数据包。
转交地址包括外地代理转交地址(Foreign Agent Care-of-
Address)和配置转交地址(Collocated Care-of-Address)。外地代理转交地址是外地代理
的任一个IP地址,外地代理只须有一个端口连接移动节点所在的外地链路上。因此,外地代理转交
地址的网络前缀并不一定与外地链路的网络前缀相同,多个移动节点可以同时共用一个外地代理转
交地址。配置转交地址是暂时分配给移动节点的某个端口的IP地址,其网络前缀必须与移动节点当
前所连的外地链路的网络前缀相同。当外地链路上没有外地代理时,移动节点可以采用这种转交地
址。配置转交地址是唯一的,只能被一个移动节点使用。
1.3 本地链路和外地链路
本地链路是与移动节点本地地址具有相同网络前缀的链路。移动
节点本地地址的网络前缀决定了它的本地链路。
外地链路是移动节点外地代理所在的链路。
2、广播消息
广播消息在移动检测中起着重要的作用。广播消息有两大类,一
是广播代理消息(Agent Advertisement Message),二是代理请求消息(Agent
Solicitation Message)。
2.1 广播代理消息
本地代理或外地代理利用代理广播消息向移动节点宣布它们的功
能。当一个节点在一条链路上被配置成本地代理或(和)外地代理,它就在这条链路上广播或组播
代理广播消息,这使得连到这条链路上的移动节点可以判定该链路上是否有代理存在。
2.2 代理请求消息
当移动节点等不到下一个周期发送的代理广播消息时,它可以发
送代理请求消息。请求该链路上的所有代理立即发送一个代理广播消息。在移动节点快速地切换链
路时,代理请求消息就非常有用了。
移动IP不要求对这两种消息进行确认,移动IP利用了这两个消
息的格式,并对它们进行了扩展以完成移动检测。
3、移动IP的工作机制
移动节点通过发送代理请求消息或接收本地代理和外地代理发送
的代理广播消息判断自己在网络中的位置。如果在本地链路上,移动节点就按固定节点的方式进行
通信,而不须使用移动IP的功能。
如果移动节点连在外地链路上,它就从外地代理广播的代理广播
消息中找到外地代理的转交地址,同时向本地代理注册该转交地址。本地代理向移动节点回应接收
或拒绝的注册应答消息。
注册成功后,本地代理将发往移动节点的数据包再次封装通过隧
道送到移动节点的转交地址。然后从隧道取出、解封装后送往移动节点。
从移动节点发出的数据包将通过标准的路由通道直接发到目的节
点,不需要使用隧道技术。
4、移动IP中的移动检测技术
移动检测可按两类情况进行,一是有代理广播消息的情况;二是
没有代理广播消息的情况。下面进行详细的探讨。
4.1 有代理广播消息的情况
假设移动节点所连接的链路上至少有一个代理,则移动节点可以
通过两种方法来确定自己是否切换到了新的链路上。一种方法是利用生存时间域作移动检测,另一
种方法是利用网络前缀作移动检测。
4.1.1 用生存时间域作移动检测
代理广播消息中ICMP路由器广播部分的生存时间域表示移动节
点接收同一代理的广播消息的时间周期。本地代理和外地代理需要频繁地发送广播消息以免广播消
息的丢失,特别是在较容易出错的无线链路上。
当移动节点注册到外地代理上时,如果在生存时间域规定的时间
内却没有收到来自该代理的广播消息,那么说明该移动节点已移动到另一链路上或者该外地代理已
经不可用了。此时移动节点向下一个发来代理广播消息的外地代理注册,如果移动节点没有收到任
何广播消息,它就发出一个代理请求消息去询问。
4.1.2 用网络前缀作移动检测
假设移动节点向某条链路上的外地代理注册,记录了该代理广播
消息后,移动节点又收到了来自另一个外地代理的代理广播消息。在这种情况下,移动节点将从两
个广播消息中计算出网络前缀并加以比较来判定两个广播消息是否来自同一条链路。如果不同,则
两个广播消息是从不同的链路上接收到的,否则就是从同一链路上接收到的。当移动节点将新收到
的广播消息与它当前正注册的外地代理比较后,如果发现它已移动到新链路上了,就应向在新链路
上的外地代理进行注册。否则,如果接收的广播消息只是来自同一条链路的另一个外地代理,移动
节点并没有移动,这时,不必向新代理注册,除非它在广播消息中的生存时间(Lifetime)内没
有收到当前注册的外地代理的广播消息,这意味着,移动节点仍然采用第一个移动检测方法-用生
存时间-来看当前的外地代理是否还可用,如果不可用,移动节点就注册到一个新的外地代理上。
4.2 没有广播消息的情况
移动节点接收不到广播消息,就无法判断自己是处在本地链路上
还是外地链路上,此时移动节点必须用其他方法进行移动检测。主要有三种方法,如
下:
4.2.1 设法在本地链路上通信
如果移动节点连到了一条链路上但却收不到任何代理广播消息,
那么移动节点可以假设正连在它的本地链路上,并且其本地代理出现故障,无法广播代理消息。这
时,移动节点只需简单地按它在本地链路上那样进行通信。例如,可以向它在本地链路上用的缺省
路由器发送ICMP Echo Request消息,如果这台缺省路由器给出了应答,那么移动节点很可能正
连在它的本地链路上,这样就可以继续通信了。
4.2.2 在外地链路上用DHCP和手工配置
如果缺省路由器没有应答,那么移动节点可以认为它正连在一条
外地链路上。这时,移动节点可以设法通过DHCP服务器得到一个地址,如果成功了,移动节点就
可以将这个地址作为配置转交地址,并向它的本地代理注册。如果DHCP服务器没有应答,那么使
用移动节点的人可以为它手工配置一个IP地址作为配置转交地址。如果还不行,那么这个移动节点
就无法工作了。
4.2.3 监测TCP进程和链路上所有数据包
假设移动节点可以得到一个配置转交地址,那么可以通过两种方
法来推断移动节点是否从一条没有代理的链路移动到了另一条链路上。
第一种方法,在它已打开的TCP连接上检查最近有没有转发进
行。如果没有,则说明移动节点在上一次注册后它已经移动过了。
第二种方法,移动节点可以将它的网络接口驱动置于接收所有包
的模式。在这种模式下,移动节点可以检查链路上的所有包,而不只是发给它的包。如果这些包中
没有一个网络前缀与它的转交地址的网络前缀一样,它就可以推断它已从获得转交地址的那条链路
移动到一条新链路上了。此时移动节点应得到一个新的转交地址并向它的本地代理注册。当然,移
动节点必须知道各种链路的前缀长度才可判断它转交地址的网络前缀与当前链路的网络前缀是否相
等。
5、总结
本文讨论了移动IP的基本概念和工作原理及其移动检测技术。
移动检测即移动节点判断它是连在本地链路还是外地链路上以及在不同链路上进行切换的过程。移
动节点接收由本地代理和外地代理周期发送的代理广播消息,它也可以通过发送代理请求得到广播
消息。
根据两种链路上有无代理广播消息,移动检测可按两种情况进
行。
移动节点可以接收代理广播消息时,移动检测有两种方法。第一
种方法是用生存时间域作检测,移动节点可以在任何情况下采用这种方法。第二种方法利用网络前
缀作检测,这要求代理在它们的代理广播消息中加入前缀长度扩展部分。
如果移动节点连接的链路上没有代理广播消息,那么移动节点可
以利用传输层和数据链路层来判定它当前的位置,从而通过DHCP或手工配置得到一个转交地址,
从而实现不中断的通信。
<完
>
<%=neirong%>作者
简介:马艳峰,330008 江西省数据通信局工程技术部;黄 鹂,400065
重庆邮电学院电子信息工程系。
上一篇:虚拟仪器网络测控系统平台
下一篇:网管接口测试及其相关技术问题