1、根据输出级扇出、中间级扇出、输入级扇出等不同的扇出机制分类,可将组播算法分为输入级扇出算法(IFMA)、最迟扇出算法(LFMA)、 切割扇出算法(SFMA)、中间级优先扇出算法(CMFFMA)。在对4种算法仿真比较的基础上,文章提出针对不同的业务采用不同的处理方法的路由方案,对于固定扇出业务可采用CMFFMA算法进行路由,针对递增业务采用先输出级、再中间级、最后输入级扇出的策略,可有效地降低阻塞率。关键词:Clos网络;组播;路由算法;扇出随着宽带技术的不断发展,视频点播、远程教学、新闻发布、网络电视等业务成为新一轮运营竞争的焦点,它们的特点是,信息由一个服务器向大量的客户端发布。组播技术非常
2、适合这类业务,并具有如下优点:服务器不必知道某个客户端是否存在,它只负责按多播地址将媒体流发送出去,即使有成千上万个客户端,也仅发送一份即可;客户端如果希望接收某媒体流服务器的数据,只需加入该媒体流服务器播放数据使用的组播组即可1。目前智能光网络的发展要求节点设备的交叉矩阵具有容量高、快速的端口配置和组播支持能力,组播业务根据目的节点数的不同,可以分为单播、组播和广播3种类型2。单播是指待转发的消息在传送网中要求实现点对点的传输,广播业务是指在传送网中把待转发的一个消息从源节点转发到传送网的全部输出端口上,而组播业务是则把消息转发到传送网中的一组输出端口上。从广义上来讲,单播和广播是组播的一个
3、特例。根据组播请求的多个目的输出端口的产生时间,可以把组播分为两类3:第一类是固定扇出业务,所有的目的输出端口是在请求一开始就确定;第二类是递增业务,它的目的端口递增,是不确定的。1 Clos网络的组播业务为了支持网络中的组播业务,网络中的核心设备交换设备也应当具有组播功能。Clos网络自提出以来4由于其低成本、易大规模实现,在交换设备中得到了广泛的应用。图1为一个对称的三级Clos网络,用n表示输入输出模块的端口数量,N表示总的输入端口数,f表示扇出值,m表示中间模块的数量,r表示输入和输出模块的数量,则一个三级Clos网络可以表示为C(n, m, r)。如果用Ip表示输入端口,Pi表示输出
4、端口,那么一个组播请求可表示为(Ip:P1,P2Pk)。对称的三级Clos网络在任意级有扇出功能的组播严格无阻塞的条件为mmin(n -1)f +n,(N -1)f,N 5,而且对于任意一个组播严格无阻塞网络,需要的开关数最少为O(N 2)6,但是在实际应用中并不需要达到严格无阻塞就可以有很好的性能。1.1 Clos网络扇出机制对于三级Clos网络,不同的扇出机制不但影响Clos网络的阻塞率,而且影响算法的时间复杂度及网络成本,因此选择好的扇出方式才能充分发挥网络的组播能力。以下将对Clos网络各级扇出的性能特点进行分析。(1) 输出级扇出输出级扇出指输出级模块具有扇出功能,如果输出级具有扇出
5、功能,那么对于同一个业务源到一个输出模块中的多个输出端口只需要经过一个中间模块,否则有多少输出端口就需要经过多少个中间模块,在三级Clos网络中路由分配主要就是中间级模块的分配,因此必须降低对中间级模块的需求,而第三级扇出可以降低对中间级模块的要求,所以采用第三级扇出可以有效的降低阻塞率,这样我们就可以将一个组播请求由原来的端口表示(Ip:P1,P2Pk)转化成模块表示(I:O1,O2Ok),其中I表示输入模块,Oi表示输出模块。(2) 中间级扇出中间级扇出指中间级的模块具有扇出功能。假如第一级没有扇出功能,那么所有组播分支只能在一个中间级模块进行扇出,因此只有那些满足所有扇出要求的中间交换单
6、元才可以成功建立连接。所以在组播请求的扇出值很大的情况下,网络的阻塞概率将会急剧上升,但是由于只使用一个中间模块,可以避免外部阻塞的发生。(3) 输入级扇出输入级扇出指输入级模块具有扇出功能,可以从一个输入端口到达不同的中间级模块。如果第三级有扇出的话,那么组播请求要到达几个输出级模块,就需要占用几个中间级模块。对于输入级扇出可以将组播分解成不同的单播请求进行处理,这样可以利用单播中成熟的算法来进行处理,实现简单,而且可以降低内部阻塞率。但是由于每个组播请求只在第一级扇出,因此需要大量的中间模块,容易出现外部阻塞问题。1.2 Clos网络组播算法介绍Clos网络中的组播算法性能主要受扇出机制的
7、影响,这样我们就根据扇出策略的不同将组播算法分为以下几种。输入级扇出算法(IFMA)7是基于输入级扇出的算法,其主要思想是通过将一个扇出值为f的组播请求转化成f个单播请求,然后按照单播请求的路由算法进行路由,这样在Clos网络中每个组播请求只在输入级进行扇出,这样可以将组播业务理解为多个相互独立的单播业务,这样就可以利用单播算法中的成熟算法。如图1中的输入端口0到输出端口0、输出端口4和输出端口8的组播业务采用输入级扇出方式,在输入模块IM1中完成所有的扇出,分别经过中间模块CM1、CM2和CM3到不同的目的模块。最迟扇出算法(LFMA)6 是基于中间级扇出的算法,该算法的思想是只有在必须进行
8、扇出时才进行扇出,即先在输出级扇出再在中间级扇出。因此对于每一个组播请求只使用一个中间模块,如图1中输入端口2中的请求(2:1,3,7),只使用了一个中间模块CM4。这两种扇出机制都存在着自身的局限性,但是又有很强的互补性,因此将两种扇出相结合的思想就应运而出。在三级Clos网络中,内部阻塞的产生主要是由于级间链路的竞争,如果没有第三级扇出,那么每个组播请求在一个输出模块的每个输出端口都要占用一个从中间级到输出级的链路,否则只需要一个链路。同样,如果中间级没有扇出,那么每一个子请求都要占用一条输入模块到中间模块之间的链路,这样就会出现外部阻塞。各种扇出机制各有优缺点,可以结合使用。在在输入级和
9、输出级同时扇出的机制中又可以根据不同的分配方式分为切分扇出算法及先中间级后输入级算法两种。切割扇出算法(SFMA)8是把目的输出模块进行分组,分组数g为扇出值F 和切割值s 的比值向上取整,然后在进行路由时在第一级就进行扇出,即需要在第二级选择g 个可用的中间交换单元,然后再在第二级和中间级扇出机制一样进行同样的处理。如图1中输入端口3的请求,如果按照切割算法理解的话其扇出值F 为3,切割值s为2,分为两组,一组通过中间模块CM1路由,另一组通过中间模块CM2路由。最后一种算法是中间级优先扇出算法(CMFFMA)9-10,利用尽量少的中间模块完成扇出,即首先选择一个可以建立尽量多扇出的中间单元
10、,建立其到输出模块的连接。如果到全部输出模块的连接均建立完成则路由成功,否则将余下的尚未完成的连接继续按照上一步的方法处理,利用其他中间级单元的扇出能力完成扇出。例如在图1中,由于没有一个中间模块能够满足输入端口3的所有扇出请求,因此通过CM1 建立其中的两条,然后再通过CM2建立剩余的连接。通过以上对扇出的分析,我们可以得到采用先中间级后输入级算法的扇出机制是最优的。与切割扇出机制相比,它少了盲目性,多了预先检测性,可以在第一级进行有目的扇出;与最迟扇出机制相比,它又有很强的灵活性。1.3 Clos网络组播算法仿真(1) 仿真条件采用OPNET软件对不同的组播算法进行仿真,仿真中的请求是按照
11、占用-空闲源模式产生,即每个输入端口有占用和空闲两种状态,占用状态表示该输入端口当前存在一个链接,每种状态的持续时间均服从指数分布,如果1/表示占用的平均时间,1/表示空闲的持续时间,那么在以输入端的状态判断,网络中的负载p1=1/u/1/u+1/=/u+,如果用f表示组播的平均扇出,Pptp表示业务中单播的比率,那么网络中的实际负载=(Pptp+(1-Pptp)f )I。每个组播的扇出值按指数分布产生。(2) 仿真结果在具有组播业务的Clos网络中网络的阻塞率主要受组播业务的扇出值、组播比例和中间模块数的影响,下面就分别进行仿真分析。图2是4种不同的算法在C(16, 16, 16)网络规模、
12、0.8负载以及单播比例为0.5时的阻塞率随扇出值变化的曲线图。从图2中可以看出随着扇出值的增加阻塞率会有所增加,但是当扇出值达到一定值时,阻塞率将趋于稳定,这是因为在负载固定、输出级有扇出的情况下,随着扇出值的增加请求数量会减少。同时由于输出级具有扇出功能,而输出级的模块数固定,所以当扇出值超出一定值后扇出的目的模块数不会有太多的变化,因此在扇出值大于一定范围后,阻塞则趋于稳定。在这几种算法里CMFFMA的阻塞率最低,因为他的扇出顺序是先输出级、再中间级、最后输入级,这样可以最低限度地节约网络中的链路资源,避免阻塞发生。图3为C(16,16,16)的Clos网络在负载为0.8时的阻塞率随单播比
13、例变化的仿真结果。从图3中可以看出随着单播比例的增加IFMA算法、SFMA和LFMA算法的阻塞率单调下降,而CMFFMA算法的阻塞率随着单播比例的变化成抛物线状,这是因为这两种算法适宜于组播请求的建立,能够最大程度的利用已有的空闲资源,因此在单播比例较低时网络的阻塞率比较低,但是随着单播比例的增加阻塞率会逐渐增加,当到达一定的比例时阻塞率又随着单播比例的增加而下降,直到单播比例为1时,以上几种算法的阻塞率均达到一个固定值。 图4为C(16,16,16)规模的Clos网络在0.8的负载,平均扇出值为8时及单播比例为0.5时各种算法的阻塞率随中间模块数的变化曲线。从图4中可以看出随着中间模块数的增
14、加,不同算法的阻塞率下降的速度不同,其中LFMA算法和IFMA算法的下降最缓慢,其他两种算法的下降速度很快;而且在中间模块数远小于严格无阻塞所需要的中间模块数的情况下,Clos网络的阻塞率可以下降到很低。从以上分析可知IFMA算法的阻塞率在所有算法中是最高的,这是因为该算法采用输入级扇出,组播业务的扇出均要在输入级实现,这样会造成很高的外部阻塞,而且占用的第一级链路数与第二级链路数相等。图5为IFMA算法的阻塞率随中间模块数的变化趋势,网络规模为C(16, m, 16),平均扇出值为8,负载为0.8,全组播业务。图5中可以看出内部阻塞率较小,故网络的整体阻塞率主要由外部阻塞率决定。上面分析了在单、组播业务混合的情况下网络的整体阻塞率,但是由于单播和组播业务的不同,其阻塞率不尽相同,图6为不同算法随单播比例变化对组播业务阻塞率的影响。从图6中可以看出随着单播比例的增加,组播业务的阻塞率单调递增。其中,CMFFMA算法的阻塞率最低,这是由于其更好的利用了网络中的空闲链路资源;IFM
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1