Ethernet Channel Bonding aka NIC Teaming na Linux sustavima


Ethernet Channel Bonding omogućuje dvije ili više kartica mrežnih sučelja (NIC) na jednu virtualnu NIC karticu što može povećati propusnost i omogućuje redundantnost NIC kartica. Ovo je odličan način za postizanje redundantnih veza, tolerancije grešaka ili mreža za uravnoteženje opterećenja u proizvodnom sustavu. Ako je jedna fizička NIC isključena ili isključena, automatski će premjestiti resurse na drugu NIC karticu. Povezivanje kanala/NIC radit će uz pomoć upravljačkog programa za povezivanje u Kernelu. Koristit ćemo dvije NIC da pokažemo isto.

Dostupno je gotovo šest vrsta Channel Bond vrsta. Ovdje ćemo pregledati samo dvije vrste Channel Bonda koje su popularne i široko korištene.

  1. 0: Balansiranje opterećenja (Round-Robin): Promet se prenosi sekvencijalnim redoslijedom ili kružnim putem s oba NIC-a. Ovaj način rada omogućuje uravnoteženje opterećenja i toleranciju na pogreške.
  2. 1: Active-Backup: Samo je jedan podređeni NIC aktivan u bilo kojem trenutku. Druga kartica sučelja bit će aktivna samo ako aktivna slave NIC ne uspije.

Stvaranje spajanja Ethernet kanala

Imamo dvije mrežne Ethernet kartice tj. eth1 i eth2 gdje će bond0 biti kreiran u svrhu povezivanja. Potreban je privilegirani superkorisnik za izvršavanje naredbi u nastavku.

Balansiranje opterećenja (Round-Robin)

Konfigurirajte eth1

Navedite parametar MASTER bond0 i eth1 sučelje kao SLAVE u konfiguracijskoj datoteci kao što je prikazano u nastavku.

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

Ovdje također navedite parametar MASTER bond0 i eth2 sučelje kao 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
Stvorite bond0 konfiguraciju

Stvorite bond0 i konfigurirajte sučelje za povezivanje kanala u “/etc/sysconfig/network-scripts/” direktoriju pod nazivom ifcfg-bond0.

Slijedi primjer konfiguracijske datoteke za povezivanje kanala.

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"

Napomena: U gornjoj konfiguraciji odabrali smo opcije spajanja mode=0 tj. Round-Robin i miimon=100 (Intervali prozivanja 100 ms).

Pogledajmo sučelja stvorena korištenjem ifconfig naredbe koja prikazuje “bond0” kako radi kao MASTER oba sučelja “eth1” i “eth2” koji rade kao ROBOVI.

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)

Ponovno pokrenite mrežnu uslugu i sučelja bi trebala biti u redu.

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

Provjera statusa obveznice.

watch -n .1 cat /proc/net/bonding/bond0
Uzorak izlaza

Donji rezultat pokazuje da je Bonding Mode Load Balancing (RR) i eth1 & eth2 se pojavljuju.

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

Stvorite aktivnu sigurnosnu kopiju

U ovom scenariju, Slave sučelja ostaju ista. bit će samo jedna promjena u sučelju veze ifcfg-bond0 umjesto '0' bit će '1' što je prikazano kao ispod .

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"

Ponovno pokrenite mrežnu uslugu i provjerite status povezivanja.

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

Provjera statusa veze s naredbom.

watch -n .1 cat /proc/net/bonding/bond0
Uzorak izlaza

Način povezivanja pokazuje toleranciju na greške (aktivna sigurnosna kopija) i Slave sučelje je uključeno.

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

Napomena: Ručno dolje i gore podređena sučelja da biste provjerili funkcioniranje Spajanja kanala. Pogledajte naredbu kao u nastavku.

ifconfig eth1 down
ifconfig eth1 up

To je to!