《2022年毕业设计方案9 .docx》由会员分享,可在线阅读,更多相关《2022年毕业设计方案9 .docx(50页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选学习资料 - - - - - - - - - 扬州市职业高校毕业设计论文)1 / 28 名师归纳总结 - - - - - - -第 1 页,共 28 页精选学习资料 - - - - - - - - - 设计 论文) 题目:基于 NS2 的泛洪路由协议的实现与仿真的设计系 别: 电子工程系专 业: 通 信 技 术班 级: 09 通信 3 )班学 号: 0906020306姓 名: 丁威指导老师:丁 晨 阳完成时间: 2022-04-29 2 / 28 名师归纳总结 - - - - - - -第 2 页,共 28 页精选学习资料 - - - - - - - - - 目 录1 绪论 5 2NS-
2、2 结构与功能 7 2.1 NS-2 的原理概述 7 2.1.1 离散大事模拟器 7 2.2.2 丰富的构件库 8 2.1.3 分裂对象模型 82.1.4 开放的源代码 82.2 NS 进行网络模拟的方法和一般过程 9 2.3 分裂对象模型和 Tc1CL 9 2.4 NS 基础 10 2.5 与 NS-2 相关几个常用工具 12 2.6 Otcl 实现模拟的一般过程 14 3Aod Hoc 网络的简洁介绍 15 3.1Ad Hoc 网络的概念 15 3.2 Ad Hoc 网络的主要特点 15 3.3 Ad Hoc 网络的结构 16 4 泛洪路由协议的设计实现 17 4.1 泛洪路由协议 17
3、4.2 添加路由协议类 17 4.3 定义包头类型 18 4.4 添加/ 修改源文件 18 4.5 编译代码 19 5 泛洪路由协议的仿真测试 19 5.1 初步测试 19 3 / 28 名师归纳总结 - - - - - - -第 3 页,共 28 页精选学习资料 - - - - - - - - - 5.2 场景测试 24 6 总结 26 致谢 27参考文献 28 4 / 28 名师归纳总结 - - - - - - -第 4 页,共 28 页精选学习资料 - - - - - - - - - 摘要 网络模拟是进行网络技术争论的一种基本手段;争论过程中,由于各种缘由,实际网络系统的实现往往是现代较
4、高或是不现实 的;在这种情形下,模拟就成了正确可供挑选的测试 ,评估和验证手 段之一;网络模拟有着周期小,成本低等特点,而且可以是争论者 更简洁理应他人的争论成果,可以是争论者更专心于自己所争论的 部分而不必为系统的其他部分耗费过多精力;关键词 NS ;网络模拟;Ad Hoc;无线自组网;路由协议;仿真;性能分 析第一章 绪论1.1 背 景 网络模拟是进行网络技术争论的一种基本手段;在新技术的争论过程中,由于 各种缘由,实际网络系统的实现往往是代价较高或是不现实的;在这种情形5 / 28 名师归纳总结 - - - - - - -第 5 页,共 28 页精选学习资料 - - - - - - -
5、- - 下,模拟就成了正确可供挑选的测试、评估和验证手段之一;网络模拟有着周 期小、成本低等特点,而且可以使争论者更简洁利用他人的争论成果;NS2 正是这样一种针对网络技术的源代码公开的、免费的软件模拟平台;它是美国 DARPA支持的工程VINTVirtual InterNet Testbed)开发的通用的多协议网络模拟软件,其中集成了大量典型的有线、无线甚至卫星网络下各个层的 协议,同时 NS 广泛的用户又在不断地对这个系统进行完善和修改;正是由于 NS2的这种开放性,使争论者更好的进行各种算法的实现和协议的改进;Ad Hoc 网络是一组具有无线收发装置的移动节点组成的一个多跳的暂时性的 自
6、组织系统,具有以下一些主要特点:动态拓扑,即网络中的节点可以任意移 动,因此,网络的拓扑结构也可能会变化;链路带宽受限、容量时变,由于拓 扑动态变化导致每个节点转发的非自身作为目的地的业务量随时间而变化,因 此与有线网络不同,它的链路容量表现出时变特点;动力受限,能量受限,由 于网络节点的移动特点,其中大多数节点以电池作为动力,在进行系统设计时 节能就成为一个特别重要的指标;物理上安全有限,移动网络比固定网络 开头编写 Otc1 脚本;第一配置模拟网络拓扑结构,此时可以确定链路的基 本特性,如推迟、带宽和丢失策略等 2建立协议代理,包括端设备的协议绑定和通信业务量模型的建盆 3配置业务量模型的
7、参数,从而确定网络上的业务量分布;4设置 Trace 对象; Trace 对象能够把模拟过程中发生的特定类型的大事记录 在 trace 文件中; NS通过 trace 文件来储存整个模拟过程;仿真完成后,用户 可以对 trace 文件进行分析争论;5编写其他的帮助过程,设定模拟终止时间,至此 6用 NS说明执行刚才编写的 Ote1 脚本Owl脚本编写完成;7对 trace文件进行分析,得出有用的数据;也可以用N-等工具观看网络模拟运行过程8调整配置拓扑结构和业务量模型,重新进行上述模拟过程;2.3 分裂对象模型和 Tc1CL Tc1 和 OIL Ta 是一种说明执行的简洁的脚本语言;其说明器是
8、用 c+编写的,具有很强的可扩展性;只要用户增加相应的说明执行模块的程序,就可扩展出新的命令;为了进一步增强编程的敏捷性,提高程序的效率,我们需要把Owl 和 C+结合起来;为了能充分发挥Otc1 和 C+这两种面对对象语言的强大才能,我们需要一种机制,使得在 C+中能直接调用 Owl 说明器的功能, Owl 和C+能够相互直接操作对方定义的数据,并且 C+中的类可以和 Owl 中的类对应9 / 28 名师归纳总结 - - - - - - -第 9 页,共 28 页精选学习资料 - - - - - - - - - 起来;这种机制就是 Tc1CL;NS正是利用了 TOCL建立起分裂对象模型,形成
9、了其丰富的构件库;通过这种机制,一;2.4 NS 基础NS 与网络模拟NS 达到了模拟配置敏捷性和运行效率的统NS是一个大事 event 驱动的模拟器,日前 NS支持 2 种类型的大事调度器 :非实时的none real-nine和实时的 real-time.非实时的调度器又分为3 种:linked-list, heap, calendar;NS 只支持单线程,故在某一时刻只能有一个大事在执行,假如有多于一个大事被支配在同一时刻,那么会依据大事代码插入的先后次序执行;list scheduler Scheduler/List类 是川一个简洁的链表结构实现的;大事依据时间次序排列,因此大事的插入
10、和删除都需要搜寻整个链表;_heap scheduler Scheduler/Heap类是用一个堆结构实现的,在大事很多时,这种结构比链表结构有优势;对于n 个大事, heap scheduler插入和删除操作的时间是 Olog n,calendar scheduler Scheduler/Calendar类是用一种类似于年历的数据结构来实现,年份不同但日月相同的时间可以记录在同一天中 : 相对于 heap scheduler 来说,它的执行效率更高 . 因此是目前 Ns中缺省的非实时事件调度器 . ;节点一个单播节点的基本结构如下列图,它主要包括两个对象 : 地址分类器address cla
11、ssifier 和端口分类器 port classifier,它们分别用来判定分组的目标地址以及分组的目标 Agents. 10 / 28 名师归纳总结 - - - - - - -第 10 页,共 28 页精选学习资料 - - - - - - - - - 单播节点的结构配置节点 配置节点就是在创建节点之前定义它的各种属性,函数 Simulator node-comfit 用来配 置节点的属性;节点的属性包括节点的地址类型、移动节点的各个网络构件的类型、 ad-b. 网络中移动节点的路由协议类型、是否打开各层Agent. Router. MAC的trace 功能等等;分类器 classifier
12、 收到一个分组后,节点需要检查分组的某些区域 大多数情形下是检查目的地址,某些时候会检查源地址 ,然后查找与这个区域的值相匹配的接收者;在NS中,这个下作由 Classifier 对象完成, NS 中有各种不同的Classifier对象,分别负责检查分组的不同部分,来完成不同的匹配、挑选工作 . 定时器11 / 28 名师归纳总结 - - - - - - -第 11 页,共 28 页精选学习资料 - - - - - - - - - 定时器 timer 既可以在 C-中实现也可以在Owl 中实现;在 c+中,各种定时器都是基于抽象基类的 定义于 ns/common/timer-handler,h
13、,它们常常用于 agent 对象中,但也可以被其他对象使用 . 分组头治理在 NS的网络模拟中,分组是对象间交互的基本单元;分组由一系列分组头和一个可选的数据空间组成 如图 5.8 所示 ;分组头的结构在Simulator对象创建时就被初始化了,同时每个分组头相对于分组的起始地址的偏移量也被记录下来;在缺省情形卜,大多数NS内建的分组头都是始能的 包括 common头、IP 头、 TCP头、 RTP头、 trace头等这意味着在缺省情形下无论某个分组头是否会被使用,它都会被初始化;当然用户也可以挑选只激活全部分组头中的一 部分,以节省模拟过程中的内存开销;在通常情形下,分组只含有系列分组头,而
14、指向数据空间的指针为 实的数据,但很少有上层应用和null ;虽然分组可以通过安排数据空间来携带真 agent 支持这一特性,由于一般来说在非实时的模拟中携带真实数据是没有意义的 . 应用层在 NS 中,应用层程序构建在运输层代理 transport agent 之上,它分为两 大 类 : 流 量 发 生 器 traffic generator 和 应 用 模 拟 器 simulated application 图 5.13 说 明 了 这 两 类 应 用 层 程 序 与 运 输 层 代 理 transport agent 之间的关系 : 流量发生器一股用在 TCP代理之上 . UDP代理之上
15、,应用模拟器一般用在Traffic generator Simulated application ApplicationTraffic Application/FTP ExponentiaAPI API Agent/UDP Agent/TCP/pull 应用程序与运输层之间的关系12 / 28 名师归纳总结 - - - - - - -第 12 页,共 28 页精选学习资料 - - - - - - - - - 2.5 与 NS-2 相关几个常用工具1)gawk gawk 是一种程序语言,对于资料的处理具有很强的功能,可以使用很短的代码轻易地完成对文本档案做修改、分析、提取和比较等处理;假如使用
16、 C 或Pascal 等语言编写程序完成 代码;2)gnu plot L 述的功能,可能需要花费较多的时间编写很长的Gnu plot是一个命令驱动的交互式画图软件,gnu plot的功能就是把数据资料和数学函数转换成简洁观看的平面或立体的图形,帮忙争论者进行数据分 析因此 gnu plot 并不是一般常见的美工绘图软件,它最适合的是在科学争论的 过程中,帮忙争论人员完成数据资料绘制与理论模型比较等机械化的工作,来 加速争论;,可以产生TCP流或者 CBR流Constant Bytes Rate Stream ; 它 所 在 目 录 为ns/indep-utils/cmu-scen-gen, 只
17、 有cbrgen.tcl一个文件口 cbrgen. 后挑选另一个目的地随机挑选一个速度连续运动 . .Threshold工具就是用来运算在某种传播模型下,如何设定接收功率阈值来掌握无线传输的范畴;13 / 28 名师归纳总结 - - - - - - -第 13 页,共 28 页精选学习资料 - - - - - - - - - 调试技术 写程序的人都知道, bug 是在所难免的,通过调试程序排除程序中的 bug 是编 程序的一个特别重要的步骤;在整个程序开发周期中,调试所花的时间往往 .断 据了极大的比例采纳什么样的调试技术、工具和手段往往打算了整个程序开发 周期的长短以及最终程序的质量;所以调
18、试技术是特别位得重视的一个环节 . 2.6 Otcl 实现模拟的一般过程 1 )建立 network model: 如推迟、带宽和丢失策略等;描述模拟网络拓扑结构,确定链路的基本特性,2)建立traffic model: 包括端设备的协议绑定和通信业务量模型的建立, 配置业务量模型的参数,从而确定网络上的业务量分布;3)设置 Trace 对象; Trace 对象能够把模拟过程中发生的特定类型的事件记录在 Trace 文件中; NS 通过 Trace 文件来储存整个模拟过程;模拟完成后,用户可以对 Trace 文件进行分析争论;4)编写其他的帮助过程,设定模拟开头 / 终止时间,运行 Otcl
19、脚本仿真;Ad Hoc 网络是一种分布式网络;Ad Hoc 网络又称为多跳网络multi-hop network、无固定网络设施的网络infrastructure less network、自组 Ad Hoc 网络是移动通信和运算机网络的交叉;在 Ad Hoc 网络中,使用运算机网络的分组交换机制,而不是电路交换机制;通信的主机一般是便携式运算机、个人数字助理PDA )等移动终端设备;Ad Hoc 网络不同于目前因特网环境中的移动 IP 网络;在移动 IP 网络中,移动主机可以通过固定有线网络、无线链路和拨号线路等方式接入网络,而在Ad Hoc 网络中只存在无线链路一种连接方式;在移动 过相邻
20、的基站等有线设施的支持才能通信,在基站和基站IP 网络中,移动主机通 无中心: Ad Hoc 网络没有严格的掌握中心;全部结点的位置公平,即是一个对等式网络;结点可以随时加入和离开网络;任何结点的故障不会影响整个网络的运行,具有很强的抗毁性;2自组织:网络的布设或绽开无需依靠于任何预设的网络设施;结点通过分层协议和分布式算法和谐各自的行为,结点开机后就可以快速、自动地组成一个独立的网络;3多跳路由:当结点要与其掩盖范畴之外的结点进行通信时,需要中间结点的多跳转发;与固定网络的多跳不同,网络结点完成的,而不是由专用的路由设备Ad Hoc 网络中的多跳路由是由一般的 动态拓扑: Ad Hoc 网络
21、是一个动态的网络;网络结点可以随处移动,也可以随时开机和关机,这些都会使网络的拓扑结构随时发生变化;15 / 28 名师归纳总结 - - - - - - -第 15 页,共 28 页精选学习资料 - - - - - - - - - 5独立性: Ad Hoc 网络相对常规通信网络而言,最大的区分就是可以在 任何时刻、任何地点不需要硬件基础网络设施的支持,快速构建起一个移动通 信网络;它的建立不依靠于现有的网络通信设施,具有肯定的独立性;6有限的无线通信带宽:在 Ad Hoc 网络中没有有线基础设施的支持,因 此,主机之间的通信均通过无线传输来完成;由于无线信道本身的物理特性,它供应的网络带宽相对
22、有线信道要低得多;除此以外,考虑到竞争共享无线信 道产生的碰撞、信号衰减、噪音干扰等多种因素,移动终端可得到的实际带宽 远远小于理论中的最大带宽值;7有限的主机能源:在Ad Hoc 网络中,主机均是一些移动设备,如PDA 、便携运算机或掌上电脑;由于主机可能处在不停的移动状态下,主机的 能源主要由电池供应,因此 Ad Hoc 网络有能源有限的特点;8有限的物理安全:移动网络通常比固定网络更简洁受到物理安全攻击,易于遭受窃听、欺诈和拒绝服务等攻击;现有的链路安全技术有些已应用于无线网络中来减小安全攻击;不过 具有肯定的抗毁性;3.3 Ad Hoc 网络的结构Ad Hoc 网络的分布式特性相对于集
23、中式的网络1结点结构: Ad Hoc 网络中的结点不仅具备一般移动终端的功能,而且 具有报文转发才能,即具备路由器的功能;因此,就功能而言可以将结点分为 主机、路由器和电台三部分;其中主机部分完成一般移动终端的功能,包括人 机接口、数据处理等应用软件;而路由器部分主要负责保护网络的拓扑结构和 路由信息,完成报文的转发功能;电台部分为信息传输供应无线信道支持;从 物理结构上分,结构可以被分为以下几类:单主机单电台、单主机多电台、多 主机单电台和多主机多电台;手持机一般采纳的单主机单电台的简洁结构;作 为复杂的车载台,一个结点可能包括通信车内的多个主机;多电台不仅可以用 来构建叠加的网络,仍可用作
24、网关结点来互联多个 Ad Hoc 网络;2 网络结构: Ad Hoc 网络的网络结构有平面结构和分级结构两种;当网 络的规模较小时,可以采纳简洁的平面式结构;而当网络的规模增大时,应用 分级结构;.平面结构:在平面结构中,全部结点的位置公平,所以又可以称为对等 式结构;平面结构的网络比较简洁,网络中全部结点是完全对等的,原就上不 存在瓶颈,所以比较健壮;它的缺点是可扩充性差:每一个结点都需要知道到 达其他全部结点的路由;保护这些动态变化的路由信息需要大量的掌握消息;.分级结构:分级结构中,网络被划分为簇;每个簇由一个簇头和多个簇 成员组成;这些簇头形成了高一级的网络;在高一级网络中,又可以分簇
25、,再 次形成更高一级的网络,直至最高级;在分级结构中,簇头结点负责簇间数据 的转发;簇头可以预先指定,也可以由结点使用算法自动选举产生;分级结构 的网络又可以被分为单频分级和多频分级两种;单频率分级网络中,全部结点 使用同一个频率通信;为了实现簇头之间的通信,要有网关结点 同时属于两个 簇的结点)的支持;而在多频率分组网络中,不同级采纳不同的通信频率;低 级结点的通信范畴较小,而高级结点要掩盖较大的范畴;高级的结点同时处于 多个级中,有多个频率,用不同的频率实现不同级的通信;在两级网络中,簇头结点有两个频率;频率1 用于簇头与簇成员的通信;而频率2 用于簇头之间16 / 28 名师归纳总结 -
26、 - - - - - -第 16 页,共 28 页精选学习资料 - - - - - - - - - 的通信;分级网络的每个结点都可以成为簇头,所以需要适当的簇头选举算 法,算法要能依据网络拓扑的变化重新分簇;在分级结构的网络中,簇成员的功能比较简洁,不需要保护复杂的路由信 息;这大大削减了网络中路由掌握信息的数量,因此具有很好的可扩充性;由 于簇头结点可以随时选举产生,分级结构也具有很强的抗毁性;分级结构的缺 点是,保护分级结构需要结点执行簇头选举算法,簇头结点可能会成为网络的 瓶颈;第四章泛洪路由协议的设计实现当用户需要一个全新的算法或协议时,就需要对NS2 进行类型的扩展这种扩展的典型特点
27、就是需要一个分组头来实现算法或协议,本章的重点是算法 或协议的添加,并不是算法或协议的本身的争论;4.1 泛洪路由协议泛洪法是一种简洁的路由挑选技术;这种技术不需要任何网络信息 , 一个 分组由源结点发送到与其相邻的每一个结点,在各个结点上,收到的分组再次被传输到与其相邻的各个结点;泛洪法具有三个属性:A:在源结点与信宿结点之间全部可能的路由都被尝试过;B:分组中至少有一个副本使用的是最小跳数路由到达信宿;C:全部直接或间接与源结点相连的结点全部被拜访到 . 4.2 添加路由协议类路由协议类为MFlood,路由表类为MFlood_Rtalbe, 由一条条路由表项MFlood_RTEntry 类
28、)组成,其中每一条路由表项针对每个数据源记录了为它 转发过的数据包情形; MFlood 协议为每个节点保护一个序列号 SEQ,数据源每 发送一个数据包将 SEQ增加,并把该序列号添加到数据包的包头信息中,其 他节点收到一个数据包后依靠序列号来判定自己是否转发过该包;在 NS2中, 全部路由协议都是从Agent 类继承而来的 , 和 UPD及 TCP等传输层协议以及 CBR等应用层协议一样 . 虽然如此 ,NS2 很好地实现了层的概念 , 应用层和传输层的数据回交到路由协议进行处理, 接收也是先由路由协议处理后, 再17 / 28 名师归纳总结 - - - - - - -第 17 页,共 28
29、页精选学习资料 - - - - - - - - - 由一层层送交各上层协议 . MFlood 路由协议需要被NS2接纳并可以在tcl代码中使用,仍需要其它定义;其中 AGENT/Mflood指定了 C+中的 Mflood 类和 TcL 部分的 AGENT/Mflood绑 定 在 一 起 , 在 编 写TcL 测 试 代 码 时 指 定 路 由 协 议 时 就 应 该 使 用AGENT/Mflood;AGENT/Mflood表示了一个继承关系,即 Mflood 继承于 AGENT;4.3 定义包头类型泛洪协议中并没有定义自己的掌握包,但是为了进行重复包检测,同样需要定义自己的包头,将序列号存在这个包头中;虽然Mflood 的包头特别简洁,仅仅需要储存一个序列号,可以同样需要实现NS2规定的功能;在hdr-mflood结构的定义中, offset和 access 都是系统所要求的,只需要作相应的修改;HDR-MFL