Help us improve your experience.

Let us know what you think.

Do you have time for a two-minute survey?

header-navigation
keyboard_arrow_up
list Table of Contents

Load Balancing for Aggregated Ethernet Interfaces

date_range 02-Apr-25

Load balancing is done on Layer 2 across the member links making the configuration better without congestion and maintaining redundancy. The below topics discuss the overview of load balancing, configuring load balancing based on MAC addresses and on LAG link, understanding the consistency through resilient hashing.

Configuring Load Balancing Based on MAC Addresses

The hash key mechanism for load-balancing uses Layer 2 media access control (MAC) information such as frame source and destination address. To load-balance traffic based on Layer 2 MAC information, include the multiservice statement at the [edit forwarding-options hash-key] or [edit chassis fpc slot number pic PIC number hash-key] hierarchy level:

content_copy zoom_out_map
multiservice {
    source-mac;
    destination-mac;
    payload {
        ip {
            layer3-only;
            layer-3 (source-ip-only | destination-ip-only);
            layer-4;
            inner-vlan-id;
            outer-vlan-id;
        }
    }
}

Use Feature Expolorer to confirm platform and release support for specific features.

Review the Platform-Specific MAC Address Based Load Balancing Behavior section for notes related to your platform.

To include the destination-address MAC information in the hash key, include the destination-mac option. To include the source-address MAC information in the hash key, include the source-mac option.

Note:
  • Any packets that have the same source and destination address will be sent over the same path.

  • You can configure per-packet load balancing to optimize EVPN traffic flows across multiple paths.

  • Aggregated Ethernet member links will now use the physical MAC address as the source MAC address in 802.3ah OAM packets.

Platform-Specific MAC Address Based Load Balancing Behavior

Platform

Difference

ACX Series

  • ACX7000 Series routers that support MAC address-based load balancing use symmetric hashing. For example, you need to configure both source-mac and destination-mac under "multiservice" options. You cannot use source-mac and destination-mac separately.

    Note the following about hashing on ACX7000 Series routers:

    • Do not support any default hashing. Load balancing does not happen if you do not configure "hash-key" option. Use the [set forwarding-options hash-key family] hierarchy.

    • Load balancing might or might not be symmetrical. Some links might carry more traffic than others. This traffic difference is based on the traffic profile.

    • Do not support weighted hashing.

Example: Configuring Multicast Load Balancing for Use with Aggregated 10-Gigabit Ethernet Interfaces on EX8200 Switches

EX8200 switches support multicast load balancing on link aggregation groups (LAGs). Multicast load balancing evenly distributes Layer 3 routed multicast traffic over the LAGs, You can aggregate up to twelve 10-gigabit Ethernet links to form a 120-gigabit virtual link or LAG. The MAC client can treat this virtual link as if it were a single link to increase bandwidth, provide graceful degradation as link failures occur, and increase availability. On EX8200 switches, multicast load balancing is enabled by default. However, if it is explicitly disabled, you can reenable it. .

Note:

An interface with an already configured IP address cannot form part of the LAG.

Note:

Only EX8200 standalone switches with 10-gigabit links support multicast load balancing. Virtual Chassis does not support multicast load balancing.

This example shows how to configure a LAG and reenable multicast load balancing:

Requirements

This example uses the following hardware and software components:

  • Two EX8200 switches, one used as the access switch and one used as the distribution switch

  • Junos OS Release 12.2 or later for EX Series switches

Before you begin:

Overview and Topology

Multicast load balancing uses one of seven hashing algorithms to balance traffic between the individual 10-gigabit links in the LAG. For a description of the hashing algorithms, see multicast-loadbalance. The default hashing algorithm is crc-sgip. You can experiment with the different hashing algorithms until you determine the one that best balances your Layer 3 routed multicast traffic.

When a link larger than 10 gigabits is needed on an EX8200 switch, you can combine up to twelve 10-gigabit links to create more bandwidth. This example uses the link aggregation feature to combine four 10-gigabit links into a 40-gigabit link on the distribution switch. In addition, multicast load balancing is enabled to ensure even distribution of Layer 3 routed multicast traffic on the 40-gigabit link. In the sample topology illustrated in Figure 2, an EX8200 switch in the distribution layer is connected to an EX8200 switch in the access layer.

Note:

Link speed is automatically determined based on the size of the LAG configured. For example, if a LAG is composed of four 10-gigabit links, the link speed is 40 gigabits per second).

Note:

The default hashing algorithm, crc-sgip, involves a cyclic redundancy check of both the multicast packet source and group IP addresses.

Figure 2: 40-Gigabit LAG Composed of Four 10-Gigabit Links40-Gigabit LAG Composed of Four 10-Gigabit Links

You will configure a LAG on each switch and reenable multicast load balancing. When reenabled, multicast load balancing will automatically take effect on the LAG, and the speed is set to 10 gigabits per second for each link in the LAG. Link speed for the 40-gigabit LAG is automatically set to 40 gigabits per second.

Configuration

Procedure

CLI Quick Configuration

To quickly configure this example, copy the following commands, paste them into a text file, remove any line breaks, change any details necessary to match your network configuration, and then copy and paste the commands into the CLI at the [edit] hierarchy level.

content_copy zoom_out_map
set chassis aggregated-devices ethernet device-count 1
set interfaces ae0 aggregated-ether-options minimum-links 1 
set interfaces xe-0/1/0 ether-options 802.3ad ae0 
set interfaces xe-1/1/0 ether-options 802.3ad ae0
set interfaces xe-2/1/0 ether-options 802.3ad ae0
set interfaces xe-3/1/0 ether-options 802.3ad ae0
set chassis multicast-loadbalance hash-mode crc-gip 
Step-by-Step Procedure

To configure a LAG and reenable multicast load balancing:

  1. Specify the number of aggregated Ethernet interfaces to be created:

    content_copy zoom_out_map
    [edit chassis]
    user@switch#  set aggregated-devices ethernet device-count 1
  2. Specify the minimum number of links for the aggregated Ethernet interface (aex), that is, the LAG, to be labeled up:

    Note:

    By default, only one link needs to be up for the LAG to be labeled up.

    content_copy zoom_out_map
    [edit interfaces]
    user@switch# set ae0 aggregated-ether-options minimum-links 1                     
  3. Specify the four members to be included within the LAG:

    content_copy zoom_out_map
    [edit interfaces]
    user@switch# set xe-0/1/0 ether-options 802.3ad ae0
    user@switch# set xe-1/1/0 ether-options 802.3ad ae0        
    user@switch# set xe-2/1/0 ether-options 802.3ad ae0  
    user@switch# set xe-3/1/0 ether-options 802.3ad ae0               
  4. Reenable multicast load balancing:

    content_copy zoom_out_map
    [edit chassis]
    user@switch#  set  multicast-loadbalance 
    Note:

    You do not need to set link speed the way you do for LAGs that do not use multicast load balancing. Link speed is automatically set to 40 gigabits per second on a 40-gigabit LAG.

  5. You can optionally change the value of the hash-mode option in the multicast-loadbalance statement to try different algorithms until you find the one that best distributes your Layer 3 routed multicast traffic.

    If you change the hashing algorithm when multicast load balancing is disabled, the new algorithm takes effect after you reenable multicast load balancing.

Results

Check the results of the configuration:

content_copy zoom_out_map
user@switch>  show configuration
chassis

	aggregated-devices {
		ethernet {
		     device-count 1;
		}
	}
	multicast-loadbalance {
		hash-mode crc-gip; 
	}

interfaces
	xe-0/1/0 {
	ether-options {
			802.3ad ae0;
		}
	}
	xe-1/1/0 {
		ether-options {
			802.3ad ae0;
		}
	}
	xe-2/1/0 {
		ether-options {
			802.3ad ae0;
		}
	}
	xe-3/1/0 {
		ether-options {
			802.3ad ae0;
		}
	}
	ae0 {
		aggregated-ether-options {
			minimum-links 1;
		}
	}
}


Verification

To confirm that the configuration is working properly, perform these tasks:

Verifying the Status of a LAG Interface

Purpose

Verify that a link aggregation group (LAG) (ae0) has been created on the switch.

Action

Verify that the ae0 LAG has been created:

content_copy zoom_out_map
user@switch> show interfaces ae0 terse
content_copy zoom_out_map
Interface             Admin  	Link 	Proto      Local             Remote               

ae0                    up       up

ae0.0                  up       up     inet     10.10.10.2/24

 

Meaning

The interface name aex indicates that this is a LAG. A stands for aggregated, and E stands for Ethernet. The number differentiates the various LAGs.

Verifying Multicast Load Balancing

Purpose

Check that traffic is load-balanced equally across paths.

Action

Verify load balancing across the four interfaces:

content_copy zoom_out_map
user@switch> monitor interface traffic           
content_copy zoom_out_map
Bytes=b, Clear=c, Delta=d, Packets=p, Quit=q or ESC, Rate=r, Up=^U, Down=^D
ibmoem02-re1                      Seconds: 3                   Time: 16:06:14

Interface    Link  Input packets        (pps)     Output packets        (pps)
 xe-0/1/0      Up        2058834         (10)          7345862         (19)
 xe-1/1/0      Up        2509289          (9)          6740592         (21)
 xe-2/1/0      Up        8625688         (90)         10558315         (20)
 xe-3/1/0      Up        2374154         (23)         71494375          (9)
Meaning

The interfaces should be carrying approximately the same amount of traffic.

Change History Table

Feature support is determined by the platform and release you are using. Use Feature Explorer to determine if a feature is supported on your platform.

Release
Description
10.1
Starting with Junos OS Release 10.1, you can also configure the load balancing hash key for Layer 2 traffic to use fields in the Layer 3 and Layer 4 headers using the payload statement.
footer-navigation