前面两种协议需要建立自己的多播
路由表。大多数
路由器只支持pim。
PIM,协议无关性,它不需要建立自己的路由表,关心的只是路由器中有没有
单播路由表,无论这个单播表项是怎样建立的,通过怎样的
路由协议。
PIM MODE:PIM DM(密集模式,使用
源分发树),
PIM SM(稀疏模式,使用共享分发树),
PIM SDM(稀疏密集模式,先尝试使用共享树,找不到RP再切向
源分发树)
PIM DM,用于用户密集的情况,如果存在着没有要求
多播的
路由器则将其“裁剪”,如果存在着后来接入又需要多播的路由器则将其“嫁接”!
PIM SM,用于用户分散的情况,只有一棵树,初始为空,只有路由器发起要求才建立分支。这种模式存在着第一个到目的的
数据包会触发目的向源发送一个
单播形式的该数据,如果到源的路径好过走rp的路径则自动向最佳路径切换。
PIM SDM,使用最多的模式,效率最高。
rp的选举问题,三种方式:手工指定,auto rp(cisco only),BSR
自举路由器(只有pim v2支持)
配置:
(config-if)#ip pim 模式
密集模式的配置:
(config-if)#ip pim dense
稀疏模式的配置:
静态: (config)#ip mutilcast-routing
(config-if)#ip pim sparse
(config)#ip pim rp-add x.x.x.x
(config)#ip pim spt-thresheld infin / 具体值 指定向源切换的界限
auto: 定义候选者,(
config)#ip pim send-rp-amounce 接口 scopettl值(定义边界) group-list
访问列表
定义映射代理,(config)#ip pim send-rp-discovery scope ttl值
指定模式,(config-if)#ip pim sp-de mode
注意,要224.0.1.39和224.0.1.40一对
组播地址支持rp选举:
rp映射代理发往rp候选者用224.0.1.40
反过来,用224.0.1.39
BSR:(config-if)#ip pim 1 / 2 更改
pim版本号,bsr只支持2
(config-if)#ip pim bsr border 定义
多播边界
(config)#ip pim rp-candidate 接口 定义rp候选者
(config)#ip pim bsr-candidate 接口 定义bsr
这里,bsr用224.0.1.13向候选者通告,候选者用
单播回应bsr。
sh ip mroute; sh ip pim int; sh ip pim nei;
sh ip pim rp; sh ip pim bsr; sh ip pim map.
三个版本:
igmpv1:report(pc发出,地址255.1.1.1,ttl=1),query(router发出,发项0.0.0.0,60秒一次,120s没收到report回应则停止向该pc发组播)。
igmpv2:在v1基础上增加了一个leave消息,query消息的作用就变成了防止pc意外离开(没有leave消息,不被
router所知)。
igmpv3:可以对信源地址做控制了,选择pc需要的特定
多播。
另外还有一个igmpv3lite,是cisco私有的过渡方案,目的是让程序员能立刻编写ssm。
(3)
switch的多播处理:cgmp和switch snooping
CGMP:思科私有协议,运行于思科
交换机与思科路由器之间,让交换机能够通过路由器给出的消息间接支持组管理。
流程大致是:pc发igmp告知
路由器我需要什么多播,如果路由器就直接把多播传入则经过交换机的时候会被交换机发向与该pc一个vlan的所有
主机,
router需要将该多播的mac通告交换机,让其明白多播具体该发向哪,并建立一个
多播的
转发表。
IGMP snooping:公有协议,只要交换机单独运行即可。它是靠帧听igmpreport来建立多播转发表的。所以对于2层交换机,因为看不到3层信息,所以要监听每一个
组播帧,从中发现igmp成员报告,这样加大了cpu等资源的使用,比较不利;而对于3层交换机,能够看到3层信息,可以识别igmp成员报告,只要处理igmp流即可,所以负担轻。