Ethernet Channel Bonding aka NIC Teaming på Linux-systemer


Ethernet Channel Bonding muliggjør to eller flere Network Interfaces Card (NIC) til et enkelt virtuelt NIC-kort som kan øke båndbredden og gir redundans for NIC-kort. Dette er en fin måte å oppnå redundante koblinger, feiltoleranse eller lastbalanserende nettverk i produksjonssystemet. Hvis en fysisk NIC er nede eller koblet fra, vil den automatisk flytte ressurser til et annet NIC-kort. Channel/NIC bonding vil fungere ved hjelp av bonding driver i kjernen. Vi bruker to NIC for å demonstrere det samme.

Det er nesten seks typer Channel Bond-typer tilgjengelig. Her vil vi kun gjennomgå to typer Channel Bond som er populære og mye brukt.

  1. 0: Lastbalansering (Round-Robin) : Trafikk overføres i sekvensiell rekkefølge eller round-robin-måte fra begge NIC. Denne modusen gir lastbalansering og feiltoleranse.
  2. 1: Aktiv sikkerhetskopi: Bare én slave NIC er aktiv på et gitt tidspunkt. Annet grensesnittkort vil bare være aktivt hvis det aktive slave-NIC mislykkes.

Opprette Ethernet-kanalbinding

Vi har to nettverk Ethernet-kort, dvs. eth1 og eth2, hvor bond0 vil bli opprettet for bindingsformål. Trenger superbrukerprivilegert for å utføre kommandoene nedenfor.

Nevn parameter MASTER bond0 og eth1-grensesnitt som en SLAVE i konfigurasjonsfilen som vist nedenfor.

# vi /etc/sysconfig/network-scripts/ifcfg-eth1
DEVICE="eth1"
TYPE=Ethernet
ONBOOT="yes"
BOOTPROTO="none"
USERCTL=no
MASTER=bond0
SLAVE=yes

Spesifiser også her parameter MASTER bond0 og eth2 grensesnitt som en SLAVE.

# vi /etc/sysconfig/network-scripts/ifcfg-eth2
DEVICE="eth2"
TYPE="Ethernet"
ONBOOT="yes"
USERCTL=no
#NM_CONTROLLED=yes
BOOTPROTO=none
MASTER=bond0
SLAVE=yes

Opprett bond0 og konfigurer Channel bonding-grensesnittet i /etc/sysconfig/network-scripts/-katalogen kalt ifcfg-bond0.

Følgende er et eksempel på konfigurasjonsfil for kanalbinding.

# vi /etc/sysconfig/network-scripts/ifcfg-bond0
DEVICE=bond0
ONBOOT=yes
IPADDR=192.168.246.130
NETMASK=255.255.255.0
BONDING_OPTS="mode=0 miimon=100"

Merk: I konfigurasjonen ovenfor har vi valgt Bonding Options-modus=0, dvs. Round-Robin og miimon=100 (Polling-intervaller 100 ms).

La oss se grensesnitt opprettet med ifconfig-kommandoen som viser bond0 som kjører som MASTER, begge grensesnittene eth1 og eth2 kjører som SLAVES.

# ifconfig
bond0     Link encap:Ethernet  HWaddr 00:0C:29:57:61:8E
          inet addr:192.168.246.130  Bcast:192.168.246.255  Mask:255.255.255.0
          inet6 addr: fe80::20c:29ff:fe57:618e/64 Scope:Link
          UP BROADCAST RUNNING MASTER MULTICAST  MTU:1500  Metric:1
          RX packets:17374 errors:0 dropped:0 overruns:0 frame:0
          TX packets:16060 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:1231555 (1.1 MiB)  TX bytes:1622391 (1.5 MiB)

eth1      Link encap:Ethernet  HWaddr 00:0C:29:57:61:8E
          UP BROADCAST RUNNING SLAVE MULTICAST  MTU:1500  Metric:1
          RX packets:16989 errors:0 dropped:0 overruns:0 frame:0
          TX packets:8072 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:1196931 (1.1 MiB)  TX bytes:819042 (799.8 KiB)
          Interrupt:19 Base address:0x2000

eth2      Link encap:Ethernet  HWaddr 00:0C:29:57:61:8E
          UP BROADCAST RUNNING SLAVE MULTICAST  MTU:1500  Metric:1
          RX packets:385 errors:0 dropped:0 overruns:0 frame:0
          TX packets:7989 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:34624 (33.8 KiB)  TX bytes:803583 (784.7 KiB)
          Interrupt:19 Base address:0x2080

lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:8 errors:0 dropped:0 overruns:0 frame:0
          TX packets:8 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:480 (480.0 b)  TX bytes:480 (480.0 b)

Start nettverkstjenesten på nytt og grensesnittene skal være OK.

# service network restart
Shutting down interface bond0:                             [  OK  ]
Shutting down loopback interface:                          [  OK  ]
Bringing up loopback interface:                            [  OK  ]
Bringing up interface bond0:                               [  OK  ]

Sjekker statusen til obligasjonen.

# watch -n .1 cat /proc/net/bonding/bond0

Utdata nedenfor viser at Bonding Mode er Load Balancing (RR) og eth1 og eth2 vises.

Every 0.1s: cat /proc/net/bonding/bond0                         Thu Sep 12 14:08:47 2013 

Ethernet Channel Bonding Driver: v3.6.0 (September 26, 2009)

Bonding Mode: load balancing (round-robin)
MII Status: up
MII Polling Interval (ms): 100
Up Delay (ms): 0
Down Delay (ms): 0

Slave Interface: eth1
MII Status: up
Speed: Unknown
Duplex: Unknown
Link Failure Count: 2
Permanent HW addr: 00:0c:29:57:61:8e
Slave queue ID: 0

Slave Interface: eth2
MII Status: up
Speed: Unknown
Duplex: Unknown
Link Failure Count: 2
Permanent HW addr: 00:0c:29:57:61:98
Slave queue ID: 0

I dette scenariet forblir slavegrensesnittene de samme. bare én endring vil være der i bindingsgrensesnittet ifcfg-bond0 i stedet for '0' det vil være '1' som vises som under.

# vi /etc/sysconfig/network-scripts/ifcfg-bond0
DEVICE=bond0
ONBOOT=yes
IPADDR=192.168.246.130
NETMASK=255.255.255.0
BONDING_OPTS="mode=1 miimon=100"

Start nettverkstjenesten på nytt og sjekk statusen til bindingen.

# service network restart
Shutting down interface bond0:                             [  OK  ]
Shutting down loopback interface:                          [  OK  ]
Bringing up loopback interface:                            [  OK  ]
Bringing up interface bond0:                               [  OK  ]

Kontrollerer statusen til bindingen med kommando.

# watch -n .1 cat /proc/net/bonding/bond0

Bonding Mode viser feiltoleranse (aktiv backup) og slavegrensesnittet er oppe.

Every 0.1s: cat /proc/n...  Thu Sep 12 14:40:37 2013

Ethernet Channel Bonding Driver: v3.6.0 (September 2
6, 2009)

Bonding Mode: fault-tolerance (active-backup)
Primary Slave: None
Currently Active Slave: eth1
MII Status: up
MII Polling Interval (ms): 100
Up Delay (ms): 0
Down Delay (ms): 0

Slave Interface: eth1
MII Status: up
Speed: Unknown
Duplex: Unknown
Link Failure Count: 0
Permanent HW addr: 00:0c:29:57:61:8e
Slave queue ID: 0

Slave Interface: eth2
MII Status: up
Speed: Unknown
Duplex: Unknown
Link Failure Count: 0
Permanent HW addr: 00:0c:29:57:61:98
Slave queue ID: 0

Merk: Manuelt ned og opp slavegrensesnittene for å sjekke hvordan kanalbindingen fungerer. Vennligst se kommandoen som nedenfor.

# ifconfig eth1 down
# ifconfig eth1 up

Det er det!