- Table of Contents
-
- 08-IP Multicast Configuration Guide
- 00-Preface
- 01-Multicast overview
- 02-IGMP snooping configuration
- 03-PIM snooping configuration
- 04-Multicast VLAN configuration
- 05-Multicast routing and forwarding configuration
- 06-IGMP configuration
- 07-PIM configuration
- 08-MSDP configuration
- 09-Multicast VPN configuration
- 10-MLD snooping configuration
- 11-IPv6 PIM snooping configuration
- 12-IPv6 multicast VLAN configuration
- 13-IPv6 multicast routing and forwarding configuration
- 14-MLD configuration
- 15-IPv6 PIM configuration
- Related Documents
-
Title | Size | Download |
---|---|---|
02-IGMP snooping configuration | 532.32 KB |
Restrictions and guidelines: IGMP snooping configuration
VLAN-based IGMP snooping tasks at a glance
VSI-based IGMP snooping tasks at a glance
Enabling IGMP snooping for multiple VLANs
Enabling IGMP snooping for a VLAN
Enabling IGMP snooping for a VSI
Configuring basic IGMP snooping features
Specifying an IGMP snooping version
Setting the maximum number of IGMP snooping forwarding entries
Setting the IGMP last member query interval
Configuring IGMP snooping port features
Setting aging timers for dynamic ports
Configuring a static member port
Configuring a static router port
Configuring a port as a simulated member host
Enabling fast-leave processing
Disabling a port from becoming a dynamic router port
Configuring the IGMP snooping querier
Enabling the IGMP snooping querier
Configuring parameters for IGMP general queries and responses
Enabling IGMP snooping proxying
Configuring parameters for IGMP messages
Configuring source IP addresses for IGMP messages
Configuring IGMP snooping policies
Configuring a multicast group policy
Enabling dropping unknown multicast data
Enabling IGMP report suppression
Setting the maximum number of multicast groups on a port
Enabling multicast group replacement
Enabling SNMP notifications for IGMP snooping
Display and maintenance commands for IGMP snooping
IGMP snooping configuration examples
Example: Configuring VLAN-based IGMP snooping group polices and simulated joining
Example: Configuring VLAN-based IGMP snooping static ports
Example: Configuring the VLAN-based IGMP snooping querier
Example: Configuring VLAN-based IGMP snooping proxying
Example: Configuring VSI-based IGMP snooping
Example: Configuring VXLAN-based IGMP snooping
Layer 2 multicast forwarding cannot function
Multicast group policy does not work
Configuring IGMP snooping
About IGMP snooping
IGMP snooping runs on a Layer 2 device as a multicast constraining mechanism to improve multicast forwarding efficiency. It creates Layer 2 multicast forwarding entries from IGMP packets that are exchanged between the hosts and the Layer 3 device.
Fundamentals of IGMP snooping
As shown in Figure 1, when IGMP snooping is not enabled, the Layer 2 switch floods multicast packets to all hosts in a VLAN or VSI. When IGMP snooping is enabled, the Layer 2 switch forwards multicast packets of known multicast groups to only the receivers.
Figure 1 Multicast packet transmission without and with IGMP snooping
IGMP snooping ports
As shown in Figure 2, IGMP snooping runs on Device A and Device B, and Host A and Host C are receivers in a multicast group. IGMP snooping ports are divided into member ports and router ports.
Router ports
On an IGMP snooping Layer 2 device, the ports toward Layer 3 multicast devices are called router ports. In Figure 2, Port A1 of Device A and Port B1 of Device B are router ports.
Router ports contain the following types:
· Dynamic router port—When a port receives an IGMP general query whose source address is not 0.0.0.0 or receives a PIM hello message, the port is added into the dynamic router port list. At the same time, an aging timer is started for the port. If the port receives either of the messages before the timer expires, the timer is reset. If the port does not receive either of the messages when the timer expires, the port is removed from the dynamic router port list.
· Static router port—When a port is statically configured as a router port, it is added into the static router port list. The static router port does not age out, and it can be deleted only manually.
Do not confuse the "router port" in IGMP snooping with the "routed interface" commonly known as the "Layer 3 interface." The router port in IGMP snooping is a Layer 2 interface.
Member ports
On an IGMP snooping Layer 2 device, the ports toward receiver hosts are called member ports. In Figure 2, Port A2 and Port A3 of Device A and Port B2 of Device B are member ports.
Member ports contain the following types:
· Dynamic member port—When a port receives an IGMP report, it is added to the associated dynamic IGMP snooping forwarding entry as an outgoing interface. At the same time, an aging timer is started for the port. If the port receives an IGMP report before the timer expires, the timer is reset. If the port does not receive an IGMP report when the timer expires, the port is removed from the associated dynamic forwarding entry.
· Static member port—When a port is statically configured as a member port, it is added to the associated static IGMP snooping forwarding entry as an outgoing interface. The static member port does not age out, and it can be deleted only manually.
Unless otherwise specified, router ports and member ports in this document include both static and dynamic router ports and member ports.
How IGMP snooping works
The ports in this section are dynamic ports. For information about how to configure and remove static ports, see "Configuring a static member port" and "Configuring a static router port."
IGMP messages types include general query, IGMP report, and leave message. An IGMP snooping-enabled Layer 2 device performs differently depending on the message types.
General query
The IGMP querier periodically sends IGMP general queries to all hosts and devices on the local subnet to check for the existence of multicast group members.
After receiving an IGMP general query, the Layer 2 device forwards the query to all ports in the VLAN or VSI except the receiving port. The Layer 2 device also performs one of the following actions:
· If the receiving port is a dynamic router port in the dynamic router port list, the Layer 2 device restarts the aging timer for the port.
· If the receiving port does not exist in the dynamic router port list, the Layer 2 device adds the port to the dynamic router port list. It also starts an aging timer for the port.
IGMP report
A host sends an IGMP report to the IGMP querier for the following purposes:
· Responds to queries if the host is a multicast group member.
· Applies for a multicast group membership.
After receiving an IGMP report from a host, the Layer 2 device forwards the report through all the router ports in the VLAN or VSI. It also resolves the address of the reported multicast group, and looks up the forwarding table for a matching entry as follows:
· If no match is found, the Layer 2 device creates a forwarding entry with the receiving port as an outgoing interface. It also marks the receiving port as a dynamic member port and starts an aging timer for the port.
· If a match is found but the matching forwarding entry does not contain the receiving port, the Layer 2 device adds the receiving port to the outgoing interface list. It also marks the receiving port as a dynamic member port and starts an aging timer for the port.
· If a match is found and the matching forwarding entry contains the receiving port, the Layer 2 device restarts the aging timer for the port.
|
NOTE: A Layer 2 device does not forward an IGMP report through a non-router port because of the host IGMP report suppression mechanism. If a non-router port has member host attached, the member hosts suppress their IGMP reports upon receiving IGMP reports forwarded by the non-router port. The Layer 2 device cannot know the existence of the member hosts attached to the non-router port. For more information about the IGMP report suppression mechanism, see "Configuring IGMP." |
Leave message
An IGMPv1 receiver host does not send any leave messages when it leaves a multicast group. The Layer 2 device cannot immediately update the status of the port that connects to the receiver host. The Layer 2 device does not remove the port from the outgoing interface list in the associated forwarding entry until the aging time for the group expires.
An IGMPv2 or IGMPv3 host sends an IGMP leave message when it leaves a multicast group.
When the Layer 2 device receives an IGMP leave message on a dynamic member port, the Layer 2 device first examines whether a forwarding entry matches the group address in the message.
· If no match is found, the Layer 2 device discards the IGMP leave message.
· If a match is found but the receiving port is not an outgoing interface in the forwarding entry, the Layer 2 device discards the IGMP leave message.
· If a match is found and the receiving port is not the only outgoing interface in the forwarding entry, the Layer 2 device performs the following actions:
¡ Discards the IGMP leave message.
¡ Sends an IGMP group-specific query to identify whether the group has active receivers attached to the receiving port.
¡ Sets the aging timer for the receiving port to twice the IGMP last member query interval.
· If a match is found and the receiving port is the only outgoing interface in the forwarding entry, the Layer 2 device performs the following actions:
¡ Forwards the IGMP leave message to all router ports in the VLAN or VSI.
¡ Sends an IGMP group-specific query to identify whether the group has active receivers attached to the receiving port.
¡ Sets the aging timer for the receiving port to twice the IGMP last member query interval.
After receiving the IGMP leave message on a port, the IGMP querier resolves the multicast group address in the message. Then, it sends an IGMP group-specific query to the multicast group through the receiving port.
After receiving the IGMP group-specific query, the Layer 2 device forwards the query through all router ports and member ports of the group in the VLAN or VSI. Then, it waits for the responding IGMP report from the directly connected hosts. For the dynamic member port that received the leave message, the Layer 2 device also performs one of the following actions:
· If the port receives an IGMP report before the aging timer expires, the Layer 2 device resets the aging timer.
· If the port does not receive an IGMP report when the aging timer expires, the Layer 2 device removes the port from the forwarding entry for the multicast group.
IGMP snooping proxying
As shown in Figure 3, to reduce the number of IGMP report and leave messages received by the upstream device, you can enable IGMP snooping proxying on the edge device. With IGMP snooping proxying enabled, the edge device acts as a host for the upstream IGMP snooping querier to send IGMP report and leave messages to Device A. The host IGMP report suppression mechanism on the edge device does not take effect. For more information about the IGMP report suppression mechanism, see "Configuring IGMP."
Figure 3 IGMP snooping proxying
The IGMP snooping proxy device processes different IGMP messages as follows:
· General query.
After receiving an IGMP general query, the device forwards the query to all ports in the VLAN except the receiving port. The device also generates an IGMP report based on the local membership information and sends the report to all router ports.
· Group-specific query or group-and-source-specific query.
After receiving an IGMP group-specific query or group-and-source-specific query, the device forwards the query to all ports in the VLAN except the receiving port. If the forwarding entry has a member port, the device sends a report to all router ports in the VLAN.
· Report.
After receiving an IGMP report from a host, the device looks up the forwarding table for a matching entry as follows:
¡ If a match is found and the matching forwarding entry contains the receiving port, the device resets the aging timer for the port.
¡ If a match is found but the matching forwarding entry does not contain the receiving port, the device adds the receiving port to the outgoing interface list. It also marks the receiving port as a dynamic member port and starts an aging timer for the port.
¡ If no match is found, the device creates a forwarding entry with the receiving port as an outgoing interface. It also marks the receiving port as a dynamic member port and starts an aging timer for the port. Then it sends the report to all router ports.
· Leave message.
After receiving the IGMP leave message on a port, the device sends an IGMP group-specific query through the receiving port. The device sends the IGMP leave message to all router ports only when the last member port is removed from the forwarding entry.
Protocols and standards
RFC 4541, Considerations for Internet Group Management Protocol (IGMP) and Multicast Listener Discovery (MLD) Snooping Switches
Restrictions and guidelines: IGMP snooping configuration
VSI-based IGMP snooping is available only for the following cards:
Card category |
Cards |
CEPC |
CEPC-XP4LX, CEPC-XP24LX, CEPC-XP48RX, CEPC-CP4RX, CEPC-CP4RX-L |
CSPC |
CSPC-GE16XP4L-E, CSPC-GE24L-E, CSPC-GP24GE8XP2L-E |
CSPEX |
CSPEX-1304X, CSPEX-1304S, CSPEX-1404X, CSPEX-1404S, CSPEX-1502X, CSPEX-1504X, CSPEX-1504S, CSPEX-1602X, CSPEX-1804X, CSPEX-1512X, CSPEX-1612X, CSPEX-1812X, CSPEX-1104-E |
SPEX |
SPEX-1204 |
SPE |
RX-SPE200 |
The IGMP snooping configurations made on Layer 2 aggregate interfaces do not interfere with the configurations made on member ports. In addition, the configurations made on Layer 2 aggregate interfaces do not take part in aggregation calculations. The configuration made on a member port of the aggregate group takes effect after the port leaves the aggregate group.
To configure IGMP snooping features for VLANs or VSIs, you must enable IGMP snooping for the specific VLANs or VSIs even though IGMP snooping is enabled globally.
Some features can be configured for a VLAN in VLAN view or for multiple VLANs in IGMP-snooping view. The configuration made in VLAN view and the configuration made in IGMP-snooping view have the same priority, and the most recent configuration takes effect.
Some features can be configured for a VLAN in VLAN view or globally for all VLANs in IGMP-snooping view. The VLAN-specific configuration takes priority over the global configuration.
Some features can be configured for a VSI in VSI view or globally for all VSIs in IGMP-snooping view. The VSI-specific configuration takes priority over the global configuration.
Some features can be configured for an interface in interface view or for all interfaces of the specified VLANs in IGMP-snooping view. The interface-specific configuration takes priority over the configuration made in IGMP-snooping view.
VLAN-based IGMP snooping tasks at a glance
To configure IGMP snooping for VLANs, perform the following tasks:
2. (Optional.) Configuring basic IGMP snooping features
¡ Specifying an IGMP snooping version
¡ Setting the maximum number of IGMP snooping forwarding entries
¡ Setting the IGMP last member query interval
3. (Optional.) Configuring IGMP snooping port features
¡ Setting aging timers for dynamic ports
¡ Configuring a static member port
¡ Configuring a static router port
¡ Configuring a port as a simulated member host
¡ Enabling fast-leave processing
¡ Disabling a port from becoming a dynamic router port
4. (Optional.) Configuring the IGMP snooping querier
¡ Enabling the IGMP snooping querier
¡ Configuring parameters for IGMP general queries and responses
5. (Optional.) Enabling IGMP snooping proxying
6. (Optional.) Configuring parameters for IGMP messages
¡ Configuring source IP addresses for IGMP messages
7. (Optional.) Configuring IGMP snooping policies
¡ Configuring a multicast group policy
¡ Enabling dropping unknown multicast data
¡ Enabling IGMP report suppression
¡ Setting the maximum number of multicast groups on a port
¡ Enabling multicast group replacement
8. (Optional.) Enabling SNMP notifications for IGMP snooping
VSI-based IGMP snooping tasks at a glance
To configure IGMP snooping for VSIs, perform the following tasks:
2. (Optional.) Configuring basic IGMP snooping features
¡ Specifying an IGMP snooping version
¡ Setting the maximum number of IGMP snooping forwarding entries
¡ Setting the IGMP last member query interval
3. (Optional.) Setting aging timers for dynamic ports
4. (Optional.) Configuring the IGMP snooping querier
¡ Enabling the IGMP snooping querier
¡ Configuring parameters for IGMP general queries and responses
5. (Optional.) Configuring parameters for IGMP messages
¡ Configuring source IP addresses for IGMP messages
6. (Optional.) Configuring IGMP snooping policies
¡ Enabling dropping unknown multicast data
¡ Enabling IGMP report suppression
7. (Optional.) Enabling SNMP notifications for IGMP snooping
Enabling IGMP snooping
Enabling IGMP snooping for multiple VLANs
1. Enter system view.
system-view
2. Enable IGMP snooping globally and enter IGMP-snooping view.
igmp-snooping
By default, IGMP snooping is globally disabled.
3. Enable IGMP snooping for the specified VLANs.
enable vlan vlan-list
By default, IGMP snooping is disabled for a VLAN.
IGMP snooping configuration in a VLAN takes effect only on the member ports in the VLAN.
Enabling IGMP snooping for a VLAN
1. Enter system view.
system-view
2. Enable IGMP snooping globally and enter IGMP-snooping view.
igmp-snooping
By default, IGMP snooping is globally disabled.
3. Return to system view.
quit
4. Enter VLAN view.
vlan vlan-id
5. Enable IGMP snooping for the VLAN.
igmp-snooping enable
By default, IGMP snooping is disabled for a VLAN.
IGMP snooping configuration in a VLAN takes effect only on the member ports in the VLAN.
Enabling IGMP snooping for a VSI
1. Enter system view.
system-view
2. Enable IGMP snooping globally and enter IGMP-snooping view.
igmp-snooping
By default, IGMP snooping is globally disabled.
3. Return to system view.
quit
4. Enter VSI view.
vsi vsi-name
5. Enable IGMP snooping for the VSI.
igmp-snooping enable
By default, IGMP snooping is disabled for a VSI.
IGMP snooping configuration in a VSI takes effect only on the member ports in the VSI.
Configuring basic IGMP snooping features
Specifying an IGMP snooping version
About this task
Different IGMP snooping versions process different versions of IGMP messages.
· IGMPv2 snooping processes IGMPv1 and IGMPv2 messages, but it floods IGMPv3 messages in the VLAN or VSI instead of processing them.
· IGMPv3 snooping processes IGMPv1, IGMPv2, and IGMPv3 messages.
Restrictions and guidelines
If you change the IGMP snooping version from 2 to 3, the device performs the following actions:
· Clears all IGMP snooping forwarding entries that are dynamically created.
· Keeps static IGMPv3 snooping forwarding entries (*, G).
· Clears static IGMPv3 snooping forwarding entries (S, G), which will be restored when the IGMP snooping version is switched back to 3.
For more information about static IGMP snooping forwarding entries, see "Configuring a static member port."
Specifying an IGMP snooping version for multiple VLANs
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Specify an IGMP snooping version for multiple VLANs.
version version-number vlan vlan-list
By default, the IGMP snooping version for a VLAN is 2.
Specifying an IGMP snooping version for a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Specify an IGMP snooping version for the VLAN.
igmp-snooping version version-number
By default, the IGMP snooping version for a VLAN is 2.
Specifying an IGMP snooping version for a VSI
1. Enter system view.
system-view
2. Enter VSI view.
vsi vsi-name
3. Specify an IGMP snooping version for the VSI.
igmp-snooping version version-number
By default, the IGMP snooping version for a VSI is 2.
Setting the maximum number of IGMP snooping forwarding entries
About this task
You can modify the maximum number of IGMP snooping forwarding entries, including dynamic entries and static entries. When the number of forwarding entries on the device reaches the upper limit, the device does not automatically remove any existing entries. To allow new entries to be created, remove some entries manually.
Procedure
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Set the maximum number of IGMP snooping forwarding entries.
entry-limit limit
By default, the maximum number of IGMP snooping forwarding entries is 4294967295.
Setting the IGMP last member query interval
About this task
A receiver host starts a report delay timer for a multicast group when it receives an IGMP group-specific query for the group. This timer is set to a random value in the range of 0 to the maximum response time advertised in the query. When the timer value decreases to 0, the host sends an IGMP report to the group.
The IGMP last member query interval defines the maximum response time advertised in IGMP group-specific queries. Set an appropriate value for the IGMP last member query interval to speed up hosts' responses to IGMP group-specific queries and avoid IGMP report traffic bursts.
Setting the IGMP last member query interval globally
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Set the IGMP last member query interval globally.
last-member-query-interval interval
By default, the global IGMP last member query interval is 1 second.
Setting the IGMP last member query interval for a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Set the IGMP last member query interval for the VLAN.
igmp-snooping last-member-query-interval interval
By default, the IGMP last member query interval is 1 second for a VLAN.
Setting the IGMP last member query interval for a VSI
1. Enter system view.
system-view
2. Enter VSI view.
vsi vsi-name
3. Set the IGMP last member query interval for the VSI.
igmp-snooping last-member-query-interval interval
By default, the IGMP last member query interval is 1 second for a VSI.
Configuring IGMP snooping port features
Setting aging timers for dynamic ports
About this task
A dynamic router port is removed from the dynamic router port list if it does not receive an IGMP general query or PIM hello message when its aging timer expires.
A dynamic member port is removed from the dynamic member port if it does not receive an IGMP report when its aging timer expires.
Restrictions and guidelines
Set an appropriate value for the aging timers of dynamic ports. For example, if the memberships of multicast groups frequently change, set a relatively small value for the aging timer of the dynamic member ports. If the memberships of multicast groups rarely change, set a relatively large value.
If a dynamic router port receives a PIMv2 hello message, the aging timer for the port is specified by the hello message. In this case, the router-aging-time or igmp-snooping router-aging-time command does not take effect on the port.
IGMP group-specific queries originated by the Layer 2 device trigger the adjustment of aging timers for dynamic member ports. If a dynamic member port receives such a query, its aging timer is set to twice the IGMP last member query interval. For more information about setting the IGMP last member query interval on the Layer 2 device, see "Setting the IGMP last member query interval."
Setting the aging timers for dynamic ports globally
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Set the aging timer for dynamic router ports globally.
router-aging-time seconds
By default, the aging timer for dynamic router ports is 260 seconds.
4. Set the global aging timer for dynamic member ports globally.
host-aging-time seconds
By default, the aging timer for dynamic member ports is 260 seconds.
Setting the aging timers for dynamic ports in a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Set the aging timer for dynamic router ports in the VLAN.
igmp-snooping router-aging-time seconds
By default, the global aging timer for dynamic router ports is used.
4. Set the aging timer for dynamic member ports in the VLAN.
igmp-snooping host-aging-time seconds
By default, the global aging timer for dynamic member ports is used.
Setting the aging timers for dynamic ports in a VSI
1. Enter system view.
system-view
2. Enter VSI view.
vsi vsi-name
3. Set the aging timer for dynamic router ports in the VSI.
igmp-snooping router-aging-time seconds
By default, the global aging timer for dynamic router ports is used.
4. Set the aging timer for dynamic member ports in the VSI.
igmp-snooping host-aging-time seconds
By default, the global aging timer for dynamic member ports is used.
Configuring a static member port
About this task
You can configure a port as a static member port for a multicast group so that hosts attached to the port can always receive multicast for the group. The static member port does not respond to IGMP queries. When you complete or cancel this configuration on a port, the port does not send an unsolicited IGMP report or leave message.
Procedure
1. Enter system view.
system-view
2. Enter Layer 2 interface view.
¡ Enter Layer 2 Ethernet interface view.
interface interface-type interface-number
¡ Enter Layer 2 aggregate interface view.
interface bridge-aggregation interface-number
3. Configure the port as a static member port.
igmp-snooping static-group group-address [ source-ip source-address ] vlan vlan-id
By default, a port is not a static member port.
Configuring a static router port
About this task
You can configure a port as a static router port for a multicast group so that all multicast data for the group received on the port will be forwarded.
Procedure
1. Enter system view.
system-view
2. Enter Layer 2 interface view.
¡ Enter Layer 2 Ethernet interface view.
interface interface-type interface-number
¡ Enter Layer 2 aggregate interface view.
interface bridge-aggregation interface-number
3. Configure the port as a static router port.
igmp-snooping static-router-port vlan vlan-id
By default, a port is not a static router port.
Configuring a port as a simulated member host
About this task
When a port is configured as a simulated member host, it is equivalent to an independent host in the following ways:
· It sends an unsolicited IGMP report when you complete the configuration.
· It responds to IGMP general queries with IGMP reports.
· It sends an IGMP leave message when you cancel the configuration.
The version of IGMP running on the simulated member host is the same as the version of IGMP snooping running on the port. The port ages out in the same way as a dynamic member port.
Procedure
1. Enter system view.
system-view
2. Enter Layer 2 interface view.
¡ Enter Layer 2 Ethernet interface view.
interface interface-type interface-number
¡ Enter Layer 2 aggregate interface view.
interface bridge-aggregation interface-number
3. Configure the port as a simulated member host.
igmp-snooping host-join group-address [ source-ip source-address ] vlan vlan-id
By default, the port is not a simulated member host.
Enabling fast-leave processing
About this task
This feature enables the Layer 2 device to immediately remove a port from the forwarding entry for a multicast group when the port receives a leave massage. The Layer 2 device no longer sends or forwards IGMP group-specific queries for the group to the port.
Restrictions and guidelines
Do not enable fast-leave processing on a port that has multiple receiver hosts in a VLAN. If you do so, the remaining receivers cannot receive multicast data for a group after a receiver leaves the group.
As a best practice to avoid multicast service interruption on other ports in the same VLAN, enable only IGMP snooping fast-leave processing on a port on a network configured with both IGMP snooping and IGMP. Do not use the igmp fast-leave command to enable IGMP fast-leaving processing. For more information about the igmp fast leave command, see IGMP commands in IP Multicast Command Reference.
Enabling fast-leave processing globally
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Enable fast-leave processing globally.
fast-leave [ vlan vlan-list ]
By default, fast-leave processing is disabled globally.
Enabling fast-leave processing on a port
1. Enter system view.
system-view
2. Enter Layer 2 interface view.
¡ Enter Layer 2 Ethernet interface view.
interface interface-type interface-number
¡ Enter Layer 2 aggregate interface view.
interface bridge-aggregation interface-number
3. Enable fast-leave processing on the port.
igmp-snooping fast-leave [ vlan vlan-list ]
By default, fast-leave processing is disabled on a port.
Disabling a port from becoming a dynamic router port
About this task
A receiver host might send IGMP general queries or PIM hello messages for testing purposes. On the Layer 2 device, the port that receives either of the messages becomes a dynamic router port. Before the aging timer for the port expires, the following problems might occur:
· All multicast data for the VLAN to which the port belongs flows to the port. Then, the port forwards the data to attached receiver hosts. The receiver hosts will receive multicast data that it does not want to receive.
· The port forwards the IGMP general queries or PIM hello messages to its upstream Layer 3 devices. These messages might affect the multicast routing protocol state (such as the IGMP querier or DR election) on the Layer 3 devices. This might further cause network interruption.
To solve these problems, you can disable a port from becoming a dynamic router port. This also improves network security and the control over receiver hosts.
Restrictions and guidelines
This configuration and the static router port configuration do not interfere with each other.
Procedure
1. Enter system view.
system-view
2. Enter Layer 2 interface view.
¡ Enter Layer 2 Ethernet interface view.
interface interface-type interface-number
¡ Enter Layer 2 aggregate interface view.
interface bridge-aggregation interface-number
3. Disable the port from becoming a dynamic router port.
igmp-snooping router-port-deny [ vlan vlan-list ]
By default, a port is allowed to become a dynamic router port.
Configuring the IGMP snooping querier
Enabling the IGMP snooping querier
About this task
This feature enables the Layer 2 device to periodically send IGMP general queries to establish and maintain multicast forwarding entries at the data link Layer. You can configure an IGMP snooping querier on a network without Layer 3 multicast devices.
Restrictions and guidelines
Do not enable the IGMP snooping querier on a multicast network that runs IGMP. An IGMP snooping querier does not take part in IGMP querier elections. However, it might affect IGMP querier elections if it sends IGMP general queries with a low source IP address.
On a VXLAN network, the IGMP snooping querier in a VSI does not include VLAN tags in IGMP general queries. As a best practice, do not enable the IGMP snooping querier in a VSI if the VSI uses the Ethernet access mode. For more information about the Ethernet access mode, see VXLAN Configuration Guide.
Enabling the IGMP snooping querier for a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Enable the IGMP snooping querier for the VLAN.
igmp-snooping querier
By default, the IGMP snooping querier is disabled for a VLAN.
Enabling the IGMP snooping querier for a VSI
1. Enter system view.
system-view
2. Enter VSI view.
vsi vsi-name
3. Enable the IGMP snooping querier for the VSI.
igmp-snooping querier
By default, the IGMP snooping querier is disabled for a VSI.
Configuring parameters for IGMP general queries and responses
About this task
You can modify the IGMP general query interval for a VLAN or VSI based on the actual condition of the network.
A receiver host starts a report delay timer for each multicast group that it has joined when it receives an IGMP general query. This timer is set to a random value in the range of 0 to the maximum response time advertised in the query. When the timer value decreases to 0, the host sends an IGMP report to the corresponding multicast group.
Set an appropriate value for the maximum response time for IGMP general queries to speed up hosts' responses to IGMP general queries and avoid IGMP report traffic bursts.
Restrictions and guidelines
To avoid mistakenly deleting multicast group members, make sure the IGMP general query interval is greater than the maximum response time for IGMP general queries.
Configuring parameters for IGMP general queries and responses globally
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Set the maximum response time for IGMP general queries.
max-response-time seconds
By default, the maximum response time for IGMP general queries is 10 seconds.
Configuring parameters for IGMP general queries and responses in a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Set the IGMP general query interval in the VLAN.
igmp-snooping query-interval interval
By default, the IGMP general query interval is 125 seconds for a VLAN.
4. Set the maximum response time for IGMP general queries in the VLAN.
igmp-snooping max-response-time seconds
By default, the maximum response time for IGMP general queries is 10 seconds for a VLAN.
Configuring parameters for IGMP general queries and responses in a VSI
1. Enter system view.
system-view
2. Enter VSI view.
vsi vsi-name
3. Set the IGMP general query interval in the VSI.
igmp-snooping query-interval interval
By default, the IGMP general query interval is 125 seconds for a VSI.
4. Set the maximum response time for IGMP general queries in the VSI.
igmp-snooping max-response-time seconds
By default, the maximum response time for IGMP general queries is 10 seconds for a VSI.
Enabling IGMP snooping proxying
About this task
The device enabled with IGMP snooping proxying is called an IGMP snooping proxy. The IGMP snooping proxy acts as a host to the upstream device. Enabled with IGMP snooping querier, the IGMP snooping proxy acts as the router to downstream devices and receives report and leave messages on behalf of the upstream device. As a best practice, enable IGMP snooping proxy on the edge device to alleviate the effect caused by excessive packets.
Restrictions and guidelines
Before you enable IGMP snooping proxying for a VLAN or VSI, you must first enable IGMP snooping globally and enable IGMP snooping for the VLAN or VSI. IGMP snooping proxying does not take effect on sub VLANs of a multicast VLAN.
Use this feature with IGMP snooping querier. For more information about enabling IGMP snooping querier, see "Enabling the IGMP snooping querier."
Enabling IGMP snooping proxying for a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Enable IGMP snooping proxying for the VLAN.
igmp-snooping proxy enable
By default, IGMP snooping proxying is disabled for a VLAN.
Enabling IGMP snooping proxying for a VSI
1. Enter system view.
system-view
2. Enter VSI view.
vsi vsi-name
3. Enable IGMP snooping proxying for the VSI.
igmp-snooping proxy enable
By default, IGMP snooping proxying is disabled for a VSI.
Configuring parameters for IGMP messages
Configuring source IP addresses for IGMP messages
About this task
The IGMP snooping querier might send IGMP general queries with the source IP address 0.0.0.0. The port that receives such queries will not be maintained as a dynamic router port. This might prevent the associated dynamic IGMP snooping forwarding entry from being correctly created at the data link layer and eventually cause multicast traffic forwarding failures. To avoid this problem, you can configure a non-all-zero IP address as the source IP address of the IGMP queries on the IGMP snooping querier. This configuration might affect the IGMP querier election within the subnet.
You can also change the source IP address of IGMP reports or leave messages sent by a simulated member host or an IGMP snooping proxy.
Configuring the source IP addresses for IGMP messages in a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Configure the source IP address for IGMP general queries.
igmp-snooping general-query source-ip ip-address
By default, the source IP address of IGMP general queries is the IP address of the current VLAN interface. If the current VLAN interface does not have an IP address, the source IP address is 0.0.0.0.
4. Configure the source IP address for IGMP group-specific queries.
igmp-snooping special-query source-ip ip-address
By default, the source IP address of IGMP group-specific queries is one of the following:
¡ The source address of IGMP group-specific queries if the IGMP snooping querier of the VLAN has received IGMP general queries.
¡ The IP address of the current VLAN interface if the IGMP snooping querier does not receive an IGMP general query.
¡ 0.0.0.0 if the IGMP snooping querier does not receive an IGMP general query and the current VLAN interface does not have an IP address.
5. Configure the source IP address for IGMP reports.
igmp-snooping report source-ip ip-address
By default, the source IP address of IGMP reports is the IP address of the current VLAN interface. If the current VLAN interface does not have an IP address, the source IP address is 0.0.0.0.
6. Configure the source IP address for IGMP leave messages.
igmp-snooping leave source-ip ip-address
By default, the source IP address of IGMP leave messages is the IP address of the current VLAN interface. If the current VLAN interface does not have an IP address, the source IP address is 0.0.0.0.
Configuring the source IP addresses for IGMP messages in a VSI
1. Enter system view.
system-view
2. Enter VSI view.
vsi vsi-name
3. Configure the source IP address for IGMP general queries.
igmp-snooping general-query source-ip ip-address
By default, the source IP address of IGMP general queries is the IP address of the gateway interface for a VSI. If the gateway interface does not have an IP address, the source IP address is 0.0.0.0.
4. Configure the source IP address for IGMP group-specific queries.
igmp-snooping special-query source-ip ip-address
By default, the source IP address of IGMP group-specific queries is one of the following:
¡ The source IP address of IGMP general queries if the IGMP snooping querier of a VSI has received IGMP general queries.
¡ The IP address of the gateway interface for the VSI if the IGMP snooping querier does not receive an IGMP general query.
¡ 0.0.0.0 if the gateway interface of the VSI does not have an IP address.
5. Configure the source IP address for IGMP reports.
igmp-snooping report source-ip ip-address
By default, the source IP address of IGMP reports is the IP address of the gateway interface for a VSI. If the gateway interface does not have an IP address, the source IP address is 0.0.0.0.
6. Configure the source IP address for IGMP leave messages.
igmp-snooping leave source-ip ip-address
By default, the source IP address of IGMP leave messages is the IP address of the gateway interface for a VSI. If the gateway interface does not have an IP address, the source IP address is 0.0.0.0.
Configuring IGMP snooping policies
Configuring a multicast group policy
About this task
This feature enables the Layer 2 device to filter IGMP reports by using an ACL that specifies the multicast groups and the optional sources. It is used to control the multicast groups that hosts can join. This configuration takes effect only on the multicast groups that ports join dynamically.
In a multicast application, a host sends an unsolicited IGMP report when a user requests a multicast program. The Layer 2 device uses the multicast group policy to filter the IGMP report. The host can join the multicast group only if the IGMP report is permitted by the multicast group policy.
Configuring a multicast group policy globally
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Configure a multicast group policy globally.
group-policy ipv4-acl-number [ vlan vlan-list ]
By default, no multicast group policies are configured, and hosts can join any multicast groups.
Configuring a multicast group policy on a port
1. Enter system view.
system-view
2. Enter Layer 2 interface view.
¡ Enter Layer 2 Ethernet interface view.
interface interface-type interface-number
¡ Enter Layer 2 aggregate interface view.
interface bridge-aggregation interface-number
3. Configure a multicast group policy on the port.
igmp-snooping group-policy ipv4-acl-number [ vlan vlan-list ]
By default, no multicast group policies are configured on a port, and hosts attached to the port can join any multicast groups.
Enabling dropping unknown multicast data
About this task
This feature enables the Layer 2 device to drop all unknown multicast data. Unknown multicast data refers to multicast data for which no forwarding entries exist in the IGMP snooping forwarding table.
If you do not enable this feature, the unknown multicast data is flooded in the VLAN or VSI to which the data belongs.
Restrictions and guidelines
When dropping unknown IPv4 multicast data is enabled, the device also drops unknown IPv6 multicast data.
When this feature is enabled for a VLAN or VSI, the device still forwards unknown multicast data out of router ports except the receiving router port in this VLAN or VSI.
Enabling dropping unknown multicast data for a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Enable dropping unknown multicast data for the VLAN.
igmp-snooping drop-unknown
By default, dropping unknown multicast data is disabled for a VLAN. Unknown multicast data is flooded in the VLAN.
Enabling dropping unknown multicast data for a VSI
1. Enter system view.
system-view
2. Enter VSI view.
vsi vsi-name
3. Enable dropping unknown multicast data for the VSI.
igmp-snooping drop-unknown
By default, dropping unknown multicast data is disabled for a VSI. Unknown multicast data is flooded in the VSI.
Enabling IGMP report suppression
About this task
This feature enables the Layer 2 device to forward only the first IGMP report for a multicast group to its directly connected Layer 3 device. Other reports for the same group in the same query interval are discarded. Use this feature to reduce multicast traffic.
Procedure
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Enable IGMP report suppression.
report-aggregation
By default, IGMP report suppression is enabled.
Setting the maximum number of multicast groups on a port
About this task
You can set the maximum number of multicast groups on a port to regulate the port traffic. This feature takes effect only on the multicast groups that a port joins dynamically.
If the number of multicast groups on a port exceeds the limit, the system removes all the forwarding entries associated with the port. The receiver hosts attached to that port can join multicast groups again before the number of multicast groups on the port reaches the limit. When the number of multicast groups on the port reaches the limit, the port automatically drops IGMP reports for new groups.
Procedure
1. Enter system view.
system-view
2. Enter Layer 2 interface view.
¡ Enter Layer 2 Ethernet interface view.
interface interface-type interface-number
¡ Enter Layer 2 aggregate interface view.
interface bridge-aggregation interface-number
3. Set the maximum number of multicast groups on the port.
igmp-snooping group-limit limit [ vlan vlan-list ]
By default, no limit is placed on the maximum number of multicast groups on a port.
Enabling multicast group replacement
About this task
When multicast group replacement is enabled, the port does not drop IGMP reports for new groups if the number of multicast groups on the port reaches the upper limit. Instead, the port leaves the multicast group that has the lowest IP address and joins the new group contained in the IGMP report. The multicast group replacement feature is typically used in the channel switching application.
Restrictions and guidelines
This feature takes effect only on the multicast groups that a port joins dynamically.
This feature does not take effect if the following conditions exist:
· The number of the IGMP snooping forwarding entries on the device reaches or exceeds the upper limit.
· The multicast group that the port newly joins is not included in the multicast group list maintained by the device.
Enabling multicast group replacement globally
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Enable multicast group replacement globally.
overflow-replace [ vlan vlan-list ]
By default, multicast group replacement is disabled globally.
Enabling multicast group replacement on a port
1. Enter system view.
system-view
2. Enter Layer 2 interface view.
¡ Enter Layer 2 Ethernet interface view.
interface interface-type interface-number
¡ Enter Layer 2 aggregate interface view.
interface bridge-aggregation interface-number
3. Enable multicast group replacement on the port.
igmp-snooping overflow-replace [ vlan vlan-list ]
By default, multicast group replacement is disabled on a port.
Enabling host tracking
About this task
This feature enables the Layer 2 device to record information about member hosts that are receiving multicast data. The information includes IP addresses of the hosts, length of time elapsed since the hosts joined multicast groups, and remaining timeout time for the hosts. This feature facilitates monitoring and managing member hosts.
Restrictions and guidelines
The global configuration does not take effect on VSIs.
Enabling host tracking globally
1. Enter system view.
system-view
2. Enter IGMP-snooping view.
igmp-snooping
3. Enable host tracking globally.
host-tracking
By default, host tracking is disabled globally.
Enabling host tracking for a VLAN
1. Enter system view.
system-view
2. Enter VLAN view.
vlan vlan-id
3. Enable host tracking for the VLAN.
igmp-snooping host-tracking
By default, host tracking is disabled for a VLAN.
Enabling SNMP notifications for IGMP snooping
About this task
To report critical IGMP snooping events to an NMS, enable SNMP notifications for IGMP snooping. For IGMP snooping event notifications to be sent correctly, you must also configure SNMP on the device. For more information about SNMP configuration, see Network Management and Monitoring Configuration Guide.
Procedure
1. Enter system view.
system-view
2. Enable SNMP notifications for IGMP snooping.
snmp-agent trap enable igmp-snooping [ global-entry-exceed ]
By default, SNMP notifications for IGMP snooping are enabled.
Display and maintenance commands for IGMP snooping
Execute display commands in any view and reset commands in user view.
Task |
Command |
Display IGMP snooping status. |
display igmp-snooping [ global | vlan vlan-id | vsi vsi-name ] |
Display dynamic IGMP snooping group entries. |
In standalone mode: display igmp-snooping group [ group-address | source-address ] * [ vlan vlan-id | vsi vsi-name ] [ verbose ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display igmp-snooping group [ group-address | source-address ] * [ vlan vlan-id | vsi vsi-name ] [ verbose ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display host tracking information. |
In standalone mode: display igmp-snooping host-tracking vlan vlan-id group group-address [ source source-address ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display igmp-snooping host-tracking vlan vlan-id group group-address [ source source-address ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display dynamic router port information. |
In standalone mode: display igmp-snooping router-port [ verbose | vlan vlan-id | vsi vsi-name [ verbose ] ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display igmp-snooping router-port [ verbose | vlan vlan-id | vsi vsi-name [ verbose ] ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display static IGMP snooping group entries. |
In standalone mode: display igmp-snooping static-group [ group-address | source-address ] * [ vlan vlan-id ] [ verbose ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display igmp-snooping static-group [ group-address | source-address ] * [ vlan vlan-id ] [ verbose ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display static router port information. |
In standalone mode: display igmp-snooping static-router-port [ vlan vlan-id ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display igmp-snooping static-router-port [ vlan vlan-id ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display statistics for the IGMP messages and PIMv2 hello messages learned by IGMP snooping. |
display igmp-snooping statistics |
Display information about Layer 2 IP multicast groups. |
In standalone mode: display l2-multicast ip [ group group-address | source source-address ] * [ vlan vlan-id | vsi vsi-name ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display l2-multicast ip [ group group-address | source source-address ] * [ vlan vlan-id | vsi vsi-name ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display Layer 2 IP multicast group entries. |
In standalone mode: display l2-multicast ip forwarding [ group group-address | source source-address ] * [ vlan vlan-id | vsi vsi-name ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display l2-multicast ip forwarding [ group group-address | source source-address ] * [ vlan vlan-id | vsi vsi-name ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display information about Layer 2 MAC multicast groups. |
In standalone mode: display l2-multicast mac [ mac-address ] [ vlan vlan-id | vsi vsi-name ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display l2-multicast mac [ mac-address ] [ vlan vlan-id | vsi vsi-name ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display Layer 2 MAC multicast group entries. |
In standalone mode: display l2-multicast mac forwarding [ mac-address ] [ vlan vlan-id | vsi vsi-name ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display l2-multicast mac forwarding [ mac-address ] [ vlan vlan-id | vsi vsi-name ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Display multicast group information that IGMP snooping learns from EVPN. |
In standalone mode: display igmp-snooping evpn-group [ group-address | source-address ] * [ vsi vsi-name ] [ slot slot-number [ cpu cpu-number ] ] In IRF mode: display igmp-snooping evpn-group [ group-address | source-address ] * [ vsi vsi-name ] [ chassis chassis-number slot slot-number [ cpu cpu-number ] ] |
Clear dynamic IGMP snooping group entries. |
reset igmp-snooping group { group-address [ source-address ] | all } [ vlan vlan-id | vsi vsi-name] |
Clear dynamic router port information. |
reset igmp-snooping router-port { all | vlan vlan-id | vsi vsi-name } |
Clear statistics for IGMP messages and PIMv2 hello messages learned through IGMP snooping. |
reset igmp-snooping statistics |
IGMP snooping configuration examples
Example: Configuring VLAN-based IGMP snooping group polices and simulated joining
Network configuration
As shown in Figure 4, Router A runs IGMPv2 and acts as the IGMP querier. Device A runs IGMPv2 snooping.
Configure a multicast group policy and simulated joining to meet the following requirements:
· Host A and Host B receive only the multicast data addressed to multicast group 224.1.1.1. Multicast data can be forwarded through Ten-GigabitEthernet 3/1/3 and Ten-GigabitEthernet 3/1/4 of Device A uninterruptedly, even though Host A and Host B fail to receive the multicast data.
· Device A will drop unknown multicast data instead of flooding it in VLAN 100.
Procedure
1. Assign an IP address and subnet mask to each interface, as shown in Figure 4. (Details not shown.)
2. Configure Router A:
# Enable IP multicast routing.
<RouterA> system-view
[RouterA] multicast routing
[RouterA-mrib] quit
# Enable IGMP on Ten-GigabitEthernet 3/1/1.
[RouterA] interface ten-gigabitethernet 3/1/1
[RouterA-Ten-GigabitEthernet3/1/1] igmp enable
[RouterA-Ten-GigabitEthernet3/1/1] quit
# Enable PIM-DM on Ten-GigabitEthernet 3/1/2.
[RouterA] interface ten-gigabitethernet 3/1/2
[RouterA-Ten-GigabitEthernet3/1/2] pim dm
[RouterA-Ten-GigabitEthernet3/1/2] quit
3. Configure Device A:
# Enable IGMP snooping globally.
<DeviceA> system-view
[DeviceA] igmp-snooping
[DeviceA-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 through Ten-GigabitEthernet 3/1/4 to the VLAN.
[DeviceA] vlan 100
[DeviceA-vlan100] port ten-gigabitethernet 3/1/1 to ten-gigabitethernet 3/1/4
# Enable IGMP snooping, and enable dropping unknown multicast data for VLAN 100.
[DeviceA-vlan100] igmp-snooping enable
[DeviceA-vlan100] igmp-snooping drop-unknown
[DeviceA-vlan100] quit
# Configure a multicast group policy so that hosts in VLAN 100 can join only multicast group 224.1.1.1.
[DeviceA] acl basic 2001
[DeviceA-acl-ipv4-basic-2001] rule permit source 224.1.1.1 0
[DeviceA-acl-ipv4-basic-2001] quit
[DeviceA] igmp-snooping
[DeviceA-igmp-snooping] group-policy 2001 vlan 100
[DeviceA-igmp-snooping] quit
# Configure Ten-GigabitEthernet 3/1/3 and Ten-GigabitEthernet 3/1/4 as simulated member hosts of multicast group 224.1.1.1.
[DeviceA] interface ten-gigabitethernet 3/1/3
[DeviceA-Ten-GigabitEthernet3/1/3] igmp-snooping host-join 224.1.1.1 vlan 100
[DeviceA-Ten-GigabitEthernet3/1/3] quit
[DeviceA] interface ten-gigabitethernet 3/1/4
[DeviceA-Ten-GigabitEthernet3/1/4] igmp-snooping host-join 224.1.1.1 vlan 100
[DeviceA-Ten-GigabitEthernet3/1/4] quit
Verifying the configuration
# Send IGMP reports from Host A and Host B to join multicast groups 224.1.1.1 and 224.2.2.2. (Details not shown.)
# Display dynamic IGMP snooping group entries for VLAN 100 on Device A.
[DeviceA] display igmp-snooping group vlan 100
Total 1 entries.
VLAN 100: Total 1 entries.
(0.0.0.0, 224.1.1.1)
Host slots (0 in total):
Host ports (2 in total):
XGE3/1/3 (00:03:23)
XGE3/1/4 (00:04:10)
The output shows the following information:
· Host A and Host B have joined multicast group 224.1.1.1 through the member ports Ten-GigabitEthernet 3/1/4 and Ten-GigabitEthernet 3/1/3 on Device A, respectively.
· Host A and Host B have failed to join multicast group 224.2.2.2.
Example: Configuring VLAN-based IGMP snooping static ports
Network configuration
As shown in Figure 5:
· Router A runs IGMPv2 and acts as the IGMP querier. Device A, Device B, and Device C run IGMPv2 snooping.
· Host A and host C are permanent receivers of multicast group 224.1.1.1.
Configure static ports to meet the following requirements:
· To enhance the reliability of multicast traffic transmission, configure Ten-GigabitEthernet 3/1/3 and Ten-GigabitEthernet 3/1/5 on Device C as static member ports for multicast group 224.1.1.1.
· Suppose the STP runs on the network. To avoid data loops, the forwarding path from Device A to Device C is blocked. Multicast data flows to the receivers attached to Device C only along the path of Device A—Device B—Device C. When this path is blocked, a minimum of one IGMP query-response cycle must be completed before multicast data flows to the receivers along the path of Device A—Device C. In this case, the multicast delivery is interrupted during the process. For more information about the STP, see Layer 2—LAN Deviceing Configuration Guide.
Configure Ten-GigabitEthernet 3/1/3 on Device A as a static router port. Then, multicast data can flow to the receivers nearly uninterruptedly along the path of Device A—Device C when the path of Device A—Device B—Device C is blocked.
Procedure
1. Assign an IP address and subnet mask to each interface, as shown in Figure 5. (Details not shown.)
2. Configure Router A:
# Enable IP multicast routing.
<RouterA> system-view
[RouterA] multicast routing
[RouterA-mrib] quit
# Enable IGMP on Ten-GigabitEthernet 3/1/1.
[RouterA] interface ten-gigabitethernet 3/1/1
[RouterA-Ten-GigabitEthernet3/1/1] igmp enable
[RouterA-Ten-GigabitEthernet3/1/1] quit
# Enable PIM-DM on Ten-GigabitEthernet 3/1/2.
[RouterA] interface ten-gigabitethernet 3/1/2
[RouterA-Ten-GigabitEthernet3/1/2] pim dm
[RouterA-Ten-GigabitEthernet3/1/2] quit
3. Configure Device A:
# Enable IGMP snooping globally.
<DeviceA> system-view
[DeviceA] igmp-snooping
[DeviceA-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 through Ten-GigabitEthernet 3/1/3 to the VLAN.
[DeviceA] vlan 100
[DeviceA-vlan100] port ten-gigabitethernet 3/1/1 to ten-gigabitethernet 3/1/3
# Enable IGMP snooping for VLAN 100.
[DeviceA-vlan100] igmp-snooping enable
[DeviceA-vlan100] quit
# Configure Ten-GigabitEthernet 3/1/3 as a static router port.
[DeviceA] interface ten-gigabitethernet 3/1/3
[DeviceA-Ten-GigabitEthernet3/1/3] igmp-snooping static-router-port vlan 100
[DeviceA-Ten-GigabitEthernet3/1/3] quit
4. Configure Device B:
# Enable IGMP snooping globally.
<DeviceB> system-view
[DeviceB] igmp-snooping
[DeviceB-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 and Ten-GigabitEthernet 3/1/2 to the VLAN.
[DeviceB] vlan 100
[DeviceB-vlan100] port ten-gigabitethernet 3/1/1 ten-gigabitethernet 3/1/2
# Enable IGMP snooping for VLAN 100.
[DeviceB-vlan100] igmp-snooping enable
[DeviceB-vlan100] quit
5. Configure Device C:
# Enable IGMP snooping globally.
<DeviceC> system-view
[DeviceC] igmp-snooping
[DeviceC-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 through Ten-GigabitEthernet 3/1/5 to the VLAN.
[DeviceC] vlan 100
[DeviceC-vlan100] port ten-gigabitethernet 3/1/1 to ten-gigabitethernet 3/1/5
# Enable IGMP snooping for VLAN 100.
[DeviceC-vlan100] igmp-snooping enable
[DeviceC-vlan100] quit
# Configure Ten-GigabitEthernet 3/1/3 and Ten-GigabitEthernet 3/1/5 as static member ports for multicast group 224.1.1.1.
[DeviceC] interface ten-gigabitethernet 3/1/3
[DeviceC-Ten-GigabitEthernet3/1/3] igmp-snooping static-group 224.1.1.1 vlan 100
[DeviceC-Ten-GigabitEthernet3/1/3] quit
[DeviceC] interface ten-gigabitethernet 3/1/5
[DeviceC-Ten-GigabitEthernet3/1/5] igmp-snooping static-group 224.1.1.1 vlan 100
[DeviceC-Ten-GigabitEthernet3/1/5] quit
Verifying the configuration
# Display static router port information for VLAN 100 on Device A.
[DeviceA] display igmp-snooping static-router-port vlan 100
VLAN 100:
Router slots (0 in total):
Router ports (1 in total):
XGE3/1/3
The output shows that Ten-GigabitEthernet 3/1/3 on Device A has become a static router port.
# Display static IGMP snooping group entries for VLAN 100 on Device C.
[DeviceC] display igmp-snooping static-group vlan 100
Total 1 entries.
VLAN 100: Total 1 entries.
(0.0.0.0, 224.1.1.1)
Host slots (0 in total):
Host ports (2 in total):
XGE3/1/3
XGE3/1/5
The output shows that Ten-GigabitEthernet 3/1/3 and Ten-GigabitEthernet 3/1/5 on Device C have become static member ports of multicast group 224.1.1.1.
Example: Configuring the VLAN-based IGMP snooping querier
Network configuration
As shown in Figure 6:
· The network is a Layer 2-only network.
· Source 1 and Source 2 send multicast data to multicast groups 224.1.1.1 and 225.1.1.1, respectively.
· Host A and Host C are receivers of multicast group 224.1.1.1, and Host B and Host D are receivers of multicast group 225.1.1.1.
· All host receivers run IGMPv2, and all switches run IGMPv2 snooping. Device A (which is close to the multicast sources) acts as the IGMP snooping querier.
Configure the switches to meet the following requirements:
· To prevent the switches from flooding unknown data in the VLAN, enable all the switches to drop unknown multicast data.
· A switch does not mark a port that receives an IGMP query with source IP address 0.0.0.0 as a dynamic router port. This adversely affects the establishment of Layer 2 forwarding entries and multicast traffic forwarding. To avoid this, configure the source IP address of IGMP queries as a non-zero IP address.
Procedure
1. Configure Device A:
# Enable IGMP snooping globally.
<DeviceA> system-view
[DeviceA] igmp-snooping
[DeviceA-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 through Ten-GigabitEthernet 3/1/3 to the VLAN.
[DeviceA] vlan 100
[DeviceA-vlan100] port ten-gigabitethernet 3/1/1 to ten-gigabitethernet 3/1/3
# Enable IGMP snooping, and enable dropping unknown multicast data for VLAN 100.
[DeviceA-vlan100] igmp-snooping enable
[DeviceA-vlan100] igmp-snooping drop-unknown
# Configure Device A as the IGMP snooping querier.
[DeviceA-vlan100] igmp-snooping querier
[DeviceA-vlan100] quit
# In VLAN 100, specify 192.168.1.1 as the source IP address of IGMP general queries.
[DeviceA-vlan100] igmp-snooping general-query source-ip 192.168.1.1
# In VLAN 100, specify 192.168.1.1 as the source IP address of IGMP group-specific queries.
[DeviceA-vlan100] igmp-snooping special-query source-ip 192.168.1.1
[DeviceA-vlan100] quit
2. Configure Device B:
# Enable IGMP snooping globally.
<DeviceB> system-view
[DeviceB] igmp-snooping
[DeviceB-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 through Ten-GigabitEthernet 3/1/4 to the VLAN.
[DeviceB] vlan 100
[DeviceB-vlan100] port ten-gigabitethernet 3/1/1 to ten-gigabitethernet 3/1/4
# Enable IGMP snooping, and enable dropping unknown multicast data for VLAN 100.
[DeviceB-vlan100] igmp-snooping enable
[DeviceB-vlan100] igmp-snooping drop-unknown
[DeviceB-vlan100] quit
3. Configure Device C:
# Enable IGMP snooping globally.
<DeviceC> system-view
[DeviceC] igmp-snooping
[DeviceC-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 through Ten-GigabitEthernet 3/1/3 to the VLAN.
[DeviceC] vlan 100
[DeviceC-vlan100] port ten-gigabitethernet 3/1/1 to ten-gigabitethernet 3/1/3
# Enable IGMP snooping, and enable dropping unknown multicast data for VLAN 100.
[DeviceC-vlan100] igmp-snooping enable
[DeviceC-vlan100] igmp-snooping drop-unknown
[DeviceC-vlan100] quit
4. Configure Device D:
# Enable IGMP snooping globally.
<DeviceD> system-view
[DeviceD] igmp-snooping
[DeviceD-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 and Ten-GigabitEthernet 3/1/2 to the VLAN.
[DeviceD] vlan 100
[DeviceD-vlan100] port ten-gigabitethernet 3/1/1 to ten-gigabitethernet 3/1/2
# Enable IGMP snooping, and enable dropping unknown multicast data for VLAN 100.
[DeviceD-vlan100] igmp-snooping enable
[DeviceD-vlan100] igmp-snooping drop-unknown
[DeviceD-vlan100] quit
Verifying the configuration
# Display statistics for IGMP messages and PIMv2 hello messages learned through IGMP snooping on Device B.
[DeviceB] display igmp-snooping statistics
Received IGMP general queries: 3
Received IGMPv1 reports: 0
Received IGMPv2 reports: 12
Received IGMP leaves: 0
Received IGMPv2 specific queries: 0
Sent IGMPv2 specific queries: 0
Received IGMPv3 reports: 0
Received IGMPv3 reports with right and wrong records: 0
Received IGMPv3 specific queries: 0
Received IGMPv3 specific sg queries: 0
Sent IGMPv3 specific queries: 0
Sent IGMPv3 specific sg queries: 0
Received PIMv2 hello: 0
Received error IGMP messages: 0
The output shows that all switches except Device A can receive the IGMP general queries after Device A acts as the IGMP snooping querier.
Example: Configuring VLAN-based IGMP snooping proxying
Network configuration
As shown in Figure 7, Router A runs IGMPv2 and acts as the IGMP querier. Device A runs IGMPv2 snooping. Configure IGMP snooping proxying so that Device A can perform the following actions:
· Forward IGMP report and leave messages to Router A.
· Respond to IGMP queries sent by Router A and forward the queries to downstream hosts.
Procedure
1. Assign an IP address and subnet mask to each interface, as shown in Figure 7. (Details not shown.)
2. Configure Router A:
# Enable IP multicast routing.
<RouterA> system-view
[RouterA] multicast routing
[RouterA-mrib] quit
# Enable IGMP and PIM-DM on Ten-GigabitEthernet 3/1/1.
[RouterA] interface ten-gigabitethernet 3/1/1
[RouterA-Ten-GigabitEthernet3/1/1] igmp enable
[RouterA-Ten-GigabitEthernet3/1/1] pim dm
[RouterA-Ten-GigabitEthernet3/1/1] quit
# Enable PIM-DM on Ten-GigabitEthernet 3/1/2.
[RouterA] interface ten-gigabitethernet 3/1/2
[RouterA-Ten-GigabitEthernet3/1/2] pim dm
[RouterA-Ten-GigabitEthernet3/1/2] quit
3. Configure Device A:
# Enable IGMP snooping globally.
<DeviceA> system-view
[DeviceA] igmp-snooping
[DeviceA-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/1 through Ten-GigabitEthernet 3/1/4 to the VLAN.
[DeviceA] vlan 100
[DeviceA-vlan100] port ten-gigabitethernet 3/1/1 to ten-gigabitethernet 3/1/4
# Enable IGMP snooping and IGMP snooping proxying for the VLAN.
[DeviceA-vlan100] igmp-snooping enable
[DeviceA-vlan100] igmp-snooping proxy enable
[DeviceA-vlan100] quit
Verifying the configuration
# Send IGMP reports from Host A and Host B to join multicast groups 224.1.1.1 and 224.1.1.1. (Details not shown.)
# Display brief information about IGMP snooping group entries on Device A.
[DeviceA] display igmp-snooping group
Total 1 entries.
VLAN 100: Total 1 entries.
(0.0.0.0, 224.1.1.1)
Host ports (2 in total):
XGE3/1/3 (00:04:00)
XGE3/1/4 (00:04:04)
The output shows that Ten-GigabitEthernet3/1/3 and Ten-GigabitEthernet3/1/4 are member ports of multicast group 224.1.1.1. Host A and Host B become receivers of the group.
# Display IGMP group membership information on Router A.
[RouterA] display igmp group
IGMP groups in total: 1
Ten-GigabitEthernet3/1/1(10.1.1.1):
IGMP groups reported in total: 1
Group address Last reporter Uptime Expires
224.1.1.1 0.0.0.0 00:00:31 00:02:03
# Send an IGMP leave message from Host A to leave multicast group 224.1.1.1. (Details not shown.)
# Display brief information about IGMP snooping group entries on Device A.
[DeviceA] display igmp-snooping group
Total 1 entries.
VLAN 100: Total 1 entries.
(0.0.0.0, 224.1.1.1)
Host ports (1 in total):
XGE3/1/3 ( 00:01:23 )
The output shows that Ten-GigabitEthernet3/1/3 is the only member port of multicast group 224.1.1.1. Only Host B remains as the receiver of the group.
Example: Configuring VSI-based IGMP snooping
Network configuration
As shown in Figure 8:
· There are three sites in VPN a. They are connected through the VPLS network.
· In VLAN 100, Source in Site 1, Host A in Site 2, and Host B in Site 3 communicate with CE 1, CE 2, and CE 3, respectively.
Configure the devices so that Host A and Host B can receive multicast data from Source.
Table 1 Interface and IP address assignment
Device |
Interface |
IP address |
Device |
Interface |
IP address |
PE 1 |
Vlan-int101 |
10.110.1.1/24 |
PE 2 |
Loop0 |
2.2.2.2/32 |
PE 1 |
Vlan-int102 |
10.110.2.1/24 |
PE 3 |
Loop0 |
10.110.2.2/24 |
PE 1 |
Loop0 |
1.1.1.1/32 |
PE 3 |
Loop0 |
10.110.3.2/24 |
PE 2 |
Vlan-int101 |
10.110.1.2/24 |
PE 3 |
Loop0 |
3.3.3.3/32 |
PE 2 |
Vlan-int103 |
10.110.3.1/24 |
|
|
|
Procedure
1. Assign an IP address and subnet mask to each interface on the VPLS network, as shown in Table 1. (Details not shown.)
2. Configure OSPF on the switches on the VPLS network. (Details not shown.)
3. Configure CE 1:
# Enable IGMP snooping globally.
<CE1> system-view
[CE1] igmp-snooping
[CE1-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/2 to VLAN 100.
[CE1] vlan 100
[CE1-vlan100] port ten-gigabitethernet 3/1/2
# In VLAN 100, enable IGMP snooping, and enable dropping unknown multicast data.
[CE1-vlan100] igmp-snooping enable
[CE1-vlan100] igmp-snooping drop-unknown
# Configure Ten-GigabitEthernet 3/1/1 as a trunk port, and assign it to VLAN 100.
[CE1] interface ten-gigabitethernet 3/1/1
[CE1-Ten-GigabitEthernet3/1/1] port link-type trunk
[CE1-Ten-GigabitEthernet3/1/1] port trunk permit vlan 100
[CE1-Ten-GigabitEthernet3/1/1] quit
# In VLAN 100, enable the IGMP snooping querier.
[CE1-vlan100] igmp-snooping querier
# In VLAN 100, specify 192.168.1.100 as the source IP address of IGMP general queries and IGMP group-specific queries.
[CE1-vlan100] igmp-snooping general-query source-ip 192.168.1.100
[CE1-vlan100] igmp-snooping special-query source-ip 192.168.1.100
4. Configure CE 2:
# Enable IGMP snooping globally.
<CE2> system-view
[CE2] igmp-snooping
[CE2-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/2 to VLAN100.
[CE2] vlan 100
[CE2-vlan100] port ten-gigabitethernet 3/1/2
# In VLAN 100, enable IGMP snooping, and enable dropping unknown multicast data.
[CE2-vlan100] igmp-snooping enable
[CE2-vlan100] igmp-snooping drop-unknown
# Configure Ten-GigabitEthernet 3/1/1 as a trunk port, and assign it to VLAN 100.
[CE2] interface ten-gigabitethernet 3/1/1
[CE2-Ten-GigabitEthernet3/1/1] port link-type trunk
[CE2-Ten-GigabitEthernet3/1/1] port trunk permit vlan 100
[CE2-Ten-GigabitEthernet3/1/1] quit
5. Configure CE 3:
# Enable IGMP snooping globally.
<CE3> system-view
[CE3] igmp-snooping
[CE3-igmp-snooping] quit
# Create VLAN 100, and assign Ten-GigabitEthernet 3/1/2 to VLAN100.
[CE3] vlan 100
[CE3-vlan100] port ten-gigabitethernet 3/1/2
# In VLAN 100, enable IGMP snooping, and dropping unknown multicast data.
[CE3-vlan100] igmp-snooping enable
[CE3-vlan100] igmp-snooping drop-unknown
# Configure Ten-GigabitEthernet 3/1/1 as a trunk port, and assign it to VLAN 100.
[CE3] interface ten-gigabitethernet 3/1/1
[CE3-Ten-GigabitEthernet3/1/1] port link-type trunk
[CE3-Ten-GigabitEthernet3/1/1] port trunk permit vlan 100
[CE3-Ten-GigabitEthernet3/1/1] quit
6. Configure PE 1:
# Configure the LSR ID as 1.1.1.1 for the local node, and enable L2VPN and LDP.
<PE1> system-view
[PE1] mpls lsr-id 1.1.1.1
[PE1] l2vpn enable
[PE1] mpls ldp
[PE1-ldp] quit
# Enable MPLS and LDP on VLAN-interface 101.
[PE1] interface vlan-interface 101
[PE1-Vlan-interface101] mpls enable
[PE1-Vlan-interface101] mpls ldp enable
[PE1-Vlan-interface101] quit
# Enable MPLS and LDP on VLAN-interface 102.
[PE1] interface vlan-interface 102
[PE1-Vlan-interface102] mpls enable
[PE1-Vlan-interface102] mpls ldp enable
[PE1-Vlan-interface102] quit
# Create a VSI named aaa, and specify the VSI to establish PWs statically.
[PE1] vsi aaa
[PE1-vsi-aaa] pwsignaling static
# Configure PWs for VSI aaa.
[PE1-vsi-aaa-static] peer 2.2.2.2 pw-id 3 in-label 100 out-label 100
[PE1-vsi-aaa-static-2.2.2.2-3] quit
[PE1-vsi-aaa-static] peer 3.3.3.3 pw-id 3 in-label 200 out-label 200
[PE1-vsi-aaa-static-3.3.3.3-3] quit
[PE1-vsi-aaa-static] quit
[PE1-vsi-aaa] quit
# Bind Ten-GigabitEthernet 3/1/1 to VSI aaa.
[PE1] interface ten-gigabitethernet 3/1/1
[PE1-Ten-GigabitEthernet3/1/1] service-instance 1
[PE1-Ten-GigabitEthernet3/1/1-srv1] encapsulation s-vid 5
[PE1-Ten-GigabitEthernet3/1/1-srv1] xconnect vsi aaa
[PE1-Ten-GigabitEthernet3/1/1-srv1] quit
[PE1-Ten-GigabitEthernet3/1/1] quit
# Enable IGMP snooping globally.
[PE1] igmp-snooping
[PE1-igmp-snooping] quit
# Enable IGMP snooping, and enable dropping unknown multicast data for VSI aaa.
[PE1] vsi aaa
[PE1-vsi-aaa] igmp-snooping enable
[PE1-vsi-aaa] igmp-snooping drop-unknown
[PE1-vsi-aaa] quit
7. Configure PE 2:
# Configure the LSR ID as 2.2.2.2 for the local node, and enable L2VPN and LDP.
<PE2> system-view
[PE2] mpls lsr-id 2.2.2.2
[PE2] l2vpn enable
[PE2] mpls ldp
[PE2-ldp] quit
# Enable MPLS and LDP on VLAN-interface 101.
[PE2] interface vlan-interface 101
[PE2-Vlan-interface101] mpls enable
[PE2-Vlan-interface101] mpls ldp enable
[PE2-Vlan-interface101] quit
# Enable MPLS and LDP on VLAN-interface 103.
[PE2] interface vlan-interface 103
[PE2-Vlan-interface103] mpls enable
[PE2-Vlan-interface103] mpls ldp enable
[PE2-Vlan-interface103] quit
# Create a VSI named aaa, and specify the VSI to establish PWs statically.
[PE2] vsi aaa
[PE2-vsi-aaa] pwsignaling static
# Configure PWs for VSI aaa.
[PE2-vsi-aaa-static] peer 1.1.1.1 pw-id 3 in-label 100 out-label 100
[PE2-vsi-aaa-static-1.1.1.1-3] quit
[PE2-vsi-aaa-static] peer 3.3.3.3 pw-id 3 in-label 300 out-label 300
[PE2-vsi-aaa-static-3.3.3.3-3] quit
[PE2-vsi-aaa-static] quit
[PE2-vsi-aaa] quit
# Bind Ten-GigabitEthernet 3/1/1 to VSI aaa.
[PE2] interface ten-gigabitethernet 3/1/1
[PE2-Ten-GigabitEthernet3/1/1] service-instance 1
[PE2-Ten-GigabitEthernet3/1/1-srv1] encapsulation s-vid 5
[PE2-Ten-GigabitEthernet3/1/1-srv1] xconnect vsi aaa
[PE2-Ten-GigabitEthernet3/1/1-srv1] quit
[PE2-Ten-GigabitEthernet3/1/1] quit
# Enable IGMP snooping globally.
[PE2] igmp-snooping
[PE2-igmp-snooping] quit
# In VSI aaa, enable IGMP snooping, and enable dropping unknown multicast data.
[PE2] vsi aaa
[PE2-vsi-aaa] igmp-snooping enable
[PE2-vsi-aaa] igmp-snooping drop-unknown
[PE2-vsi-aaa] quit
8. Configure PE 3:
# Configure the LSR ID as 3.3.3.3 for the local node, and enable L2VPN and LDP.
<PE3> system-view
[PE3] mpls lsr-id 3.3.3.3
[PE3] l2vpn enable
[PE3] mpls ldp
[PE3-ldp] quit
# Enable MPLS and LDP on VLAN-interface 102.
[PE3] interface vlan-interface 102
[PE3-Vlan-interface102] mpls enable
[PE3-Vlan-interface102] mpls ldp enable
[PE3-Vlan-interface102] quit
# Enable MPLS and LDP on VLAN-interface 103.
[PE3] interface vlan-interface 103
[PE3-Vlan-interface103] mpls enable
[PE3-Vlan-interface103] mpls ldp enable
[PE3-Vlan-interface103] quit
# Create a VSI named aaa, and specify the VSI to establish PWs statically.
[PE3] vsi aaa
[PE3-vsi-aaa] pwsignaling static
# Configure PWs for VSI aaa.
[PE3-vsi-aaa-static] peer 1.1.1.1 pw-id 3 in-label 200 out-label 200
[PE3-vsi-aaa-static-1.1.1.1-3] quit
[PE3-vsi-aaa-static] peer 2.2.2.2 pw-id 3 in-label 300 out-label 300
[PE3-vsi-aaa-static-2.2.2.2-3] quit
[PE3-vsi-aaa-static] quit
[PE3-vsi-aaa] quit
# Bind Ten-GigabitEthernet 3/1/1 to VSI aaa.
[PE3] interface ten-gigabitethernet 3/1/1
[PE3-Ten-GigabitEthernet3/1/1] service-instance 1
[PE3-Ten-GigabitEthernet3/1/1-srv1] encapsulation s-vid 5
[PE3-Ten-GigabitEthernet3/1/1-srv1] xconnect vsi aaa
[PE3-Ten-GigabitEthernet3/1/1-srv1] quit
[PE3-Ten-GigabitEthernet3/1/1] quit
# Enable IGMP snooping globally.
[PE3] igmp-snooping
[PE3-igmp-snooping] quit
# In VSI aaa, enable IGMP snooping, and enable dropping unknown multicast data.
[PE3] vsi aaa
[PE3-vsi-aaa] igmp-snooping enable
[PE3-vsi-aaa] igmp-snooping drop-unknown
[PE3-vsi-aaa] quit
Verifying the configuration
# Display detailed information about dynamic IGMP snooping group entries for VSI aaa on PE 1.
[PE1] display igmp-snooping group vsi aaa verbose
Total 1 entries.
VSI aaa: Total 1 entries.
(0.0.0.0, 225.0.0.1)
Attribute: global port
FSM information: normal
Host slots (0 in total):
Host ports (1 in total):
NPW (VSI index 0 Link ID 9) (00:02:24)
VLAN pairs (1 in total):
Out VLAN 100 In VLAN 0 (00:02:24)
# Display detailed information about dynamic router ports for VSI aaa on PE 1.
[PE1] display igmp-snooping router-port vsi aaa verbose
VSI aaa:
Router slots (0 in total):
Router ports (1 in total):
AC (VSI index 0 Link ID 0) (00:01:46)
VLAN pairs (1 in total):
Out VLAN 100 In VLAN 0 (00:01:46)
# Display detailed information about dynamic IGMP snooping group entries for VSI aaa on PE 2.
[PE2] display igmp-snooping group vsi aaa verbose
Total 1 entries.
VSI aaa: Total 1 entries.
(0.0.0.0, 225.0.0.1)
Attribute: global port
FSM information: normal
Host slots (0 in total):
Host ports (1 in total):
NPW (VSI index 0 Link ID 8) (00:02:07)
VLAN pairs (1 in total):
Out VLAN 100 In VLAN 0 (00:02:07)
# Display detailed information about dynamic router ports for VSI aaa on PE 2.
[PE2] display igmp-snooping router-port vsi aaa verbose
VSI aaa:
Router slots (0 in total):
Router ports (1 in total):
NPW (VSI index 0 Link ID 9) (00:01:26)
VLAN pairs (1 in total):
Out VLAN 100 In VLAN 0 (00:01:26)
# Display detailed information about dynamic IGMP snooping group entries for VSI aaa on PE 3.
[PE3] display igmp-snooping group vsi aaa verbose
Total 1 entries.
VSI aaa: Total 1 entries.
(0.0.0.0, 225.0.0.1)
Attribute: global port
FSM information: normal
Host slots (0 in total):
Host ports (1 in total):
AC (VSI index 0 Link ID 0) (00:02:04)
VLAN pairs (1 in total):
Out VLAN 100 In VLAN 0 (00:02:04)
# Display detailed information about dynamic router ports for VSI aaa on PE 3.
[PE3] display igmp-snooping router-port vsi aaa verbose
VSI aaa:
Router slots (0 in total):
Router ports (1 in total):
NPW (VSI index 0 Link ID 9) (00:01:24)
VLAN pairs (1 in total):
Out VLAN 100 In VLAN 0 (00:01:24)
Example: Configuring VXLAN-based IGMP snooping
Network configuration
As shown in Figure 9:
· VXLAN 10 provides Layer 2 connectivity for VM 1, VM 2, and VM 3 across the network sites.
· VXLAN 10 uses the unicast mode for flood traffic.
Configure IGMP snooping on the switches to implement Layer 2 multicast forwarding and reduce the burden of replicating known multicast traffic for VTEPs in VXLAN 10.
Table 2 Interface and IP address assignment
Device |
Interface |
IP address |
Device |
Interface |
IP address |
Device A |
Vlan-int11 |
11.1.1.1/24 |
Device C |
Vlan-int13 |
13.1.1.3/24 |
Device A |
Loop0 |
1.1.1.1/32 |
Device C |
Loop0 |
3.3.3.3/32 |
Device B |
Vlan-int12 |
12.1.1.2/24 |
Device D |
Vlan-int11 |
11.1.1.4/24 |
Device B |
Loop0 |
2.2.2.2/32 |
Device D |
Vlan-int12 |
12.1.1.4/24 |
|
|
|
Device D |
Vlan-int13 |
13.1.1.4/24 |
Procedure
1. Assign an IP address and subnet mask to each interface on the transport network, as shown in Table 2. (Details not shown.)
2. Configure OSPF on all the switches in the transport network. (Details not shown.)
3. Configure Device A:
# Enable L2VPN.
<DeviceA> system-view
[DeviceA] l2vpn enable
# Enable Layer 2 forwarding for VXLANs.
[DeviceA] undo vxlan ip-forwarding
# Create a VSI named vpna, and create VXLAN 10.
[DeviceA] vsi vpna
[DeviceA-vsi-vpna] vxlan 10
[DeviceA-vsi-vpna-vxlan-10] quit
[DeviceA-vsi-vpna] quit
# Enable IGMP snooping globally.
[DeviceA] igmp-snooping
[DeviceA-igmp-snooping] quit
# Enable IGMP snooping and dropping unknown multicast data packets for VSI vpna.
[DeviceA] vsi vpna
[DeviceA-vsi-vpna] igmp-snooping enable
[DeviceA-vsi-vpna] igmp-snooping drop-unknown
[DeviceA-vsi-vpna] quit
# Assign an IP address to Loopback 0. This IP address will be used as the source address of the VXLAN tunnels to Device B and Device C.
[DeviceA] interface loopback 0
[DeviceA-Loopback0] ip address 1.1.1.1 255.255.255.255
[DeviceA-Loopback0] quit
# Create a VXLAN tunnel to Device B.
¡ The tunnel interface name is Tunnel 1.
¡ The source address and destination address of the tunnel interface are 1.1.1.1 and 2.2.2.2, respectively.
[DeviceA] interface tunnel 1 mode vxlan
[DeviceA-Tunnel1] source 1.1.1.1
[DeviceA-Tunnel1] destination 2.2.2.2
[DeviceA-Tunnel1] quit
# Create a VXLAN tunnel to Device C.
¡ The tunnel interface name is Tunnel 2.
¡ The source address and destination address of the tunnel interface are 1.1.1.1 and 3.3.3.3, respectively.
[DeviceA] interface tunnel 2 mode vxlan
[DeviceA-Tunnel2] source 1.1.1.1
[DeviceA-Tunnel2] destination 3.3.3.3
[DeviceA-Tunnel2] quit
# Assign Tunnel 1 and Tunnel 2 to VXLAN 10.
[DeviceA] vsi vpna
[DeviceA-vsi-vpna] vxlan 10
[DeviceA-vsi-vpna-vxlan-10] tunnel 1
[DeviceA-vsi-vpna-vxlan-10] tunnel 2
[DeviceA-vsi-vpna-vxlan-10] quit
[DeviceA-vsi-vpna] quit
# On Ten-GigabitEthernet 3/1/1, create Ethernet service instance 1000 to match VLAN 2.
[DeviceA] interface ten-gigabitethernet 3/1/1
[DeviceA-Ten-GigabitEthernet3/1/1] service-instance 1000
[DeviceA-Ten-GigabitEthernet3/1/1-srv1000] encapsulation s-vid 2
# Map Ethernet service instance 1000 to VSI vpna.
[DeviceA-Ten-GigabitEthernet3/1/1-srv1000] xconnect vsi vpna
[DeviceA-Ten-GigabitEthernet3/1/1-srv1000] quit
[DeviceA-Ten-GigabitEthernet3/1/1] quit
4. Configure Device B:
# Enable L2VPN.
<DeviceB> system-view
[DeviceB] l2vpn enable
# Enable Layer 2 forwarding for VXLANs.
[DeviceB] undo vxlan ip-forwarding
# Create a VSI named vpna, and create VXLAN 10.
[DeviceB] vsi vpna
[DeviceB-vsi-vpna] vxlan 10
[DeviceB-vsi-vpna-vxlan-10] quit
[DeviceB-vsi-vpna] quit
# Enable IGMP snooping globally.
[DeviceB] igmp-snooping
[DeviceB -igmp-snooping] quit
# Enable IGMP snooping and dropping unknown multicast data packets for VSI vpna.
[DeviceB] vsi vpna
[DeviceB-vsi-vpna] igmp-snooping enable
[DeviceB-vsi-vpna] igmp-snooping drop-unknown
[DeviceB-vsi-vpna] quit
# Assign an IP address to Loopback 0. This IP address will be used as the source address of the VXLAN tunnels to Device A and Device C.
[DeviceB] interface loopback 0
[DeviceB-Loopback0] ip address 2.2.2.2 255.255.255.255
[DeviceB-Loopback0] quit
# Create a VXLAN tunnel to Device A.
¡ The tunnel interface name is Tunnel 2.
¡ The source address and destination address of the tunnel interface are 2.2.2.2 and 1.1.1.1, respectively.
[DeviceB] interface tunnel 2 mode vxlan
[DeviceB-Tunnel2] source 2.2.2.2
[DeviceB-Tunnel2] destination 1.1.1.1
[DeviceB-Tunnel2] quit
# Create a VXLAN tunnel to Device C.
¡ The tunnel interface name is Tunnel 3.
¡ The source address and destination address of the tunnel interface are 2.2.2.2 and 3.3.3.3, respectively.
[DeviceB] interface tunnel 3 mode vxlan
[DeviceB-Tunnel3] source 2.2.2.2
[DeviceB-Tunnel3] destination 3.3.3.3
[DeviceB-Tunnel3] quit
# Assign Tunnel 2 and Tunnel 3 to VXLAN 10.
[DeviceB] vsi vpna
[DeviceB-vsi-vpna] vxlan 10
[DeviceB-vsi-vpna-vxlan-10] tunnel 2
[DeviceB-vsi-vpna-vxlan-10] tunnel 3
[DeviceB-vsi-vpna-vxlan-10] quit
[DeviceB-vsi-vpna] quit
# On Ten-GigabitEthernet 3/1/1, create Ethernet service instance 1000 to match VLAN 2.
[DeviceB] interface ten-gigabitethernet 3/1/1
[DeviceB-Ten-GigabitEthernet3/1/1] service-instance 1000
[DeviceB-Ten-GigabitEthernet3/1/1-srv1000] encapsulation s-vid 2
# Map Ethernet service instance 1000 to VSI vpna.
[DeviceB-Ten-GigabitEthernet3/1/1-srv1000] xconnect vsi vpna
[DeviceB-Ten-GigabitEthernet3/1/1-srv1000] quit
[DeviceB-Ten-GigabitEthernet3/1/1] quit
5. Configure Device C:
# Enable L2VPN.
<DeviceC> system-view
[DeviceC] l2vpn enable
# Enable Layer 2 forwarding for VXLANs.
[DeviceC] undo vxlan ip-forwarding
# Create a VSI named vpna, and create VXLAN 10.
[DeviceC] vsi vpna
[DeviceC-vsi-vpna] vxlan 10
[DeviceC-vsi-vpna-vxlan-10] quit
[DeviceC-vsi-vpna] quit
# Enable IGMP snooping globally.
[DeviceB] igmp-snooping
[DeviceB -igmp-snooping] quit
# Enable IGMP snooping for VSI vpna.
[DeviceC] vsi vpna
[DeviceC-vsi-vpna] igmp-snooping enable
# Enable dropping unknown multicast data packets for VSI vpna.
[DeviceC-vsi-vpna] igmp-snooping drop-unknown
# Specify 3.3.3.3 as the source IP address of IGMP general queries in VSI vpna.
[DeviceC-vsi-vpna] igmp-snooping general-query source-ip 3.3.3.3
# Enable the IGMP snooping querier.
[DeviceC-vsi-vpna] igmp-snooping querier
[DeviceC-vsi-vpna] quit
# Assign an IP address to Loopback 0. This address will be used as the source address of the VXLAN tunnels to Device A and Device B.
[DeviceC] interface loopback 0
[DeviceC-Loopback0] ip address 3.3.3.3 255.255.255.255
[DeviceC-Loopback0] quit
# Create a VXLAN tunnel to Device A.
¡ The tunnel interface name is Tunnel 1.
¡ The source address and destination address of the tunnel interface are 3.3.3.3 and 1.1.1.1, respectively.
[DeviceC] interface tunnel 1 mode vxlan
[DeviceC-Tunnel1] source 3.3.3.3
[DeviceC-Tunnel1] destination 1.1.1.1
[DeviceC-Tunnel1] quit
# Create a VXLAN tunnel to Device B.
¡ The tunnel interface name is Tunnel 3.
¡ The source address and destination address of the tunnel interface are 3.3.3.3 and 2.2.2.2, respectively.
[DeviceC] interface tunnel 3 mode vxlan
[DeviceC-Tunnel3] source 3.3.3.3
[DeviceC-Tunnel3] destination 2.2.2.2
[DeviceC-Tunnel3] quit
# Assign Tunnel 1 and Tunnel 3 to VSI vpna.
[DeviceC] vsi vpna
[DeviceC-vsi-vpna] vxlan 10
[DeviceC-vsi-vpna-vxlan-10] tunnel 1
[DeviceC-vsi-vpna-vxlan-10] tunnel 3
[DeviceC-vsi-vpna-vxlan-10] quit
[DeviceC-vsi-vpna] quit
# On Ten-GigabitEthernet 3/1/1, create Ethernet service instance 1000 to match VLAN 2.
[DeviceC] interface ten-gigabitethernet 3/1/1
[DeviceC-Ten-GigabitEthernet3/1/1] service-instance 1000
[DeviceC-Ten-GigabitEthernet3/1/1-srv1000] encapsulation s-vid 2
# Map Ethernet service instance 1000 to VSI vpna.
[DeviceC-Ten-GigabitEthernet3/1/1-srv1000] xconnect vsi vpna
[DeviceC-Ten-GigabitEthernet3/1/1-srv1000] quit
[DeviceC-Ten-GigabitEthernet3/1/1] quit
Verifying the configuration
# Display brief information about dynamic router ports for VSI vpna on Device A.
[DeviceA] display igmp-snooping router-port vsi vpna
VSI vpna:
Router slots (0 in total):
Router ports (1 in total):
NPW (VXLAN ID 10 Link ID 0X5000001) (00:04:17)
# Display brief information about dynamic router ports for VSI vpna on Device B.
[DeviceB] display igmp-snooping router-port vsi vpna
VSI vpna:
Router slots (0 in total):
Router ports (1 in total):
NPW (VXLAN ID 10 Link ID 0X5000001) (00:04:07)
Troubleshooting IGMP snooping
Layer 2 multicast forwarding cannot function
Symptom
Layer 2 multicast forwarding cannot function on the Layer 2 device.
Solution
To resolve the issue:
1. Use the display igmp-snooping command to display IGMP snooping status.
2. If IGMP snooping is not enabled, use the igmp-snooping command in system view to enable IGMP snooping globally. Then, use the igmp-snooping enable command in VLAN view or VSI view to enable IGMP snooping for the VLAN or VSI.
3. If IGMP snooping is enabled globally but not enabled for the VLAN or VSI, use the igmp-snooping enable command in VLAN view or VSI view to enable IGMP snooping for the VLAN or VSI.
4. If the issue persists, contact H3C Support.
Multicast group policy does not work
Symptom
Hosts can receive multicast data for multicast groups that are not permitted by the multicast group policy.
Solution
To resolve the issue:
1. Use the display acl command to verify that the configured ACL meets the multicast group policy requirements.
2. Use the display this command in IGMP-snooping view or in a corresponding interface view to verify that the correct multicast group policy has been applied. If the applied policy is not correct, use the group-policy or igmp-snooping group-policy command to apply the correct multicast group policy.
3. Use the display igmp-snooping command to verify that dropping unknown multicast data is enabled. If it is not, use the drop-unknown or igmp-snooping drop-unknown command to enable dropping unknown multicast data.
4. If the issue persists, contact H3C Support.