• 易迪拓培训,专注于微波、射频、天线设计工程师的培养
首页 > 无线通信 > 技术文章 > 基于NS-3的MANET路由协议性能分析

基于NS-3的MANET路由协议性能分析

录入:edatop.com     点击:

NS-3在多网卡处理和IP寻址策略方面具有很的好特性,为了提高MANET路由协议性能,采用了NS-3仿真工具对MANET路由协议进行分析,详细阐述了如何搭建NS-3仿真平台,并从网络规模和动态拓扑角度分析比较了AODV,DS-DV和OLSR三种路由协议的端到端平均时延和投递率性能。仿真结果为协议的后续优化和改进提供了依据。

0引言

随着网络技术和通信技术的蓬勃发展,如何在硬件条件不具备的情况下研究大规模网络,如何快速设计。实现。分析新的协议和算法,如何比较新老系统和算法而不必花费巨资建立实际系统等问题日益成为网络研究者关注的焦点。近年来,盛行的方式是通过计算机软件对网络协议。网络拓扑。网络性能进行模拟分析。采用这种网络仿真的研究方法,降低了成本,研究方法灵活可靠,提高了研究效率。现在主流的网络仿真工具主要有:OPNET,QualNet,NS-2.OPNET是商业软件,软件所提供的模型库比较有限,而且主要集中于路由仿真。QualNet也是一款商业软件,弱化了网络分层的概念。NS-2的内容比较庞杂,各模块间的协同及耦合不便于系统扩展。为此,在广泛汲取现有网络模拟器的成功经验基础上,美国华盛顿大学Thmos R. Henderson教授及其小组研发了一款极具特色的新型网络仿真器——NS-3.相比其他网络仿真工具,NS-3是一款开源软件,在多网卡处理和IP寻址策略方面表现出更好特性,同时,NS-3的架构也相对更明了清晰,代码不需做很大修改就可直接移植到真实网络节点上,此外,研究者可根据自身需求进行任意拓展。

1 MANET路由协议分析

移动无线自组织网络(MANET)是一种无中心。自组织的分布式多跳网络,MANET以其固有特点在某些特殊场景(如:救灾。战争等)中得到了广泛运用。路由协议的好坏直接影响到整个网络性能的优劣。这里简要介绍MANET中应用比较广泛的3种平面路由协议。DSDV(Destination-Sequenced Distance Vector)是一种表驱动路由协议,它是在传统的距离矢量DV算法基础上改进设计的,同时也被称为消除环路的Bellman-Ford路由算法。DSDV算法中每个节点都维护一张到达全网可达目的节点的路由表。相比DV算法,DSDV最大的区别是路由中增加了目的系列号(Sequence Number)字段,通过序列号来区别新旧路由信息。节点将收到新路由信息和当前路由信息比较,选择序列号较大的路由记录来更新路由表。若两者序列号相同,则选择跳数较小者。

此外,全网节点要求周期性广播路由包来进行路由维护。AODV(Ad Hoc On-Demand Distance Vector)是一种源驱动的路由协议[5],是DSR协议结合了DSDV中的按需路由机制设计出来的。节点在发送数据包时,首先查找自己路由表是否有到达目的节点的路由信息,若有,则直接按照路由信息发送;若没有,则执行路由发现过程。节点广播路由请求包RREQ给自己邻居,邻居收到RREQ包后查询自己路由表是否有到达目的节点路由信息,若有或本身就是目的节点,则将路由信息添加到路由应答包RREP,并将其反馈给源节点;若没有,再将RREQ转发给自己所有的邻居。依次类推,直到到达目的节点或中间节点存在到达目的节点的路由。

AODV协议通过定期广播Hello分组来进行路由维护,一旦发现了某条通信链路断开,节点就会在DE-LEte_PERIOD时间之后从路由表中删除包含该断开链路的路由,并发送ERROR(路由错误)报文来通知那些因为链路断开而不可达的节点删除相应的路由记录或者对已经存储的路由信息进行修复更新。

OLSR(Optimized Link State Routing)是一种优化的链路状态路由协议,类似其他表驱动路由协议,节点需要周期性交互网络路由信息。被邻居节点选作中继节点(Multi Point Telay,MPR)的节点周期性向网络广播控制信息分组,分组中包括将它选作MPR的那些节点的信息,以告诉网络中其他节点与这些节点之间相连。而且,只有MPR节点才能够作为路由节点,其他非MPR节点不参与路由计算,也不需转播控制信息。OLSR协议中主要通过HELLO和TC(Topological Control)两种控制消息来感知广播拓扑。通过HELLO消息实现链路侦测。邻居侦听,以此建立节点的本地链路信息表,同时用于向邻居节点通告本节点的多点中继MPR节点的选择;TC消息负责执行MPR Selector链路状态声明,使得每个节点都能够感知全网拓扑结构。最终,节点根据本地链路信息库和拓扑集合中的信息,采用Dijkstra算法根据路径最短的原则计算路由表。

2 NS-3仿真平台搭建

2.1 NS-3仿真架构

NS-3是一款离散型模拟器,NS-3的网络架构主要由模拟器内核和网络构件2部分组成,如图1所示。其中模拟器内核包括时间调度器和网络模拟支持系统,是NS-3最核心的部分。相比NS-2,NS-3仿真时间不仅支持Default Scheduler,而且还支持Realtime Scheduler.

NS-3的网络模拟支持系统包括:Attribute系统。Logging系统和Tracing系统。由于广泛汲取了其他网络仿真工具的经验和技术,NS-3的内核在可量测性。可扩展性。模块化。支持仿真与现实融合等方面具有极大优势。NS-3的网络构件包括:节点(Node)。应用(Application)。协议栈(Protocol Stack)。网络设备(Net Device)。信道(Channel)。拓扑生成器(Helper)等。网络构件是对真实网络的各个部分的抽象,具有低耦合高内聚特点,NS-3通过低层次的抽象,使得仿真效果尽可能反映真实网络的性能。

2.2 NS-3仿真流程

以下简单介绍NS-3代码编写的特点及如何在NS-3中搭建一个完整仿真场景的过程。NS-3运行在Linux环境下,对Linux系统版本有要求且依赖较多系统组件,安装过程较复杂。NS-3仿真器代码核心部分全部使用C++语言编写,外部配置。编译。执行使用了基于Python的waf系统,方便使用者配置仿真场景。NS-3完全模拟了TCP/IP的协议栈,并且把每一层的功能模块化,在NS-3安装完成后,默认只是生成各个功能模块,自带的仿真例子没有生成,需要把这些例子复制到scrach文件夹下才能运行,并且NS-3中编写好的代码也都需要放到该文件夹下才能运行。在NS-3中搭建仿真场景遵循固定的流程,在编写C++代码时一般可以分为以下几个步骤:

(1)设置仿真场景的全局参数。比如采用Seed-Manager::SetSeed(7)设置随机数种子,以保证产生相同的随机序列,设置随机平面移动模型(Random-Walk2dMobilityModel)的参数Config::SetDefault("NS-3::RandomWalk-2dMobilityModel::Mode",StringValue("Tim-e"))等,以上的全局设定使得仿真场景可以重现。

(2)定义仿真中使用的参数,比如数据包的大小,需要创建的节点个数,物理层使用的传输速率等,这些参数可以使用CommandLine类来实现并解析,方便在仿真过程中使用外部脚本动态改变这些参数。

(3)创建网络节点,然后按照TCP/IP协议,从下而上给网络节点安装协议栈。NS-3在实现中考虑到为了方便使用者,协议栈的每一层都实现了帮助类(XXX-Helper),使用者可以方便地使用这些帮助类设定每一层参数。比如使用YansWifiPhyHelper设定物理层协议,使用YansWifiChannelHelper来设置传输信道类型,使用NqosWifiMacHelper来设置数据链路层协议等。最后通过帮助类给节点安装路由协议,分配IP地址,至此便搭建了TCP/IP的物理层。数据链路层和网络层,实现网络的通信功能。

(4)通信网络搭建好后,需要编写实验程序,即在节点之间的收发数据包的代码,以达到测试底层协议的目的。NS-3中为了减少使用者的编程工作量,同样提供了丰富易用的函数,一般都是先创建使用UDP协议套(Socket),同时把接收节点号。发送节点号作为参数传入,再给套接字指定IP地址,端口号,最后让发送节点连接到接收节点。为接收节点指定回调函数。

(5)完成节点之间如何发送数据包的代码后,需要编写接收节点的回调函数,即在接收节点收到数据包后调用的函数。可以在回调函数中对数据包的时延,投递率进行统计。

(6)使用Simulator::Schedule函数设定调度事件即设定源节点的发送数据的开始时间,发送间隔,发送数据包总数等。至此,整个场景部署完成。

上一篇:华为超长距离光纤传输MSTP系列产品方案
下一篇:数据中心的核心:飞思卡尔通信处理技术,助用户“一马当先”

手机天线设计培训教程详情>>

手机天线设计培训教程 国内最全面、系统、专业的手机天线设计培训课程,没有之一;是您学习手机天线设计的最佳选择...【More..

射频和天线工程师培训课程详情>>

  网站地图