《毕业设计(论文)基于SIP业务模拟器工具设计和研究.doc》由会员分享,可在线阅读,更多相关《毕业设计(论文)基于SIP业务模拟器工具设计和研究.doc(27页珍藏版)》请在三一办公上搜索。
1、 本科生毕业设计(论文)题 目: SIP业务模拟器工具的 设计与研究 姓 名: 学 号: 学 院: 数学与计算机科学学院 专 业: 信息与计算科学 年 级: 2007级 指导教师: (签名)2011 年 06 月16 日 SIP业务模拟器工具设计和研究中文摘要本文讨论了关于下一代网络(NGN)的应用开发的问题,它是基于SIP业务的开发,SIP(会话初始化协议)的开发目的是用来帮助提供跨越因特网的高级电话业务。本文设计了一个SIP呼处理的模拟器。开始描述了SIP基本术语,所需要的基本原理以及模拟器工具的系统架构,并使用MFC开发出相关的界面。接着对于呼处理的模块设计,其需要两部分完成,一个是SI
2、P消息本身的解析模块设计,另一个是SIP消息脚本的解析模块设计。对于SIP消息本身的解析模块设计,采用了按行的解析算法思想以及C+实现,和按字节的解析算法思想相比,即保证了消息的完整性又具有整体直观性,也提高了程序的运行效率。而SIP消息脚本通过XML编写,故是实现XML脚本的解析,此解析算法思想是采用串行解析技术,并通过形成链表和树形结构,完成对关键字的提取。此模拟器工具是在Window 使用Visual C+ 6.0来实现,在Winsock的编程原理基础上,即客户机-服务器的通信模式,采用改进的流套接字编程方法,实现SIP基本呼叫建立过程。最后通过对此模拟器工具的进行了性能测试来说明其对验
3、证大量的准正常和异常case的效果。关键字:SIP消息、解析算法、呼处理 The development of simulative tool based on SIP professional work Abstract目 录中文摘要IIAbstractIII第1章 绪论11.1 背景知识11.2 SIP协议简介11.3 工具开发概要31.4 本文主要研究内容3第2章 系统架构及界面开发42.1 系统架构42.2 主界面及子界面5第3章 SIP消息解析模块设计93.1 SIP消息引言93.2 SIP消息解析策略及初步模型103.3 SIP解析模型改进11第4章 XML脚本解析模块设计134.
4、1 解析技术134.2 脚本格式及特点134.3 脚本解析模型及特点17第5章 模拟器测试及结果分析195.1 模拟器呼叫模块及结果195.2 性能测试及结果205.3 结果分析21结论21谢辞22参考文献23第1章 绪论1.1 背景知识随着VoIP(网络电话)的迅猛发展,通讯技术数字化已成为现代通信技术的基本特征和最突出的发展趋势。而网络的下一个发展目标就是NGN,NGN是下一代网络,又称为次世代网络,它使得新一代网络上语音、视频、数据等综合业务成为了可能。而SIP协议是NGN中的重要协议,SIP称为会话初始化协议,它的开发目的是用来帮助提供跨越因特网的高级电话业务。因特网电话正在向一种正式
5、的商业电话模式演进,SIP就是用来确保这种演进实现而需要的NGN序列协议中重要的一员。目前,单一的业务已经无法满足人们的需求了,而转变为一种综合的业务,它融合了文本数据业务、语音数据业务、多媒体视频数据业务。为了建设投资小、效益高、可共享的网络,以电话网为代表的电信网和以因特网为代表的数据网络的互通和融合进程正在快速发展。加上以前被我们视为瓶颈的带宽和服务质量问题已得到解决,大大推动了 IP 技术的发展,带动各种应用向 IP靠拢。SIP (Session Initiation Protocol,会话初始协议)是由 IETF ( The Internet Engi2neering Task Fo
6、rce,互联网工程任务组) 于1999 年提出的一个基于 IP 网络的一种实时通信应用信令协议1。因为 SIP协议具有Internet协议简单、灵活、扩展性好等特点,目前已得到越来越广泛的应用。因此,对基于 SIP业务的应用软件工具进行相关的开发及测试也就十分重要。1.2 SIP协议简介SIP(Session Initiation Protocol)会话初始协议是IETF制定的,用于多方多媒体的通信。SIP是一个基于文本的应用层控制协议,独立于底层传输协议TCP/UDP/SCTP,用于建立、修改和终止IP网上的双方或者多方多媒体会话。SIP协议借鉴了HTTP、SMTP等协议,支持代理、重定向及
7、登记定位用户等功能,支持用户移动。通过与RTP/RTCP、SDP、RTSP等协议及DNS配合,SIP支持语音、视频、数据、E-mail、状态、IM、聊天、游戏等。SIP 可以用来对会话进行初始化, 也可以邀请成员加入经其他手段建立或公布的会话。SIP 支持建立和终止多媒体通信方面的功能有:l 用户端定位( user locat ion):对在通信中使用的端系统的位置的确定。l 用户能力( user capabilties):决定在通信中要使用的媒体和媒体参数。l 用户可行性( user availability ):确定被呼叫方是否愿意加入通信。l 呼叫建立( call setup):呼叫方和
8、被呼叫方双方建立呼叫参数。l 呼叫处理( call handling):包括转移和结束呼叫。SIP的终端系统称为用户代理(User Agent,简称UA),含用户代理客户机UAC(User Agent Client)以及用户代理服务器UAS(User Agent Server)两部分,呼叫过程即是UAC和UAS通信的过程。一个呼叫建立过程如图1.1。用户代理客户端(UAC)用户代理服务器(UAS)INVITE180200ACKBYE200图1.1 SIP业务模拟器基本呼叫建立过程SIP协议把一个呼叫分为三个阶段:呼叫建立,呼叫保持,呼叫释放。图1.1所示的是一个呼叫建立的信令过程。首先要建立呼
9、叫信令信道,即一个UDP或者TCP连接。则,由服务器的IP地址和端口号建立客户端和服务器端之间的呼叫信令信道。然后,客户端向服务器端发送INVITE消息,如果服务器端同意建立呼叫,发送180、200消息,其中180状态码表示请求已经收到,正在处理中,200表示请求已经成功。此时,如果客户端突然不想参加此次会话,可以向服务器端发送BYE消息,此次呼叫结束;如果客户端仍然想参加此次会话,就向服务器端发送ACK消息,确认客户端已经收到了对INVITE请求的最终响应(200),经过三次握手机制后,基本呼叫建立完成,进入呼叫保持阶段。当双方通信一段时间后,任何一方可以发送BYE消息来结束此次会话的呼叫。
10、1.3 工具开发概要SipServer呼处理相关业务测试过程中需要验证大量的准正常和异常case,这些case在设备正常呼叫过程中很难出现,测试的难度较大。需要一种测试业务模拟工具,它实现了UAC(用户代理客户端)功能,能够根据用户配置的脚本,自动生成相应的呼叫流程,发送和接收相应的SIP消息,并报告执行结果。1.4 本文主要研究内容很多的SIP测试工具器是基于DOS命令并在Linux下的,本文设计了一个在Windows下的SIP业务模拟器工具,是一个呼叫处理工具,该工具和DOS命令下的界面相比,更简洁直观,优化了命令的传输形式。一开始描述了系统构架并完成相关的界面;其次研究了SIP消息解析模
11、块的设计,提出一中按行解析的新思路,而其编码是基于扩展的巴基科范式(ABNF)2;而后对脚本解析的设计和实现,在原有的XML解析算法流程进行扩展,以达到满足项目需求;最后通过Visual C+6.0 实现模拟器工具以及采用Winsock的原理实现基本呼叫的过程。最后一章通过实验数据来表明该模拟器工具的性能。第2章 系统架构及界面开发2.1 系统架构数据对象脚本文件对象类Sip消息对象类配置参数对象类统计数据对象类。呼处理控制脚本解析呼处理控制Sip消息解析统计数据收集。界面和数据展示消息窗口统计窗口案例展示窗口配置窗口。 图2.1 系统架构图2.2 主界面及子界面 图2.2 主界面图2.2.1
12、 工具栏工具栏上有4个功能按钮,每个按钮需求说明如下:1) Start test:启动测试,默认状态:disabled ,只有scenario被选择,状态才转为enabled2) Stop test:停止测试,默认状态:disabled,只有start test开始了,状态才转为enabled3) Select scenario:选择测试方案,点击后弹出文件选择框,选择 scenario,在Scenario window 显示4) Option:设置测试选项,点击后弹出测试选项对话框,完成后选项配置要保存到配置文件中。2.2.2 Scenario window情景窗口(图2.3)需要实现的内容
13、为:1) 允许编辑,修改2) 提供右键弹出菜单,来保存用户修改3) 脚本的格式参考sipp的脚本格式 图2.3 情景窗口:显示脚本内容2.2.3 Message window消息窗口(图2.4)需要实现的内容为:1) 显示当前接收发送的消息2) 提供右键弹出菜单,来保存log功能 图2.4 消息显示窗口2.2.4 Statistic window统计窗口(图2.5)显示测试的统计信息:测试方案执行次数,成功次数,失败次数,预期消息,未预期的消息 图2.5 消息统计窗口2.2.5 Option window软件的运行参数配置如图2.6:该配置提供本地IP和本地端口以及远程IP和远程端口。 图2.
14、6软件运行参数配置如下内容将自动保存到配置文件中:Option.iniPRODUCT_INFOMultiCalls=1RIP=1.1.1.1RPort=5060LIP=1.1.1.2LPort=5060MaxCallNum=1000Log=1第3章 SIP消息解析模块设计3.1 SIP消息引言SIP采用C/S结果的消息机制,分布式控制。SIP消息分为两大类:从客户端到服务器的请求(Request)和从服务器到客户端的响应(Response)。SIP基于HTTP,是一中文本型请求响应吸引:客户端发起请求,服务器端回送响应。一次SIP事务处理包括一个客户端的请求、没有多个临时响应,以及一个来自服务
15、器端的最终响应。SIP消息 = 开始行消息头CRLF消息体开始行 = 请求行/状态行 图3.1 SIP消息格式图3.1显示了SIP消息格式,它以起始行开始,请求消息中称为请求行,响应消息中称状态行。起始行后面是一些标题区域,包括格式name:value以及一个空行将标题区域和可选信息实体分隔开。消息头由域名和域值并加上中间的”:”组成的,例如:From:。消息体由SDP消息构成,SDP消息是文本信息,采用UTF-8编码中的ISO10646字符集,但SIP消息中不一定都有SDP消息。一个由UAC发出的合法SIP请求必须包含的最小头字段如下:To,From,CSeq,Call-ID,Max-For
16、wards,Via所有这些头字段在SIP请求中都是强制的。这六个域是构成SIP消息的基本块,它们联合提供大多数的消息路由服务,包括消息寻址、响应路由、限制消息传播、消息定制、唯一性鉴定事务。这些头字段还追加了一些强制请求行包括方法、请求地址、SIP版本。3.2 SIP消息解析策略及初步模型SIP消息是采用C+面向对象来实现的,根据C+面向对象的特点,以及SIP协议自身的特点,提出了一种按行解析的新思路产生SIP协议栈来保存SIP消息。 按行解析式是相对于按字节解析的,一个字节、一个字节读取时按照字节解析的;而所谓按行解析,是把SIP消息中的每个行当作一个整体来处理,通过逐行解析,来完成整个消息
17、的解析。但是SIP消息每一行的格式和类型又是不尽相同,不可能用一个函数解析到底,针对这一点,结合C+语言的继承性和多态性可以完全解决这个问题。继承性使得能够将SIP消息看作一个整体来对待,多态性则将其中请求消息与相应消息的不同的细节问题解决得比较完善,通过建立在继承性和多态性的基础上,完成按行解析的过程。解析模块完成两大功能:第一是正向消息解析,完成文本(字符串)到协议规定的消息格式的转换,主要是在接收消息时候调用。第二是逆向消息编码,完成消息到字符串的转换,主要在发送消息时候调用。基于单线程的解析模型算法流程图如图3.1。解析起始行开始收到消息解析头字段解析SIP版本号状态码和解释信息解析请
18、求方法请求URI和版本解析消息体SIP消息?消息体? 结束图3.1 SIP消息解析流程图有是无否SIP消息解析算法描述:当UA接收到一个SIP消息后,首先对字符串形式的消息进行整体的判断和分解。当对行结束符以及回车换行的识别,判断消息是否合法。如果合法,再将消息分成三个部分分别进行判断和解析。先是对开始行进行分析判断,判断收到的消息是请求还是响应,而后对其进行解析,同时提取相关信息(SIP URI和版本号);随后对各个头字段进行解析,提取相关信息;当遇到空行(CRLF)后,调用对消息体的解析函数;最后完成消息的解析。3.3 SIP解析模型改进在实现单线程解析的基础上,采用ABNF语法规则2。我
19、们可以设计一个多线程的消息处理模型来提高解析效率,即系统解析SIP消息时,可以同时从开始行、头字段、消息体解析。在消息头种类比较多时,可以快速匹配到对应的消息头解析函数。在词法解析算法中3,标准LR算法是可以同时处理多个进程,系统可能会并行地存在几组树结构栈,大大缩减计算量;在解析过程中采用共享子树结构来表现局部分析结果,节省空间开销;通过节点合并,压缩局部歧义。SIP消息解析时,解析模块从输入消息的句首顺次“移入”SIP消息的开始行、头字段、消息体,并根据语法中的重写规则逐级向上按条件“规约”,直到构造出表示SIP消息结构的整个推到树。在移入和归约过程中SIP信息以栈的形式存放,栈中存放解析
20、过程的有关“历史”信息,在解析时根据这些历史信息和当前正在处理的符合来决定究竟是移入还是归约3。SIP算法解析过程:1) 从输入消息的左端将一个未处理过的终结符移入栈顶,并等待更多的信息到了之后再做决定;2) 根据上下文无关语法的ABNF规则,用该规则左边的符合来取代栈顶的与规则右边相匹配的符合;3) 对栈中符合和输入符合串进行处理,输入串处理完成,且栈中只剩下一个符号S,分析成功,然后结束;4) 若栈中并非只有一个符合S或者输入的字符串中的符号没有处理完成,也不能进行任何的规约操作,分析失败结束。SIP解析改进算法流程如图4所示5。开 始输入ABNF规则输入SIP消息i = 1取第i个条件的
21、信息电子词典LR分析表i+按LR分析表处理,如果出现多种操作,启动多线程是否出错?是否接受?是否归约?移 进打印出错信 息打印出错信 息输出分析树结 束合一算法生成子树成功否?是否否否是是否是图3.2 改进SIP解析算法流程图第4章 XML脚本解析模块设计4.1 解析技术XML解析技术分为串行解析技术和并行解析技术。其中串行解析技术是指解析XML文档过程中采用单线程方式,即解析相关操作按照顺序执行的解析技术。而本文的XML解析模块的设计采用串行解析技术的原理,在此基础上通过基于预处理技术,可以提高解析性能,同时可以保持应用程序编程接口的兼容性。4.2 脚本格式及特点脚本实际上是一个sipp的x
22、ml配置文件,XML脚本不但提供了SIP消息本身,而且通过XML元素的属性提供了对这些消息的处理控制信息,这些处理控制信息包括重传时间、是否是必须的消息、及时开始和结束等。目前ph1阶段我们只支持其中一部分功能,可以认为我们的脚本文件是sipp的一个子集。格式:所有的脚本都是以下方式开始以结束。一个客户机(UAC)的脚本结构内容是以“send”关键字开始的,在“”和“”之间的内容称为关键字,如下: !CDATA INVITE sip:serviceremote_ip:remote_port SIP/2.0 Via: SIP/2.0/transport local_ip:local_port F
23、rom: sipp ;tag=call_number To: sut Call-ID: call_id Cseq: 1 INVITE Contact: sip:sipplocal_ip:local_port Max-Forwards: 70 Subject: Performance Test Content-Type: application/sdp Content-Length: len v=0 o=user1 53655765 2353687637 IN IPlocal_ip_type local_ip s=- t=0 0 c=IN IPmedia_ip_type media_ip m=a
24、udio media_port RTP/AVP 0 a=rtpmap:0 PCMU/8000 一个服务器(UAS)的脚本结构内容如下: !CDATA SIP/2.0 180 Ringing last_Via: last_From: last_To:;tag=call_number last_Call-ID: last_CSeq: Contact: Content-Length: 0 在“send”命令中,我们把SIP的消息封装到“”标签之间。在这两个标签里的内容将会被发送到远程系统。这些关键字是用来说明SIPp该做什么事情。关键字列表说明如表1: 表1 SIP消息关键字说明关键字默认值说明se
25、rviceservice服务字段,通过命令 s service_name传递remote_ip-远程IP地址,通过命令行传递remote_port5060远程IP端口,通过命令行传递。你可以增加一个已经计算过的偏移量remote_port + 3 来赋给这个值。transportUDP取决于t 参数的值,将获得值“UDP”或者“TCP”local_ipPrimary host IP address获得-i参数的值local_ip_type-取决于-i参数地址类型(IPv4或IPv6),local_ip_type 的值若是4则为IPv4,若为6则为IPv6local_portRandom获得-p
26、参数的值,你可以增加一个已经经过计算的偏移量(localport+3)赋给这个值。len-计算SIP消息体的长度。用在“Content-Length”字段中,你可以增加一个已经经过计算的偏移量(len+3) 赋给这个值。call_number-索引。从1开始,每出现一个呼叫增加一。cseq-该值是自动生成的,初始值是1,可以通过使用-base_cseq命令行选择来改变它。call_id-SIPp每一个新的呼叫就会产生一个call-id,一个这个值识别一个呼叫。在客户模块中,它通过SIPp中的Call-ID字段值的形成来强制使用。否者,由于成为一个已经存在的呼叫的一部分使得SIPp无法识别该应答
27、哪一个消息的发送。注:call-id可以通过三斜杠字符串/来识别。如:Call-ID:ABCDEFGHIJ/call_id,则sipp仍然可以识别并当作是同一个呼叫部分。media_ip-取决于-mi参数的值,它是本地IP地址对RTP的回应值。media_ip_type-取决于-mi参数的地址类型(IPv4或IPv6),media_ip_type 的值若是4则为IPv4,若为6则为IPv6media_port-取决于-mp参数的值,它设置了本地RTP回声值。RTP/UDP包接收它们的发送者。你可以增加一个已经经过计算的偏移量(media_port +3) 赋给这个值。auto_media_po
28、rt-仅使用在pcap中。从-mp参数的值开始来设置它的端口,使用含10000组建(为pcap_play限制10000个当前RTP会话)的周期系统来改变每个呼叫。last_*-如果接收的消息是最后一个,则last_*关键字会被自动的加到这个当前消息的特定字段中(除了复传送的消息外)。如果这个头字段不是当前的或者该消息已经被接收,则该关键字被丢弃,且是值到最后一行的所有字节都会被丢弃。若一个消息中出现该头字段多次,所有该情况连续使用last_*关键字来代替。field0-n-从外部CSV文件写入该值。$n-用于写入呼叫变量数n值。authentication-用于设置鉴别字段,该字段可以有参数,
29、如下:authentication username=myusernamepassword=mypassword.如果username没有提供,则从-s命令行参数中取得。如果password没有提供,则从-ap命令行参数中取得。pid-提供SIPp主线程的进程ID号routes-如果“rrs”属性在recv命令中被设置成“true”,则接收消息中的“Record-Route”头字段被存储并可以使用该关键字进行重呼叫。next_url-如果“rrs”属性在recv命令中被设置成“true”,则该字段含有Cantact字段的文本内容(该内容在Cantact中使用包含)。branch-提供一个分支值
30、,它在情景中由一串z9hG4bK+呼叫数+消息索引组成。msg_index-为情景提供消息数量cseq-提供最后请求接收的CSeq值。这个值可以增大(如:cseq+1,为最后请求的CSeq值增一)。在XML脚本中,元素的属性表示对此消息的处理控制的方法。例如:optional属性说明这个消息是否是必需的。XML的CDATA部分表示了SIP消息的一个框架,可以看到在方括号中的内容代表了一个变量,这些变量由用户配置文件中给出,如remote_ip、local_ip、transport等,或者由模拟器工具自己生成,如call_id、call_number、tag等。通过这种方式,用户可以方便地编写出
31、针对某类系统具有普遍适用性的测试实例。4.3 脚本解析模型及特点4.3.1 串行解析技术 根据对XML实例进行验证的模式,可以将串行解析技术进一步分为独立解析和解析与验证集两种解析模式。独立解析的模式指将解析过程与验证过程彼此独立、验证过程处于解析过程之后的处理模式。文档对象模型DOM6是独立解析模式的一种,是W3C推荐的一种独立于语言和平台的标准,并且是一种基于树型的解析技术,其目标是提供一个可以通用于各种程序语言、操作系统和应用程序的编程接口。DOM模型在解析XML文档时先将整个XML文档扫描一遍,得到独立的元素、属性和注释等然后以节点树的形式在内存中创建XML文档的表示,是以层次结构组织
32、的节点或信息片段的集合,每个节点代表一个可以与之交互的对象,用户可以通过结点树访问文档内容。 此模型的优点是在内存中保留整个文档的所有信息,用户可以随意访问任意位置的节点信息或是对之进行修改,开发人员可以方便编写程序。4.3.2 解析模型描述在串行技术的基础上,又根据SIP脚本的内容特点,对有些特定的字符串进行预处理,预过滤技术根据一定的规则、机制,在解析之前对XML文档进行预处理,将用户真正需要的部分过滤出来然后执行解析,从而降低了解析的工作量,提高了解析的性能。在解析XML文档DOM解析技术的基础上,采用C+面向对象的方法实现对XML的解析,其定义了一系列的对象和方法对DOM树的节点进行各
33、种随机操作:1) CXmlDocument对象:作为树的最高节点,是解析XML文档的入口。2) CXmlAttrList对象和CXmlAttrElement对象:这些节点对象都是文档某一部分的映射,节点的定级层次恰好反映了文档的结构。3) CXmlNode对象是节点类,用于保存信息;而CXmlUtil对象是内部转换封装类,用于对有用信息转换。以下描述在解析过程中对节点和属性的遍历,先获取脚本的内容:在解析过程中,脚本文件的内容通过节点的遍历会保存到子节点的标签值中,则可以先获得根节点的地址,在找出相应的子节点的地址,最后通过子节点中的GetTagValue()获取脚本的内容。在遍历xml的节点
34、:通过解析,可以生成根节点,而根节点下会有相应的子节点,通过循环会生成子节点链表;故可以通过定义根节点,找到子节点的头节点,再通过链表的遍历,寻找出相应的节点。最后可获取xml的属性值:解析过程中,通过CXmlAttrElement类的SetAttrName()和SetAttrValue()来保存相应的属性,若成功,则会通过CXmlAttrList:AddAttrElement()函数添加到属性链表中,故可以在节点下的属性链表中获取相应元素属性的地址,从而可以获取属性值。 对得到的属性和属性值进行扩展解析,与满足用户的需求,由于SIP消息是封包在“”之间,故需要获得相关的值,再进行对其进一步解
35、析,由UAC结构中可知我们需要提取的是关键字,因关键字的特殊性,可采用按字节解析的算法对其进行提取。XML解析算法过程如下:1) 输入XML文档内容;2) 进行预处理,取得用户所需要的信息;3) 解析开始部分内容,得到版本号和编码代号,如果失败,则结束,否则进入下一步;4) 进行子内容的解析,通过调用接口函数可获得XML的节点和XML属性值;5) 判断是否有下一个字内容,若有则返回上一步,否则结束。解析模型流程如图4.1:输入脚本内容开始解析版本号和编码成功?解析消息内容子消息?结束有无是否图4.1 XML解析算法流程图预处理第5章 模拟器测试及结果分析5.1 模拟器呼叫模块及结果此模拟器呼叫
36、是单路呼叫,单路呼叫的运行线程模拟一个SIP用户代理,单路呼叫模块既可以动态配置成UAC,也可以配置成UAS,通过SIP服务器与其它的SIP用户代理进行会话。与真正的用户代理不同,单路呼叫模块只进行会话的信令交换,不进行真实的会话媒体流的交换。单路呼叫模块的结构如图5.1,由呼处理控制和SIP消息解编码器两个子模块组成。呼处理控制SIP呼叫信息解码编码解编码器图5.1 模拟器呼叫模块moni呼叫处理控制子模块根据单路呼叫模块的运行线程在会话扮演的角色是UAS还是UAC,通过选择相应的呼叫流程对呼叫进行控制,此模拟器只支持典型流程的呼叫。预期每次呼叫,都会有一定数量的准正常和异常case,其指标
37、由呼叫失败率和忙时最高呼处理能力BHCA(Busy Hour Call Attempt)值等来说明。通过呼叫测试获得的统计信息如表2所示。序号总呼叫次数成功呼叫次数失败呼叫次数BHCA(次/秒)失败率110000800020002736020%27000600010002862014%3500042507502146015%440003600400956010%5.2 性能测试及结果通过SIP业务模拟器对SIP服务器性能的测试,是模拟通话高峰时的情况,对SIP服务器施加话务压力,监测SIP服务器此时的性能,而性能指标一般包括呼叫高峰时呼损率和忙时最高呼处理能力BHCA(Busy Hour Ca
38、ll Attempt)值等。测试的目标是监测SIP模拟器工具实现的BHCA值,呼叫高峰时呼损率,以及支持并发呼叫的能力。该软交换设备的预期性能是BHCA大于140万,呼叫高峰时呼损率小于0.0034%,每秒钟至少能够同时支持200路并发呼叫。首先测试单台PC作为呼叫器实施业务压力的能力,单个呼叫器在30路并发时每小时能够对软交换成功呼叫33万次。在实际的测试环境中利用1台PC作为控制器,10台PC作为呼叫器,这样能够确保测试系统本身能够达到测试必需的性能。在测试中对软交换四次呼叫,每次总呼叫次数为100万,并发路数的依次为100,150,200,250,测试运行结果如表3所示。 表3 SipS
39、erver呼处理测试结果序号并发路数 单路呼叫次数时间(s)BHCA(次/小时)失败数(呼损率)1100=1010100002442148万43(0.004%)2150=101566672363152万125(0.01%)3200=102050003084117万4285(0.4%)4250=10254000593961 万74356(7.4%)5.3 结果分析从表3 可以看出,在100路到150路并发的情况下,BHCA值大于140万和呼损率小于0.0034%,待测系统的性能超过预期要求的性能。但是并发的路数增加达到200 路和250 路时,软交换的性能指标下降,不能达到预期性能,并随着并发路
40、数增加BHCA值越低,呼损率越高。对于200路和250路并发呼叫的测试情况,通过察看控制器记录的呼叫失败信息,呼叫器在进行呼叫时,有很多的SIP消息发出,但没有及时收到作为应答的消息。这可能是由于在大量并发性呼叫时,软交换的消息解码模块对于同时收到的大量消息不能及时处理,使得部分消息丢失。而消息丢失的部分很容易从表2中得出明显的信息,通过得到这些大量准正常和异常的情况,从而能够为下一步的开发产品的性能优化提供了很好的帮助。结论本文讨论了基于SIP业务模拟器工具的设计和研究,将蚁群算法,遗传算法及粒子群算法应用于求解工程项目选择问题,并将其结果分别与枚举算法的结果进行对比,取得了较好的效果。首先
41、,使用MFC开发出相关的界面。接着对于呼处理的模块设计,其需要两部分完成,一个是SIP消息本身的解析模块设计,另一个是SIP消息脚本的解析模块设计。在对SIP消息本身的解析模块设计,采用了按行的解析算法思想以及C+实现,和按字节的解析算法思想相比,即保证了消息的完整性又具有整体直观性,也提高了程序的运行效率。而后提出了基于ABNF规则的改进的SIP消息解析算法。其次,设计了现XML脚本的解析,此解析算法思想是采用串行解析技术,并通过形成链表和树形结构,完成对关键字的提取。此过程中,根据XML原有的特性以及SIP消息的特点,通过增加预处理技术从而提高了解析的效率。最后,此模拟器工具在Window 使用Visual C+ 6.0来实现,在Winsock的编程原理基础上,实现SIP基本呼叫建立。最后通过对此模拟器工具进行了性能相关测试,得出结果,充分说明了其对验证大量的准正常和异常case的效果。