09-IPv6組播路由與轉發配置
本章節下載: 09-IPv6組播路由與轉發配置 (465.58 KB)
每個IPv6組播路由協議都有一個自身的路由表,綜合成一個總的IPv6組播路由表,由一係列(S,G)和(*,G)表項組成,即由組播源S向IPv6組播組G發送IPv6組播數據的IPv6組播路由信息。其中最優IPv6組播路由下發到IPv6組播轉發表中,控製IPv6組播數據的轉發。IPv6組播傳輸路徑上的設備根據IPv6組播轉發表轉發IPv6組播數據的同時還需執行RPF(Reverse Path Forwarding,逆向路徑轉發)機製確保IPv6組播數據沿正確路徑傳輸。
IPv6組播路由協議在創建和維護IPv6組播路由表項時,運用了RPF(Reverse Path Forwarding,逆向路徑轉發)檢查機製,以確保IPv6組播數據能夠沿正確的路徑傳輸,同時還能避免由於各種原因而造成的環路。
執行RPF檢查的過程如下:
(1) 首先,以“報文源”的IPv6地址為目的地址,分別從IPv6單播路由表和IPv6 MBGP路由表中各選出一條最優路由。
根據IPv6組播報文傳輸的具體情況不同,“報文源”所代表的具體含義也不同:
· 如果當前報文沿從組播源到接收者或RP(Rendezvous Point,彙集點)的SPT(Shortest Path Tree,最短路徑樹)進行傳輸,則以組播源為“報文源”進行RPF檢查。
· 如果當前報文沿從RP到接收者的RPT(Rendezvous Point Tree,共享樹)進行傳輸,或者沿從組播源到RP的組播源側RPT進行傳輸,則都以RP為“報文源”進行RPF檢查。
· 如果當前報文為BSR(Bootstrap Router,自舉路由器)報文,沿從BSR到各設備的路徑進行傳輸,則以BSR為“報文源”進行RPF檢查。
有關SPT、RPT、組播源側RPT、RP和BSR的詳細介紹,請參見“IP組播配置指導”中的“IPv6 PIM”。
(2) 然後,從這些最優路由中再選出一條作為RPF路由。選取規則如下:
· 如果配置了按照最長匹配選擇路由,則:
¡ 選擇前綴長度最長的路由。
¡ 如果前綴長度相同,則選擇路由優先級最高的路由。
¡ 如果路由優先級也相同,則按照IPv6 MBGP路由、IPv6單播路由的順序進行選擇。
¡ 如果存在等價路由,則選擇下一跳的IPv6地址較大者。
· 如果沒有配置按照最長匹配選擇路由,則:
¡ 選擇路由優先級最高的路由。
¡ 如果路由優先級相同,則按照IPv6 MBGP路由、IPv6單播路由的順序進行選擇。
¡ 如果存在等價路由,則選擇下一跳的IP地址較大者。
RPF路由中包含有RPF接口和RPF鄰居的信息,不論RPF路由為IPv6單播路由還是IPv6 MBGP路由,該路由表項的出接口都是RPF接口,下一跳都是RPF鄰居。
(3) 最後,判斷報文實際到達的接口與RPF接口是否相同:
· 相同,RPF檢查通過。
· 不同,RPF檢查失敗。
對每一個收到的IPv6組播數據報文都進行RPF檢查會給設備帶來較大負擔,而利用IPv6組播轉發表可以解決這個問題。在建立IPv6組播路由和轉發表時,會把IPv6組播數據報文(S,G)的RPF接口記錄為(S,G)表項的入接口。當設備收到IPv6組播數據報文(S,G)後,查找IPv6組播轉發表:
· 如果IPv6組播轉發表中不存在(S,G)表項,則對該報文執行RPF檢查,將其RPF接口作為入接口,結合相關路由信息創建相應的表項,並下發到IPv6組播轉發表中:
¡ 若該報文實際到達的接口正是其RPF接口,則RPF檢查通過,向所有的出接口轉發該報文;
¡ 若該報文實際到達的接口不是其RPF接口,則RPF檢查失敗,丟棄該報文。
· 如果IPv6組播轉發表中已存在(S,G)表項,且該報文實際到達的接口與入接口相匹配,則向所有的出接口轉發該報文。
· 如果IPv6組播轉發表中已存在(S,G)表項,但該報文實際到達的接口與入接口不匹配,則對此報文執行RPF檢查:
¡ 若其RPF接口與入接口一致,則說明(S,G)表項正確,丟棄這個來自錯誤路徑的報文;
¡ 若其RPF接口與入接口不符,則說明(S,G)表項已過時,於是把入接口更新為RPF接口。如果該報文實際到達的接口正是其RPF接口,則向所有的出接口轉發該報文,否則將其丟棄。
圖1-1 RPF檢查過程
如圖1-1所示,假設網絡中IPv6單播路由暢通,未配置IPv6 MBGP。IPv6組播報文(S,G)沿從組播源(Source)到接收者(Receiver)的SPT進行傳輸。假定Device C上的IPv6組播轉發表中已存在(S,G)表項,其記錄的入接口為Port A:
· 如果該IPv6組播報文從接口Port A到達Device C,與(S,G)表項的入接口相匹配,則向所有的出接口轉發該報文。
· 如果該IPv6組播報文從接口Port B到達Device C,與(S,G)表項的入接口不匹配,則對其執行RPF檢查:通過查找IPv6單播路由表發現到達Source的出接口(即RPF接口)是Port A,與(S,G)表項的入接口一致。這說明(S,G)表項是正確的,該報文來自錯誤的路徑,RPF檢查失敗,於是丟棄該報文。
網絡中可能存在不支持IPv6組播協議的設備,從IPv6組播源發出的IPv6組播數據沿IPv6組播設備逐跳轉發,當下一跳設備不支持IPv6組播協議時,IPv6組播轉發路徑將被阻斷。而通過在處於IPv6單播網段兩端的IPv6組播設備之間建立隧道,則可以實現跨IPv6單播網段的IPv6組播數據轉發。
圖1-2 使用隧道傳輸IPv6組播數據
如圖1-2所示,在IPv6組播設備Device A和Device B之間建立隧道。Device A將IPv6組播數據封裝在IPv6單播報文中,通過IPv6單播設備轉發至隧道另一端的Device B,再由Device B將IPv6單播報文頭剝掉後繼續進行IPv6組播傳輸。
本特性的支持情況與設備型號有關,詳細差異信息如下:
型號 |
說明 |
MSR610 |
不支持 |
MSR810、MSR810-W、MSR810-W-DB、MSR810-LM、MSR810-W-LM、MSR810-10-PoE、MSR810-LM-HK、MSR810-W-LM-HK、MSR810-LM-CNDE-SJK、MSR 810-CNDE-SJK、MSR810-EI、MSR810-LM-EA、MSR810-LM-EI |
支持 |
MSR810-LMS、MSR810-LUS |
不支持 |
MSR810-SI、MSR810-LM-SI |
不支持 |
MSR810-LMS-EA、MSR810-LME |
支持 |
MSR1004S-5G、MSR1004S-5G-CN |
支持 |
MSR1104S-W、MSR1104S-W-CAT6、MSR1104S-5G-CN、MSR1104S-W-5G-CN、MSR1104S-W-5GGL |
支持 |
MSR2600-6-X1、MSR2600-15-X1、MSR2600-15-X1-T |
支持 |
MSR2600-10-X1 |
支持 |
MSR2630-G-X1 |
支持 |
MSR 2630 |
支持 |
MSR3600-28、MSR3600-51 |
支持 |
MSR3600-28-SI、MSR3600-51-SI |
不支持 |
MSR3600-28-X1、MSR3600-28-X1-DP、MSR3600-51-X1、MSR3600-51-X1-DP |
支持 |
MSR3600-28-G-DP、MSR3600-51-G-DP |
支持 |
MSR3600-28-G-X1-DP、MSR3600-51-G-X1-DP |
支持 |
MSR3610-I-DP、MSR3610-IE-DP、MSR3610-IE-ES、MSR 3610-IE-EAD、MSR-EAD-AK770、MSR3610-I-IG、MSR3610-IE-IG |
支持 |
MSR-iMC |
支持 |
MSR3610-X1、MSR3610-X1-DP、MSR3610-X1-DC、MSR3610-X1-DP-DC、MSR3620-X1、MSR3640-X1 |
支持 |
MSR 3610、MSR 3620、MSR 3620-DP、MSR 3640、MSR 3660 |
支持 |
MSR3610-G、MSR3620-G |
支持 |
MSR3640-G |
支持 |
MSR3640-X1-HI |
支持 |
型號 |
說明 |
MSR810-W-WiNet、MSR810-LM-WiNet |
支持 |
MSR830-4LM-WiNet |
支持 |
MSR830-5BEI-WiNet、MSR830-6EI-WiNet、MSR830-10BEI-WiNet |
支持 |
MSR830-6BHI-WiNet、MSR830-10BHI-WiNet |
支持 |
MSR2600-6-WiNet |
支持 |
MSR2600-10-X1-WiNet |
支持 |
MSR2630-WiNet |
支持 |
MSR3600-28-WiNet |
支持 |
MSR3610-X1-WiNet |
支持 |
MSR3620-X1-WiNet |
支持 |
MSR3610-WiNet、MSR3620-10-WiNet、MSR3620-DP-WiNet、MSR3620-WiNet、MSR3660-WiNet |
支持 |
型號 |
說明 |
MSR860-6EI-XS |
支持 |
MSR860-6HI-XS |
支持 |
MSR2630-XS |
支持 |
MSR3600-28-XS |
支持 |
MSR3610-XS |
支持 |
MSR3620-XS |
支持 |
MSR3610-I-XS |
支持 |
MSR3610-IE-XS |
支持 |
MSR3620-X1-XS |
支持 |
MSR3640-XS |
支持 |
MSR3660-XS |
支持 |
型號 |
說明 |
MSR810-LM-GL |
支持 |
MSR810-W-LM-GL |
支持 |
MSR830-6EI-GL |
支持 |
MSR830-10EI-GL |
支持 |
MSR830-6HI-GL |
支持 |
MSR830-10HI-GL |
支持 |
MSR1004S-5G-GL |
支持 |
MSR2600-6-X1-GL |
支持 |
MSR3600-28-SI-GL |
不支持 |
IPv6組播路由與轉發配置任務如下:
(1) 使能IPv6組播路由
(2) (可選)配置按照最長匹配選擇RPF路由
(3) (可選)配置 IPv6組播負載分擔
(4) (可選)配置IPv6組播轉發邊界
(5) (可選)配置IPv6組播數據在Super VLAN內的各Sub VLAN之間互通
(6) (可選)配置緩存未知IPv6組播數據報文的最大數目
在配置IPv6組播路由與轉發之前,需配置任一IPv6單播路由協議,實現域內網絡層互通。
在公網實例或VPN實例中配置各項三層IPv6組播功能之前,必須先在該實例中使能IPv6組播路由。
(1) 進入係統視圖。
system-view
(2) 使能IPv6組播路由,並進入IPv6 MRIB(Multicast Routing Information Base,組播路由信息庫)視圖。
ipv6 multicast routing [ vpn-instance vpn-instance-name ]
缺省情況下,IPv6組播路由處於關閉狀態。
在未配置按照最長匹配選擇RPF路由之前,RPF檢查以最優路由作為RPF路由。在配置按照最長匹配選擇RPF路由之後,RPF檢查將按照最長匹配選擇RPF路由。有關RPF路由選擇的詳細介紹,請參見“1.1.1 1. RPF檢查過程”。
system-view
(2) 進入IPv6 MRIB視圖。
ipv6 multicast routing [ vpn-instance vpn-instance-name ]
(3) 配置按照最長匹配選擇RPF路由。
longest-match
缺省情況下,選擇路由優先級最高的路由作為RPF路由。
用戶通過配置根據組播源或組播源組進行IPv6組播流量的負載分擔,可以優化存在多條IPv6組播數據流時的網絡流量。
本命令對IPv6雙向PIM不生效。
(1) 進入係統視圖。
system-view
(2) 進入IPv6 MRIB視圖。
ipv6 multicast routing [ vpn-instance vpn-instance-name ]
(3) 配置對IPv6組播流量進行負載分擔。
load-splitting { source | source-group }
缺省情況下,不對IPv6組播流量進行負載分擔。
IPv6組播信息在網絡中的轉發並不是漫無邊際的,每個IPv6組播組對應的IPv6組播信息都必須在確定的範圍內傳遞。IPv6組播轉發邊界可以限製IPv6組播協議報文的收發,為指定範圍或Scope值的IPv6組播組劃定了邊界條件。如果IPv6組播報文的目的地址與邊界條件匹配,就停止轉發。當在一個接口上配置了IPv6組播轉發邊界後,將不能從該接口轉發IPv6組播報文(包括本機發出的IPv6組播報文),並丟棄該接口接收到的IPv6組播報文。
本配置不需要使能IPv6組播路由。
(1) 進入係統視圖。
system-view
(2) 進入接口視圖。
interface interface-type interface-number
(3) 配置IPv6組播轉發邊界。
ipv6 multicast boundary { ipv6-group-address prefix-length | scope { scope-id | admin-local | global | organization-local | site-local } }
缺省情況下,接口上未配置任何IPv6組播組的轉發邊界。
一個Super VLAN內可以有多個Sub VLAN,不同Sub VLAN之間相互隔離。通過本配置可以使IPv6組播數據在同一Super VLAN內的各Sub VLAN之間互通。有關Super VLAN及其Sub VLAN的詳細介紹,請參見“二層技術-以太網交換配置指導”中的“VLAN”。
(1) 進入係統視圖。
system-view
(2) 進入VLAN接口視圖。
interface vlan-interface interface-number
(3) 配置IPv6組播數據在Super VLAN內的各Sub VLAN之間互通。
ipv6 multicast forwarding supervlan community
缺省情況下,IPv6組播數據在Super VLAN內的各Sub VLAN之間隔離。
(4) 退回係統視圖。
quit
(5) 退回用戶視圖。
quit
(6) 清除所有以Super VLAN接口為入接口的轉發表項。
reset ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding-table incoming-interface { interface-type interface-number }
執行本命令後,ipv6 multicast forwarding supervlan community命令才能生效。
建立IPv6組播轉發表項需要一定時間,在這段時間內設備若收到(S,G)表項的IPv6組播數據報文,可以緩存該報文。如果需要緩存多個未知IPv6組播數據報文,可以通過本配置來設置對於同一個(S,G)表項,可緩存的最大未知IPv6組播數據報文數目。通過本配置還可以設置內存中緩存的未知IPv6組播數據報文的總數。
建議配置ipv6 multicast forwarding-table cache-unknown total的值要遠遠大於ipv6 multicast forwarding-table cache-unknown per-entry配置的值。
(1) 進入係統視圖。
system-view
(2) 設置對於同一個(S,G)表項,可緩存的最大未知IPv6組播數據報文數目。
ipv6 multicast forwarding-table cache-unknown per-entry per-entry-limit
缺省情況下,對於同一個(S,G)表項,可緩存的最大未知IPv6組播數據報文數目為1。
(3) 設置內存中緩存的未知IPv6組播數據報文的總數。
ipv6 multicast forwarding-table cache-unknown total total-limit
缺省情況下,內存中緩存的未知IPv6組播數據報文的總數量為1024。
執行reset命令清除IPv6組播路由表或IPv6組播轉發表中的信息,可能導致IPv6組播信息無法正常傳輸。
在完成上述配置後,在任意視圖下執行display命令可以顯示配置後IPv6組播路由與轉發的運行情況,通過查看顯示信息驗證配置的效果。
在用戶視圖下執行reset命令可以清除IPv6組播路由與轉發的統計信息。
表1-1 IPv6組播路由與轉發顯示和維護
操作 |
命令 |
顯示IPv6 MRIB維護的接口信息 |
display ipv6 mrib [ vpn-instance vpn-instance-name ] interface [ interface-type interface-number ] |
顯示IPv6組播邊界的信息 |
display ipv6 multicast [ vpn-instance vpn-instance-name ] boundary { group [ ipv6-group-address [ prefix-length ] ] | scope [ scope-id ] } [ interface interface-type interface-number ] |
顯示IPv6組播快速轉發表項信息 |
(獨立運行模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] fast-forwarding cache [ ipv6-source-address | ipv6-group-address ] * (IRF模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] fast-forwarding cache [ ipv6-source-address | ipv6-group-address ] * [ slot slot-number ] |
顯示IPv6組播轉發的DF信息 |
(獨立運行模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding df-info [ ipv6-rp-address ] [ verbose ] (IRF模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding df-info [ ipv6-rp-address ] [ verbose ] [ slot slot-number ] |
顯示IPv6組播轉發的事件統計信息 |
(獨立運行模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding event (IRF模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding event [ slot slot-number ] |
顯示IPv6組播轉發表的信息 |
(獨立運行模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding-table [ ipv6-source-address [ prefix-length ] | ipv6-group-address [ prefix-length ] | incoming-interface interface-type interface-number | outgoing-interface { exclude | include | match } interface-type interface-number | statistics ] * (IRF模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding-table [ ipv6-source-address [ prefix-length ] | ipv6-group-address [ prefix-length ] | incoming-interface interface-type interface-number | outgoing-interface { exclude | include | match } interface-type interface-number | slot slot-number | statistics ] * |
顯示IPv6組播轉發表的DF列表信息 |
(獨立運行模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding-table df-list [ ipv6-group-address ] [ verbose ] (IRF模式) display ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding-table df-list [ ipv6-group-address ] [ verbose ] [ slot slot-number ] |
顯示IPv6組播路由表的信息 |
display ipv6 multicast [ vpn-instance vpn-instance-name ] routing-table [ ipv6-source-address [ prefix-length ] | ipv6-group-address [ prefix-length ] | incoming-interface interface-type interface-number | outgoing-interface { exclude | include | match } interface-type interface-number ] * |
顯示IPv6組播源的RPF信息 |
display ipv6 multicast [ vpn-instance vpn-instance-name ] rpf-info ipv6-source-address [ ipv6-group-address ] |
清除IPv6組播快速轉發表中的轉發項 |
(獨立運行模式) reset ipv6 multicast [ vpn-instance vpn-instance-name ] fast-forwarding cache { { ipv6-source-address | ipv6-group-address } * | all } (IRF模式) reset ipv6 multicast [ vpn-instance vpn-instance-name ] fast-forwarding cache { { ipv6-source-address | ipv6-group-address } * | all } [ slot slot-number ] |
清除IPv6組播轉發的事件統計信息 |
reset ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding event |
清除IPv6組播轉發表中的轉發項 |
reset ipv6 multicast [ vpn-instance vpn-instance-name ] forwarding-table { { ipv6-source-address [ prefix-length ] | ipv6-group-address [ prefix-length ] | incoming-interface { interface-type interface-number } } * | all } |
清除IPv6組播路由表中的路由項 |
reset ipv6 multicast [ vpn-instance vpn-instance-name ] routing-table { { ipv6-source-address [ prefix-length ] | ipv6-group-address [ prefix-length ] | incoming-interface interface-type interface-number } * | all } |
· 清除IPv6組播路由表中的路由項後,IPv6組播轉發表中的相應表項也將隨之刪除。
· 清除IPv6組播轉發表中的轉發項後,IPv6組播路由表中的相應表項也將隨之刪除。
· Router A和Router C支持IPv6組播功能並運行IPv6 PIM-DM,但Router B不支持IPv6組播功能;
· Router A、Router B和Router C之間運行OSPFv3協議(不發布或引入組播源所在接口前綴);
· 要求通過配置,使Receiver能夠接收來自Source的IPv6組播信息。
圖1-3 利用GRE隧道實現IPv6組播轉發配置組網圖
(1) 配置IPv6地址和IPv6單播路由協議
請按照圖1-3配置各接口的IPv6地址和前綴長度,並在各路由器上配置OSPFv3協議(不發布或引入組播源所在接口前綴),具體配置過程略。
(2) 配置GRE隧道
# 在Router A上創建接口Tunnel2,並指定其隧道模式為GRE over IPv6隧道。
<RouterA> system-view
[RouterA] interface tunnel 2 mode gre ipv6
# 在Router A上為Tunnel2接口配置IPv6地址,並指定隧道的源地址和目的地址。
[RouterA-Tunnel2] ipv6 address 5001::1 64
[RouterA-Tunnel2] source 2001::1
[RouterA-Tunnel2] destination 3001::2
[RouterA-Tunnel2] quit
# 在Router C上創建接口Tunnel2,並指定其隧道模式為GRE over IPv6隧道。
<RouterC> system-view
[RouterC] interface tunnel 2 mode gre ipv6
# 在Router C上為Tunnel2接口配置IPv6地址,並指定隧道的源地址和目的地址。
[RouterC-Tunnel2] ipv6 address 5001::2 64
[RouterC-Tunnel2] source 3001::2
[RouterC-Tunnel2] destination 2001::1
[RouterC-Tunnel2] quit
(3) 使能IPv6組播路由,並使能IPv6 PIM-DM和MLD
# 在Router A上使能IPv6組播路由,並在各接口上使能IPv6 PIM-DM。
[RouterA] ipv6 multicast routing
[RouterA-mrib6] quit
[RouterA] interface gigabitethernet 1/0/1
[RouterA-GigabitEthernet1/0/1] ipv6 pim dm
[RouterA-GigabitEthernet1/0/1] quit
[RouterA] interface gigabitethernet 1/0/2
[RouterA-GigabitEthernet1/0/2] ipv6 pim dm
[RouterA-GigabitEthernet1/0/2] quit
[RouterA] interface tunnel 2
[RouterA-Tunnel2] ipv6 pim dm
[RouterA-Tunnel2] quit
# 在Router C上使能IPv6組播路由,在主機側接口GigabitEthernet1/0/1上使能MLD,並在其它接口上使能IPv6 PIM-DM。
[RouterC] ipv6 multicast routing
[RouterC-mrib6] quit
[RouterC] interface gigabitethernet 1/0/1
[RouterC-GigabitEthernet1/0/1] mld enable
[RouterC-GigabitEthernet1/0/1] quit
[RouterC] interface gigabitethernet 1/0/2
[RouterC-GigabitEthernet1/0/2] ipv6 pim dm
[RouterC-GigabitEthernet1/0/2] quit
[RouterC] interface tunnel 2
[RouterC-Tunnel2] ipv6 pim dm
[RouterC-Tunnel2] quit
(4) 配置IPv6靜態路由
# 在Router C上配置IPv6靜態路由,該路由的目的地址為1001::1/64,下一跳地址為Tunnel2。
[RouterC] ipv6 route-static 1001::1 64 tunnel 2
IPv6組播源向IPv6組播組FF1E::101發送IPv6組播數據,接收者加入該IPv6組播組後能夠收到IPv6組播源發來的IPv6組播數據。
# 顯示Router C上的IPv6 PIM路由表信息。
[RouterC] display ipv6 pim routing-table
Total 1 (*, G) entries; 1 (S, G) entries
(*, FF1E::101)
Protocol: pim-dm, Flag: WC
UpTime: 00:04:25
Upstream interface: NULL
Upstream neighbor: NULL
RPF prime neighbor: NULL
Downstream interface(s) information:
Total number of downstreams: 1
1: GigabitEthernet1/0/1
Protocol: mld, UpTime: 00:04:25, Expires: -
(1001::100, FF1E::101)
Protocol: pim-dm, Flag: ACT
UpTime: 00:06:14
Upstream interface: Tunnel2
Upstream neighbor: FE80::A01:101:1
RPF prime neighbor: FE80::A01:101:1
Downstream interface(s) information:
Total number of downstreams: 1
1: GigabitEthernet1/0/1
Protocol: pim-dm, UpTime: 00:04:25, Expires: -
Router C的RPF鄰居為Router A,IPv6組播數據通過GRE隧道由直接Router A發往Router C。
· Spoke與Hub之間建立ADVPN隧道;
· Hub和Spoke支持組播功能並運行PIM-SM,ADVPN隧道口運行NBMA模式;
· Hub1、Hub2、Spoke1和Spoke2之間運行OSPF協議;
· 使Spoke1能夠接收來自Hub1的組播信息。
圖1-4 IPv6 ADVPN實現組播轉發配置組網圖
設備 |
接口 |
IP地址 |
設備 |
接口 |
IP地址 |
Hub1 |
GE1/0/1 |
1::1/64 |
Hub2 |
GE1/0/1 |
1::2/64 |
|
Tunnel1 |
192:168::1/64 FE80::1 |
|
Tunnel1 |
192:168::2/64 FE80::2 |
|
Loop0 |
44::44/64 |
|
Loop0 |
55::55/64 |
GE1/0/2 |
100::100/64 |
|
|
|
|
Spoke1 |
GE1/0/1 |
1::3/64 |
Spoke2 |
GE1/0/1 |
1::4/64 |
|
Tunnel1 |
192:168::3/64 FE80::3 |
|
Tunnel1 |
192:168::4/64 FE80::4 |
GE1/0/2 |
200::100/64 |
|
|
|
|
Server |
GE1/0/1 |
1::11/64 |
|
|
|
(1) 配置IPv6地址
請按照圖1-4配置各接口的IPv6地址和前綴長度,具體配置過程略。
(2) 配置IPv6 ADVPN信息
# 在Server上創建ADVPN域abc。
<Server> system-view
[Server] vam server advpn-domain abc id 1
# 在Server上配置VAM Server的預共享密鑰為123456。
[Server-vam-server-domain-abc] pre-shared-key simple 123456
# 在Server上配置對VAM Client不進行認證。
[Server-vam-server-domain-abc] authentication-method none
# 在Server上啟動該ADVPN域的VAM Server功能。
[Server-vam-server-domain-abc] server enable
# 在Server上創建Hub組0。
[Server-vam-server-domain-abc] hub-group 0
# 在Server上指定Hub組內Hub的IPv6私網地址。
[Server-vam-server-domain-abc-hub-group-0] hub ipv6 private-address 192:168::1
[Server-vam-server-domain-abc-hub-group-0] hub ipv6 private-address 192:168::2
# 在Server上指定Hub組內Spoke的IPv6私網地址範圍。
[Server-vam-server-domain-abc-hub-group-0] spoke ipv6 private-address range 192:168:: 192:168::FFFF:FFFF:FFFF:FFFF
[Server-vam-server-domain-abc-hub-group-0] quit
[Server-vam-server-domain-abc] quit
# 在Hub1上創建VAM Client Hub1。
<Hub1> system-view
[Hub1] vam client name Hub1
# 在Hub1上配置VAM Client所屬的ADVPN域為abc。
[Hub1-vam-client-Hub1] advpn-domain abc
# 在Hub1上配置VAM Server的IP地址。
[Hub1-vam-client-Hub1] server primary ipv6-address 1::11
# 在Hub1上配置VAM Client的預共享密鑰。
[Hub1-vam-client-Hub1] pre-shared-key simple 123456
# 在Hub1上開啟VAM Client功能。
[Hub1-vam-client-Hub1] client enable
# 在Hub2上創建VAM Client Hub2。
<Hub2> system-view
[Hub2] vam client name hub2
# 在Hub2上配置VAM Client所屬的ADVPN域為abc。
[Hub2-vam-client-hub2] advpn-domain abc
# 在Hub2上配置VAM Server的IP地址。
[Hub2-vam-client-hub2] server primary ipv6-address 1::11
# 在Hub2上配置VAM Client的預共享密鑰。
[Hub2-vam-client-hub2] pre-shared-key simple 123456
# 在Hub2上開啟VAM Client功能。
[Hub2-vam-client-hub2] client enable
# 在Spoke1上創建VAM Client Spoke1。
<Spoke1> system-view
[Spoke1] vam client name Spoke1
# 在Spoke1上配置VAM Client所屬的ADVPN域為abc。
[Spoke1-vam-client-Spoke1] advpn-domain abc
# 在Spoke1上配置VAM Server的IP地址。
[Spoke1-vam-client-Spoke1] server primary ipv6-address 1::11
# 在Spoke1上配置VAM Client的預共享密鑰。
[Spoke1-vam-client-Spoke1] pre-shared-key simple 123456
# 在Spoke1上開啟VAM Client功能。
[Spoke1-vam-client-Spoke1] client enable
[Spoke1-vam-client-Spoke1] quit
# 在Spoke2上創建VAM Client Spoke2。
<Spoke2> system-view
[Spoke2] vam client name Spoke2
# 在Spoke2上配置VAM Client所屬的ADVPN域為abc。
[Spoke2-vam-client-Spoke2] advpn-domain abc
# 在Spoke2上配置VAM Server的IP地址。
[Spoke2-vam-client-Spoke2] server primary ipv6-address 1::11
# 在Spoke2上配置VAM Client的預共享密鑰。
[Spoke2-vam-client-Spoke2] pre-shared-key simple 123456
# 在Spoke2上開啟VAM Client功能。
[Spoke2-vam-client-Spoke2] client enable
[Spoke2-vam-client-Spoke2] quit
(3) 配置IPv6 ADVPN隧道
# 在Hub1上配置GRE封裝的IPv6 ADVPN隧道接口Tunnel1。
[Hub1] interface tunnel 1 mode advpn gre ipv6
[Hub1-Tunnel1] source gigabitethernet 1/0/1
[Hub1-Tunnel1] ipv6 address FE80::1 link-local
[Hub1-Tunnel1] ipv6 address 192:168::1 64
[Hub1-Tunnel1] vam ipv6 client hub1
[Hub1-Tunnel1] quit
# 在Hub2上配置GRE封裝的IPv6 ADVPN隧道接口Tunnel1。
[Hub2] interface tunnel 1 mode advpn gre ipv6
[Hub2-Tunnel1] source gigabitethernet 1/0/1
[Hub2-Tunnel1] ipv6 address FE80::2 link-local
[Hub2-Tunnel1] ipv6 address 192:168::2 64
[Hub2-Tunnel1] vam ipv6 client hub1
[Hub2-Tunnel1] quit
# 在Spoke1上配置GRE封裝的IPv6 ADVPN隧道接口Tunnel1。
[Spoke1] interface tunnel 1 mode advpn gre ipv6
[Spoke1-Tunnel1] source gigabitethernet 1/0/1
[Spoke1-Tunnel1] ipv6 address FE80::3 link-local
[Spoke1-Tunnel1] ipv6 address 192:168::3/64
[Spoke1-Tunnel1] vam ipv6 client spoke1
[Spoke1-Tunnel1] quit
# 在Spoke2上配置GRE封裝的IPv6 ADVPN隧道接口Tunnel1。
[Spoke2] interface tunnel 1 mode advpn gre ipv6
[Spoke2-Tunnel1] source gigabitethernet 1/0/1
[Spoke2-Tunnel1] ipv6 address FE80::4 link-local
[Spoke2-Tunnel1] ipv6 address 192:168::4/64
[Spoke2-Tunnel1] vam ipv6 client spoke2
[Spoke2-Tunnel1] quit
(4) 配置OSPFv3路由協議
# 在Hub1上 配置路由信息。
<Hub1> system-view
[Hub1] ospfv3
[Hub1-ospfv3-1] router-id 0.0.0.1
[Hub1-ospfv3-1] area 0.0.0.0
[Hub1-ospfv3-1-area-0.0.0.0] quit
[Hub1-ospfv3-1] quit
[Hub1] interface loopback 0
[Hub1-LoopBack0] ospfv3 1 area 0.0.0.0
[Hub1-LoopBack0] quit
[Hub1] interface gigabitethernet 1/0/2
[Hub1-GigabitEthernet1/0/2] ospfv3 1 area 0.0.0.0
[Hub1-GigabitEthernet1/0/2] quit
[Hub1] interface tunnel 1
[Hub1-Tunnel1] ospfv3 1 area 0.0.0.0
[Hub1-Tunnel1] ospfv3 network-type p2mp
[Hub1-Tunnel1] quit
# 在Hub2上配置路由信息。
<Hub2> system-view
[Hub2] ospfv3
[Hub2-ospfv3-1] router-id 0.0.0.2
[Hub2-ospfv3-1] area 0.0.0.0
[Hub2-ospfv3-1-area-0.0.0.0] quit
[Hub2-ospfv3-1] quit
[Hub2] interface loopback 0
[Hub2-LoopBack0] ospfv3 1 area 0.0.0.0
[Hub2-LoopBack0] quit
[Hub2] interface tunnel 1
[Hub2-Tunnel1] ospfv3 1 area 0.0.0.0
[Hub2-Tunnel1] ospfv3 network-type p2mp
[Hub2-Tunnel1] quit
# 在Spoke1上配置路由信息。
<Spoke1> system-view
[Spoke1] ospfv3 1
[Spoke1-ospfv3-1] router-id 0.0.0.3
[Spoke1-ospfv3-1] area 0.0.0.0
[Spoke1-ospfv3-1-area-0.0.0.0] quit
[Spoke1-ospfv3-1] quit
[Spoke1] interface tunnel 1
[Spoke1-Tunnel1] ospfv3 1 area 0.0.0.0
[Spoke1-Tunnel1] ospfv3 network-type p2mp
[Spoke1-Tunnel1] quit
# 在Spoke2上配置路由信息。
<Spoke2> system-view
[Spoke2] ospfv3 1
[Spoke2-ospfv3-1] router-id 0.0.0.4
[Spoke2-ospfv3-1] area 0.0.0.0
[Spoke2-ospfv3-1-area-0.0.0.0] quit
[Spoke2-ospfv3-1] quit
[Spoke2] interface tunnel 1
[Spoke2-Tunnel1] ospfv3 1 area 0.0.0.0
[Spoke2-Tunnel1] ospfv3 network-type p2mp
[Spoke2-Tunnel1] quit
[Spoke2] interface gigabitethernet 1/0/2
[Spoke2-GigabitEthernet1/0/2] ospfv3 1 area 0.0.0.0
[Spoke2-GigabitEthernet1/0/2] quit
(5) 使能IPv6組播路由,並使能IPv6 PIM-SM和MLD
# 在Hub1上使能IPv6組播路由,並使能IPv6 PIM-SM、IPv6 PIM-NBMA。
<Hub1> system-view
[Hub1] ipv6 multicast routing
[Hub1-mrib6] quit
[Hub1] interface loopback 0
[Hub1-LoopBack0] ipv6 pim sm
[Hub1-LoopBack0] quit
[Hub1] interface gigabitethernet 1/0/2
[Hub1-GigabitEthernet1/0/2] ipv6 pim sm
[Hub1-GigabitEthernet1/0/2] quit
[Hub1] interface tunnel 1
[Hub1-Tunnel1] ipv6 pim sm
[Hub1-Tunnel1] ipv6 pim nbma-mode
[Hub1-Tunnel1] quit
# 在Hub1上配置C-BSR、C-RP。
<Hub1> system-view
[Hub1] ipv6 pim
[Hub1-pim6] c-bsr 44::44
[Hub1-pim6] c-rp 44::44
[Hub1-pim6] quit
# 在Hub2上使能IPv6組播路由,並使能IPv6 PIM-SM、IPv6 PIM-NBMA。
<Hub2> system-view
[Hub2] ipv6 multicast routing
[Hub2-mrib6] quit
[Hub2] interface loopback 0
[Hub2-LoopBack0] ipv6 pim sm
[Hub2-LoopBack0] quit
[Hub2] interface tunnel 1
[Hub2-Tunnel1] ipv6 pim sm
[Hub2-Tunnel1] ipv6 pim nbma-mode
[Hub2-Tunnel1] quit
# 在Hub2上配置C-BSR、C-RP。
<Hub2> system-view
[Hub2] ipv6 pim
[Hub2-pim6] c-bsr 55::55
[Hub2-pim6] c-rp 55::55
[Hub2-pim6] quit
# 在Spoke1上使能IPv6組播路由,並使能IPv6 PIM-SM、IPv6 PIM-NBMA、MLD。
<Spoke1> system-view
[Spoke1] ipv6 multicast routing
[Spoke1-mrib6] quit
[Spoke1] interface tunnel 1
[Spoke1-Tunnel1] ipv6 pim sm
[Spoke1-Tunnel1] ipv6 pim nbma-mode
[Spoke1-Tunnel1] quit
[Spoke1] interface gigabitethernet 1/0/2
[Spoke1-GigabitEthernet1/0/2] mld enable
[Spoke1-GigabitEthernet1/0/2] quit
# 在Spoke2上使能IPv6組播路由,並使能IPv6 PIM-SM、IPv6 PIM-NBMA。
<Spoke2> system-view
[Spoke2] ipv6 multicast routing
[Spoke2-mrib6] quit
[Spoke2] interface tunnel 1
[Spoke2-Tunnel1] ipv6 pim sm
[Spoke2-Tunnel1] ipv6 pim nbma-mode
[Spoke2-Tunnel1] quit
組播源向Hub1發送組播組FF0e::1組播數據,接收者向Spoke1加入該組播組後能夠收到組播源發來的組播數據。
# 顯示Hub1上的PIM路由表信息。
[Hub1] display ipv6 pim routing-table
Total 1 (*, G) entries; 1 (S, G) entries
(*, FF0E::1)
RP: 44::44 (local)
Protocol: pim-sm, Flag: WC
UpTime: 17:02:10
Upstream interface: Register-Tunnel1
Upstream neighbor: NULL
RPF prime neighbor: NULL
Downstream interface information:
Total number of downstream interfaces: 1
1: Tunnel1, FE80::3
Protocol: pim-sm, UpTime: 17:01:23, Expires: 00:02:41
(100::1, FF0E::1)
RP: 44::44 (local)
Protocol: pim-sm, Flag: SPT LOC ACT
UpTime: 00:00:02
Upstream interface: GigabitEthernet1/0/3
Upstream neighbor: NULL
RPF prime neighbor: NULL
Downstream interface information:
Total number of downstream interfaces: 1
1: tunnel1, FE80::3
Protocol: pim-sm, UpTime: 00:00:02, Expires: 00:03:28
不同款型規格的資料略有差異, 詳細信息請向具體銷售和400谘詢。H3C保留在沒有任何通知或提示的情況下對資料內容進行修改的權利!