interfaces-bond(5)

# NAME

*interfaces-bond* - Bonding/LAG extensions for the interfaces(5) file format

# DESCRIPTION

The Linux implementation for Ling Aggregation Groups (LAGs) is called
_bonding_, whereas a LAG interface is called _bond_. The Linux bonding
implementation supports active/passive setups, classical EtherChannels
as well as LACP (802.3ad).

The following options set up bonding/LAG interfaces with ifupdown-ng.

See https://www.kernel.org/doc/Documentation/networking/bonding.rst and
for more information.

# BOND-RELATED OPTIONS

A bond interface must have at least one member port set. All other
options are optional.

*bond-members* _list of interfaces_
	Denotes the physical member interfaces to form this LAG. For
	compatiblity to ifupdown1 and ifupdown2 _slaves_ as well as
	_bond-slaves_ are an alias for this option. This option is
	required.

*bond-mode* _mode_
	Denotes the mode for this LAG. The _mode_ can be given as string
	or as numerical value. Valid values are _balance-rr_ (0),
	_active-backup_ (1), _balance-xor_ (2), _broadcast_ (3),
	_802.3ad_ (4), _balance-tlb_ (5), _balance-alb_ (6).
	The default is _balance-rr_.

*bond-xmit-hash-policy* _policy_
	Denotes the hash policy/algorithm used to distribute packets
	across the physical links. This only applies for modes
	_balance-alb_, _balance-tlb_, _balance-xor_, and _802.3ad_.
	The _policy_ can be given as string or as numerical value.
	Valid values are _layer2_ (0), _layer3+4_ (1), _layer2+3_ (2),
	_encap2+3_ (3), and _encap3+4_ (4). The default is _layer2_.

*bond-min-links* _number_
	Denotes the minimum number of available links before turning on
	carrier.

*bond-miimon* _interval_
	Denotes the MII link monitoring frequency in milliseconds.
	This determines how often the link state of each slave is
	inspected for link failures. A value of zero disables MII
	link monitoring. The default is 0.

*bond-use-carrier* _bool_
	Denotes wether miimon uses MII or ethtool ioctls vs. the
	netif_carrier_ok() call to determine member link status.
	A value of 1 enables the use of netif_carrier_ok(), a value of
	0 will use the deprecated MII / ETHTOOL ioctls. The default
	is 1.

*bond-updelay* _delay_
	Denotes the delay in milliseconds before considering link up,
	in milliseconds. The default is 0.

*bond-downdelay* _delay_
	Denotes the delay in milliseconds before considering link down,
	in milliseconds. The default is 0.

*bond-all-slaves-active* _bool_
	Denotes wether duplicate frames (received on inactive ports)
	should be dropped (0) or delivered (1). The default is 0.

*bond-packets-per-slave* _num_packets_
	Denotes the number of packets to transmit through a member
	before moving to the next one. When set to 0 then a slave is
	chosen at random. The valid range is 0 - 65535; the default
	value is 1. This option has effect only in balance-rr mode.

*bond-lp-interval* _interval_
	Denotes the interval in seconds between sending learning packets
	to each members peer switch. The valid range is 1 - 0x7fffffff;
	the default value is 1. This option has effect only in modes
	balance-tlb and balance-alb.

*bond-resend-igmp* _number_
	Denotes the number of IGMP membership reports to send after a
	link failover happend. The valid range is 0 - 255; a value of
	0 prevents the IGMP membership report from being issued in
	response to the failover event. The default is 1.
	This option is useful for bonding modes balance-rr, active-backup
	balance-tlb and balance-alb, in which a failover can switch the
	IGMP traffic from one slave to another.

# LACP-RELATED OPTIONS

The following options are only valid in LACP (802.3ad) mode.

*bond-lacp-rate* _rate_
	Denotes the _rate_ of LACPDU requested from the peer. The _rate_
	can be given as string or as numerical value. Valid values are
	slow (0) and fast (1). The default is slow.

*bond-ad-select* _mode_
	Denotes the 802.3ad aggregation selection logic. The _mode_ can
	be given as string or as numerical value. Valid values are
	_stable_ (0), _bandwidth_ (1) and _cound_ (2). The default is
	_stable_.

*bond-ad-actor-sys-prio* _priority_
	Denotes the LACP system priority. The allowed range is 1 - 65535.
	The default value is 65535.

*bond-ad-user-port-key* _key_
	Denotes the upper 10 bits of the port-key. he values can be from
	0 - 1023. The default is 0.


# ACTIVE/BACKUP-RELATED OPTIONS

The following options are only valid in active/passive setups.

*bond-primary* _interface_
	Denotes the primary member interface The specified device will
	always be the active slave while it is available. The primary
	option is only valid for active-backup, balance-tlb and
	balance-alb mode.

*bond-primary-reselect* _policy_
	Denotes the reselection policy for the primary member interface.
	Valid values are _always_ (0), _better_ (1), and _failure_ (2).
	The default is _always_.

*bond-fail-over-mac* _mode_
	Denotes whether active-backup mode should set all member
	interfaces to the same MAC address at enslavement (the
	traditional behavior), or, when enabled, perform special
	handling of the bond's MAC address in accordance with the
	selected policy. Valid values are _none_ (0), _active_ (1),
	_follow_ (2). The default is _none_.

*bond-num-grat-arp* _count_
	Denotes the number of peer notifications (gratuitous ARPs and
	unsolicited IPv6 Neighbor Advertisements) to be issued after a
	failover event. The valid range is 0 - 255; the default is 1.

*bond-num-unsol-na* _count_
	This is an alias for _bond-num-grat-arp_

*bond-peer-notif-delay* _interval_
	Denotes the interval in milliseconds, between each peer
	notification (gratuitous ARP and unsolicited IPv6 Neighbor
	Advertisement) issued after a failover event. The default
	is 0 which means to match the value of the link monitor
	interval.

# ARP-RELATED OPTIONS

The following options configure ARP link monitoring.
The ARP monitor works by periodically checking the slave
devices to determine whether they have sent or received
traffic recently. Regular traffic is generated via ARP
probes issued for the addresses specified by the
_bond-arp-ip-target_ option.

*bond-arp-interval* _interval_
	Denotes the frequency in milliseconds to send ARP probes.

*bond-arp-ip-target* _IPv4 address_
	Denotes the IP addresses to use as ARP monitoring peers when
	_bond-arp-interval_ is > 0.

*bond-arp-validate* _mode_
	Specifies whether or not ARP probes and replies should be
	validated in any mode that supports arp monitoring, or whether
	non-ARP traffic should be filtered (disregarded) for link
	monitoring purposes. Valid values are _none_ (0), _active_ (1),
	_backup_ (2), _all_ (3), _filter_ (4), _filter_active_ (5), and
	_filter_backup_ (6). The default is _none_.

*bond-arp-all-targets* _mode_
	Denotes the number of _bond-arp-ip-targets_ that have to be
	reachable to consider the member interface to be up. Valid
	options are _any_ (0) and _all_ (1). The default is _any_.

# EXAMPLES

A bond using two links and LACP (802.3ad):

```
auto bond0
iface bond0
	bond-members eth0 eth1
	bond-mode 802.3ad
	bond-xmit-hash-policy layer3+4
	bond-min-links 1
	#
	address 192.0.2.42/24
	address 2001:db8::42/64
```

# AUTHORS

Maximilian Wilhelm <max@sdn.clinic>