无线自组织网络aodv协议的仿真

上传人:第*** 文档编号:38908492 上传时间:2018-05-09 格式:DOC 页数:13 大小:753KB
返回 下载 相关 举报
无线自组织网络aodv协议的仿真_第1页
第1页 / 共13页
无线自组织网络aodv协议的仿真_第2页
第2页 / 共13页
无线自组织网络aodv协议的仿真_第3页
第3页 / 共13页
无线自组织网络aodv协议的仿真_第4页
第4页 / 共13页
无线自组织网络aodv协议的仿真_第5页
第5页 / 共13页
点击查看更多>>
资源描述

《无线自组织网络aodv协议的仿真》由会员分享,可在线阅读,更多相关《无线自组织网络aodv协议的仿真(13页珍藏版)》请在金锄头文库上搜索。

1、 第 1 页 共 13 页无线自组织网络 AODV 协议的仿真【实验目的】 在 NS-2 仿真 AODV 协议,并在 trace 文件中了解 AODV 协议的原理。【实验原理】1、AODV 简介 AODV 是由 Nokia 研究中心的 CharlesE.Perkins 和加利福尼亚大学 SantaBarbara 的 ElizabethM.Belding-Roryer 以及 Cincinnati 大学 SamirR.Das 等共同开发,已经被 IETFMANET 工作组于 2003 年 7 月正式公布为自组网路由协议的 RFc 标准。AODV 实质 上就是 DSR 和 DSDV 的综合,它借用了

2、 DSR 中路由发现和路由维护的基础程序,及 DSDV 的逐跳(Hop-by-Hop)路由、目的节点序列号和路由维护阶段的周期更新机制,以 DSDV 为基础,结合 DSR 中的按需路由思想并加以改进。 AODV 在每个中间节点隐式保存了路由请求和应答的结果,并利用扩展环搜索的办法 来限制搜索发现过的目的节点的范围。AODV 支持组播功能,支持 QoS,而且 AODV 中 可以使用 IP 地址,实现同 Internet 连接,但是不支持单向信道。和 DSDV 保存完整的路由 表不同的是,AODV 通过建立基于按需路由来减少路由广播的次数,这是 AODV 对 DSDV 的重要改进。和 DSR 相比

3、,AODV 的好处在于源路由并不需要包括在每一个数据分组中, 这样会使路由协议的开销有所降低。AODV 是一个纯粹的按需路由系统,那些不在路径内 的节点不保存路由信息,也不参与路由表的交换。AODV 协议可以实现在移动终端间动态 的、自发的路由,使移动终端很快获得通向所需目的的路由,同时又不用维护当前没有使 用的路由信息,并且还能很快对断链的拓扑变化做出反应。AODV 的操作是无环路的,在 避免了通常 Bellman-ford 算法的无穷计数问题的同时,还提供了很快的收敛速度。AODV 的路由表中每个项都使用了目的序列号(DestinationSequenceNumber)。目的序列号是目的节

4、 点创建,并在发给发起节点的路由信息中使用的。使用目的序列号可以避免环路的发生。 AODV 使用 3 种消息作为控制信息:RouteRequest(RREQ),RouteReply(RREP)和 RouteError(RERR)。这些消息都在 UDP 上使用 654 端口号。 当源节点需要和目的节点通信时,如果在路由表中已经存在了对应的路由时,AODV 不会进行任何操作。当源节点需要和新的目的通信时,它就会发起路由发现过程,通过广 播 RREQ 信息来查找相应路由。当这个 RREQ 到达目的节点本身,或者是一个拥有足够新 的到目的节点路由的中间节点时,路由就可以确定了。所谓“足够新”就是通过目

5、的序列 号来判断的。目的节点或中间节点通过原路返回一个 RREP 信息来向源节点确定路由的可 用性。在维护路由表的过程中,当路由不再被使用时,节点就会从路由表中删除相应的项。 同时,节点会监视一个活动路由(activeroute,有限跳的,可用于数据转发的路由表)中,下 一跳节点的状况。当发现有链路断开的情况时,节点就会使用 RERR 通知上游的节点,而 上游的节点就会使用该 RERR 分组拷贝通知更上游的节点。在 RERR 消息中,指明了由于 断链而导致无法达到目的节点。每个节点都保留了一个“前驱列表”(precursorlist)来帮助 完成错误报告的功能,这个列表中保存了把自己作为到当前

6、不可达节点的下一跳的相邻节 点(可以通过记录 RERR 很容易地获得)。在路由表中,针对每一个表项,需要记录相应的 的特征内容。其中,序列号是防止路由环路的关键所在。当发生断链时,通过增加序列号第 2 页 共 13 页和度量值(跳数)来使路由表项无效。 2、AODV 路由协议的运行方式(a)AODV 路由发现 AODV 路由协议是一种典型的 按需驱动路由协议,该算法可被称为纯粹的需求路由获取系统,那些不在活跃路径上的节 点不会维持任何相关路由信息,也不会参与任何周期路由表的交换。此外,节点没有必要 去发现和维持到另一节点的路由,除非这两个节点需要进行通信。移动节点间的局部连接 性可以通过几种方

7、法得到,其中包括使用局部广播 Hello 消息。这种算法的主要目的是:在 需要时广播路由发现分组一般的拓扑维护;区别局部连接管理(邻居检测)和一般的拓扑维护; 向需要连接信息的邻居移动节点散播拓扑变化信息。AODV 使用广播路由发现机制,它依 赖中间节点动态建立路由表来进行分组的传送。为了维持节点间的最新路由信息,AODV 借鉴了 DSDV 中的序列号的思想,利用这种机制就能有效地防止路由环的形成。当源节点 想与另外一个节点通信,而它的路由表中又没有相应的路由信息时,它就会发起路由发现 过程。每一个节点维持两个独立的计数器:节点序列号计数器和广播标识。源节点通过向自 己的邻居广播 RREQ(R

8、outeRequests)分组来发起一次路由发现过程。(b)反向路由的建立在 RREQ 分组中包含了两个序列号:源节点序列号和源节点所知道的最新的目的序列号。源节 点序列号用于维持到源的反向路由的特性,目的序列号表明了到目的地的最新路由。当 RREQ 分组从一个源节点转发到不同的目的地时,沿途所经过的节点都要自动建立到源节 点的反向路由。节点通过记录收到的第一个 RREQ 分组的邻居地址来建立反向路由,这些 反向路由将会维持一定时间,一该段时间足够 RREQ 分组在网内转发以及产生的 RREP 分 组返回源节点。当 RREQ 分组到达了目的节点,目的节点就会产生 RREP 分组,并利用建 立的

9、反向路由来转发 RREP。(c)正向路由的建立 RREQ 分组最终将到达一个节点,该 节点可能就是目的节点,或者这个节点有到达目的节点的路由。如果这个中间节点有到达 目的的路由项,它就会比较路由项里的目的序列号和 RREQ 分组里的目的序列号的大小来 判断自己已有的路由是否是比较新的。如果 RREQ 分组里的目的序列号比路由项中的序列 号大,则这个中间节点不能使用己有的路由来响应这个 RREQ 分组,只能是继续广播这个 RREQ 分组。中间节点只有在路由项中的目的序列号不小于 RREQ 中的目的序列号时,才 能直接对收到的 RREQ 分组做出响应。如果节点有到目的地的最新路由,而且这个 RRE

10、Q 还没有被处理过,这个节点将会沿着建立的反向路由返回 RREP 分组。在 RREP 转发回源节点的过程中,沿着这条路径上的每一个.节点都将建立到目的节 点的同向路由,也就是记录下 RREP 是从哪一个邻居节点来的地址,然后更新有关源和目 的路由的定时器信息以及记录下 RREP 中目的节点的最新序列号。对于那些建立了反向路 由,但 RREP 分组并没有经过的节点,它们中建立的反向路由将会在一定时间(Active- Route-Timeout)后自动变为无效。收到 RREP 分组的节点将会对到某一个源节点的第一个 RREP 分组进行转发,对于其后收到的到同一个源的 RREP 分组,只有当后到的

11、RREP 分 组中包含了更高的目的序列号或虽然有相同的目的序列号但所经过的跳数较少时,节点才 一会重新更新路由信息,以及把这个 RREP 分组转发出去。这种方法有效地抑制了向源节 点转发的 RREP 分组数,而且确保了最新及最快的路由信息。源节点将在收到第一个 RREP 分组后,就开始向目的节点发送数据分组。如果以后源节点了解到的更新的路由, 它就会更新自己的路由信息。 3、AODV 路由表的管理 节点的路由中除了存储源和目的节点的序列号外,还存 储了其他有用的信息,这些信息成为有关路由项的软状态。与反向路由相关的是路由请求 定时器,这些定时器的目的是清除一定时间内没有使用的反向路由项。定时器

12、的设置依赖 于自组网的规模大小,与路由表相联系的另外一个重要的参数是路由缓存时间,即在超过 这个时间之后,对应的路由表就变为无效。此外,在每一个路由表中,还要记录本节点用 于转发分组的活跃邻居。如果节点在最近一次活跃期间(Active-Timeout)发起或转发了到某第 3 页 共 13 页个目的节点的分组,那么就可以称这个节点为活跃节点。这样,当到达某一个目的节点的 链路有问题时,所有与这条链路有关的活跃节点都可以被通知到。一个路由表还有活跃邻 居在使用,就可以认为是有效的。通过各个活跃路由项所建立的源节点到目的节点的路径, 也就是一条活跃路径。路由表中的目的节点序列号,正如在 DSDV 路

13、由协议中所使用的那 样,可以在无序分组的传送和节点高度移动的极端条件下避免路由环路的产生。移动节点为每一个相关的目的节点维护了一个路由表。每一个路由表包含以下一些 信息:目的地址、下一跳地址、跳数、目的序列号及路由项的生存时间。路由表在每一次被 用来传送一个分组时,它的生存时间都要重新开始计算,也就是用当前时间加上 Aetive- Route-Timeout。如果一个移动节点被提供了到达某一个目的节点的新路由,那么它就会把 这个新路由的目的序列号与自己路由表中己有的目的序列号做比较,并将目的序列号大的 作为到达目的节点的路由表。如果目的序列号相同,则采用到目的节点所经过的节点数(跳 数)最少的

14、那个路由。 4、AODV 路由维护如果节点的移动不是沿着活跃路径进行的,那么就不会影响己经 建立的路由。如果一个源节点在活跃路径上移动,它就要向目的节点重新发起一次路由发 现过程。如果移动的节点是中间节点或目的节点,那么一个特殊的 RREP 分组将转发到那 些受移动影响的源节点。周期性发送的 Hello 分组可以用来确保链路的对称性,并检测不 能用的链路。如果不用 Hello 分组,也可以采用链路层通告机制来报告链路的无效性,这 样可以减少延迟。此外,节点在尝试向下一跳节点转发分组失败后,也能检测出链路的不 可用性。 一旦一个节点的下一跳节点变得不可达,这时它就要向利用该损坏链路的活跃上游节

15、点发送未被请求的 RREP(RERR)分组,这个 RREP(RERR)分组带有一个新的序列号(即 在目的序列号上加 1),并将跳数值设置为二。收到这个 RREP(RERR)分组的节点再依次将 RREP(RERR)分组转发到它们各自的活跃邻居,这个过程持续到所有的与损坏链路有关的 活跃节点都被通知到为止。源节点在收到断链的通知后,如果它还要与目的节点联系,它 就需要再次发起新的路由发现过程。这时,它将会广播一个 RREQ 分组,这个 RREQ 分组 中的目的序列号要在源节点已知的最新目的序列号之上加 1,以确保那些还不知道目的节 点最新位置的中间节点对这个 RREQ 分组做出响应,从而能保证建立

16、一条新的、有效的路 由。 5、AODV 协议评价。总之,AODV 是一种距离矢量路由协议,采用的算法克服了以 前提出的一些算法(如 DSDV)的缺点,具有如下优点:(a)基于传统的距离向量路由机制, 思路简单、易懂。(b)支持中间节点应答,能使源节点快速获得路由,有效减少了广播数, 但存在过时路由问题。(c)节点只存储需要的路由,减少了内存的需求和不必要的复制。(d) 快速响应活跃路径上断链。(e)通过使用目的序列号来避免路由环路,解决了传统的基于距 离向量路由协议存在的无限计数问题。(f)具有网络的可扩充性。(g)需要周期性地广播分组, 需要消耗一定的电池能源和网络带宽。与 DSDV 以及其他持续存储更新路由信息的算法相 比,AODV 需要相对较长的路由建立时延,不过 AODV 采取了以下的一些措施来加以改善: (a)到某个目的节点的路由可以由知道路由的中间节点进行响应。(b)链路失效能够被立即报 告,这样路由可重新建立。(c)不活跃的路由在一定时间后会被删除。【实验过程】1、使用、使用 cbrgen 产生产生 traffic pattern。这个实验由。这个实验由 10

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号