De acordo com as Leis 12.965/2014 e 13.709/2018, que regulam o uso da Internet e o tratamento de dados pessoais no Brasil, ao me inscrever na newsletter do portal DICAS-L, autorizo o envio de notificações por e-mail ou outros meios e declaro estar ciente e concordar com seus Termos de Uso e Política de Privacidade.


Link aggregation/Bonding em linux

Colaboração: Gustavo Mendes de Carvalho

Data de Publicação: 12 de junho de 2010

Seguem algumas informações e dois scripts úteis para adição e configuração de interfaces em link agregation/bonding em linux. Eu fiz isso em Debian 3.1, mas vale para qualquer linux.

No exemplo abaixo (/etc/init.d/start_bonding) eu tenho um servidor com 4 interfaces de rede e estou criando 2 link aggregation, para uso em dois switches trabalhando com HSRP (Cisco). Eu vou criar a interface lógica bond0 com as interfaces físicas eth0 e eth1, e a interface lógica bond1 com as interfaces físicas eth2 e eth3.

Vale lembrar que se você tem 1 servidor e 1 switch operando em modo bonding, a escolha do modo é muito importante para o correto balanceamento.

No caso do servidor, o melhor modo para balanceamento é o mode=0, que envia um pacote para cada interface alternadamente. A escolha do modo vale somente para o envio dos pacotes, uma vez que quando o bonding ou aggregation está ativado, qualquer que seja o modo de configuração do bonding, o outro equipamento deve ser capaz de recebê-los sem problema. Ou seja, eu posso ter modo de envio 0 (Round-robin mode) do servidor para o switch e modo 1 (Active-backup mode) do switch para o servidor, e eles serão capazes de trocar tráfego sem problema.

  #!/bin/sh
  # arquivo /etc/init.d/start_bonding
  # obtendo os MACs
  MAC_ADDR_0=`/sbin/ifconfig -a | /bin/grep eth0 | /bin/awk  {print $5} `
  MAC_ADDR_1=`/sbin/ifconfig -a | /bin/grep eth2 | /bin/awk  {print $5} `
  
  # modos de operacao de bonding suportados
  # mode=0 ==> Round-robin policy
  # mode=1 ==> Active-backup policy
  # mode=2 ==> Balance-xor policy
  # mode=3 ==> Broadcast policy
  # mode=4 ==> 802.3ad policy
  # mode=5 ==> Balance-tlb (Adaptive transmit load balancing) policy
  # mode=6 ==> Balance-alb (Adaptive load balancing) policy
  
  # carregando o modulo em memoria para o primeiro bonding
  /sbin/modprobe bonding mode=0                  ## bond0
  
  # pulo do gato para criar o segundo bonding no mesmo servidor
  /sbin/modprobe bonding -o bonding1 mode=0      ## bond1
  
  # criando a interface bond0 e dando-lhe um MAC
  /sbin/ifconfig bond0 hw ether $MAC_ADDR_0
  /sbin/ifconfig bond0 up
  
  # criando a interface bond1 e dando-lhe um MAC
  /sbin/ifconfig bond1 hw ether $MAC_ADDR_1
  /sbin/ifconfig bond1 up
  
  # adicionando as interfaces físicas ao bond 0
  /sbin/ifenslave bond0 eth0
  /sbin/ifenslave bond0 eth1
  
  # adicionando as interfaces físicas ao bond 1
  /sbin/ifenslave bond1 eth2
  /sbin/ifenslave bond1 eth3
  
  # ativando as interfaces físicas
  /sbin/ifconfig eth0 up
  /sbin/ifconfig eth1 up
  /sbin/ifconfig eth2 up
  /sbin/ifconfig eth3 up
  
  #========eof /etc/init.d/start_bonding

É claro que este exemplo server para mostrar o que pode ser feito, mas é possível também adicionar mais interfaces físicas em um mesmo bonding. No exemplo abaixo, eu vou criar 1 bonding com 4 interfaces físicas.

  #!/bin/sh
  # arquivo /etc/init.d/start_bonding
  # obtendo os MACs
  MAC_ADDR_0=`/sbin/ifconfig -a | /bin/grep eth0 | /bin/awk  {print $5} `
  
  # carregando os modulos em memoria
  # mode=0 ==> Round-robin policy
  # mode=1 ==> Active-backup policy
  # mode=2 ==> Balance-xor policy
  # mode=3 ==> Broadcast policy
  # mode=4 ==> 802.3ad policy
  # mode=5 ==> Balance-tlb (Adaptive transmit load balancing) policy
  # mode=6 ==> Balance-alb (Adaptive load balancing) policy
  
  # carregando o modulo em meoria para o primeiro bonding
  /sbin/modprobe bonding mode=0                  ## bond0
  
  # criando a interface bond0 e dando-lhe um MAC
  /sbin/ifconfig bond0 hw ether $MAC_ADDR_0
  /sbin/ifconfig bond0 up
  
  # adicionando as interfaces físicas ao bond 0
  /sbin/ifenslave bond0 eth0
  /sbin/ifenslave bond0 eth1
  /sbin/ifenslave bond0 eth2
  /sbin/ifenslave bond0 eth3
  
  # ativando as interfaces físicas
  /sbin/ifconfig eth0 up
  /sbin/ifconfig eth1 up
  /sbin/ifconfig eth2 up
  /sbin/ifconfig eth3 up
  
  #========eof /etc/init.d/start_bonding

Já para desfazer estas interfaces, o caminho deve ser desfeito de trás para frente. Veja o script para desfazer is dois bondings com 2 interfaces físicas cada.

  #!/bin/sh
  # arquivo /etc/init.d/stop_bonding
  
  # colocando as interfaces físicas em down
  /sbin/ifconfig eth1 down
  /sbin/ifconfig eth2 down
  /sbin/ifconfig eth3 down
  /sbin/ifconfig eth4 down
  
  # desvinculando as interfaces físicas do bonding
  /sbin/ifenslave -d bond0 eth0
  /sbin/ifenslave -d bond0 eth1
  /sbin/ifenslave -d bond1 eth2
  /sbin/ifenslave -d bond1 eth3
  
  # colocando as interfaces de bonding em down
  /sbin/ifconfig bond0 down
  /sbin/ifconfig bond1 down
  
  #===========eof  /etc/init.d/stop_bonding

Adicionar comentário

* Campos obrigatórios
5000
Powered by Commentics

Comentários

Nenhum comentário ainda. Seja o primeiro!


Veja a relação completa dos artigos de Gustavo Mendes de Carvalho