Pular para o conteúdo principal
O software SDLMUX combina dois adaptadores de rede em uma interface IP, proporcionando uma capacidade de fail over se o link no adaptador ativo cair ou o adaptador falhar. Uma vez configurado, ele não requer praticamente nenhuma administração, mas há algumas coisas que você deve estar ciente.
Em primeiro lugar, o SDLMUX não fornece nenhum balanceamento de carga; todo o tráfego é transmitido e recebido no adaptador ativo.
Segundo, no hardware ftServer VSeries o adaptador ativo tem um endereço MAC do formulário 00:00:A8:4v:wx:yz. O 00:00:A8 é o identificador organizacional único Stratus (OUI), atribuído pelo IEEE. O "v" é um índice baseado na ordem em que os dispositivos SDLMUX foram inicializados, começando em 0. O valor "wx:yz" é baseado no número de série do sistema. O endereço em espera difere do endereço ativo somente na mordida superior do quarto byte, ao invés de um 4 é um 6. Também a diferença entre os endereços MAC de dois adaptadores ativos (ou em espera) no mesmo módulo estará somente na mordida inferior do quarto byte. A maneira mais fácil de obter uma lista de todos os endereços MAC é com a solicitação do sistema de análise "dump_sdlmux" correspondente no "MAC", veja a figura 1.
as: match 'MAC' ; dump_sdlmux
MAC address               = 0000A8405A8B
MAC address               = 0000A8605A8B
MAC address               = 0000A8415A8B
MAC address               = 0000A8615A8B
MAC address               = 0000A8425A8B
MAC address               = 0000A8625A8B
MAC address               = 0000A8435A8B
MAC address               = 0000A8635A8B
as:
Figura 1
Apenas os endereços MAC não são muito úteis; combinando em "MAC" ou "#" você obtém os endereços MAC e os nomes dos dispositivos SDLMUX e adaptador de rede. Note que esta lista não conterá nenhum adaptador de rede que não faça parte de uma parceria do SDLMUX.
as: match 'MAC' -or '#' ; dump_sdlmux
sdlmux device             = #sdlmuxA.m16.10-5-0.11-5-0
MAC address               = 0000A8405A8B
Interface device = %phx_vos#enetA.m16.10-5-0
MAC address               = 0000A8605A8B

Interface device          = %phx_vos#enetA.m16.11-5-0

sdlmux device             = #sdlmuxA.m16.10-5-1.11-5-1
MAC address               = 0000A8415A8B
Interface device = %phx_vos#enetA.m16.10-5-1
MAC address               = 0000A8615A8B

Interface device          = %phx_vos#enetA.m16.11-5-1

 

sdlmux device             = #sdlmux.m16.11-2
MAC address               = 0000A8425A8B
Interface device = %phx_vos#enet.m16.11.11-2
MAC address               = 0000A8625A8B

Interface device          = %phx_vos#enet.m16.10.11-2

 

sdlmux device             = #sdlmux.m16.11-3
MAC address               = 0000A8435A8B
Interface device = %phx_vos#enet.m16.10.11-3
MAC address               = 0000A8635A8B
Interface device          = %phx_vos#enet.m16.11.11-3
as:
Figura 2
Em terceiro lugar, os adaptadores de rede SDLMUX enviam quadros Ethernet 802.2 LLC a seus parceiros para assegurar que o caminho da rede esteja funcionando corretamente. Cinco conjuntos destes quadros de teste saem em intervalos de três segundos, seguidos por um intervalo de 33 segundos. O traço 1 mostra três ciclos deste padrão. O Trace 1 também mostra o quadro real do adaptador ativo (quadro 1) e o adaptador de espera (quadro 2). Destaquei o quadro que segue o intervalo de 33 segundos apenas para facilitar a leitura dos ciclos. Estes não são quadros Ethernet tipo II ou pacotes IP e os switches conectados aos adaptadores de rede e quaisquer switches ao longo do caminho entre os dois adaptadores devem ter uma configuração que não bloqueie estes quadros 802.2 LLC.

 

No. delta Time       Source              Destination   Protocol Info
1 0.000000   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
0000 00 00 a8 62 5a 8b 00 00 a8 42 5a 8b 00 1b ac ac   ...bZ....BZ.....
0010 03 31 32 39 2e 31 2e 30 00 00 00 00 00 00 00 00   .129.1.0........
0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00   ................
0030 00 00 00 00 00 00 00 00 00 00 00 00 b1 60 74 48   .............`tH
2 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
0000 00 00 a8 42 5a 8b 00 00 a8 62 5a 8b 00 1b ac ac   ...BZ....bZ.....
0010 03 31 32 39 2e 31 2e 30 00 00 00 00 00 00 00 00   .129.1.0........
0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00   ................
0030 00 00 00 00 00 00 00 00 00 00 00 00 45 23 24 c0   ............E#$.
3 2.999945   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
4 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
5 2.999943   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
6 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
7 2.999882   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
8 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
9 2.999946   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command

10 0.000009   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command

11 32.99900   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
12 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
13 2.999945   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
14 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
15 2.999938   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
16 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
17 2.999942   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
18 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
19 2.999943   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
20 0.000008   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
21 32.99900   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
22 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
23 2.999944   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
24 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
25 2.999947   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
26 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
27 2.999938   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
28 0.000007   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
29 2.999946   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
30 0.000010   StratusC_62:5a:8b     StratusC_42:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
31 32.99900   StratusC_42:5a:8b     StratusC_62:5a:8b LLC   U, func=UI; DSAP 0xac Individual, SSAP 0xac Command
Traço 1
Note que você não pode usar o packet_monitor para ver estes quadros de teste. Os quadros são enviados abaixo do ponto em que o packet_monitor bate na pilha e o SDLMUX remove os quadros da pilha antes que o packet_monitor possa lê-los.
Quarto, se cada adaptador estiver conectado a um switch diferente e a ligação entre esses switches falhar ou por alguma outra razão, os quadros de teste não se tornam, embora você veja algo que se parece com a figura 3 no syserr_log. A partir da versão 16.2.1ak e 17.0.0ah, se houver uma falha no quadro de teste, o SDLMUX aciona um pedido de ARP para o último host que foi ARP'ed com sucesso sobre a interface suspeita. Se obtiver uma resposta, ele sabe que o adaptador ativo está funcionando, então ele reinicia o adaptador de espera para tentar fazer com que ele funcione. Se houver um problema de rede bloqueando os quadros de teste, reinicializar o adaptador não ajuda e o adaptador eventualmente vai para o MTBF, veja o carimbo de tempo 08:08:10 na figura 3. O comando dlmux_admin informará o adaptador quebrado como DOWN, figura 4, e um traço não mostrará nenhum quadro de teste, já que neste ponto não há nada para testar. Se uma resposta da ARP não for recebida ou o problema estiver em um lançamento que não envie o pedido da ARP, o SDLMUX falhará sobre os adaptadores e quebrará o novo adaptador de espera. Se durante o próximo ciclo os quadros de teste falharem novamente e nenhuma resposta da ARP for recebida, a falha e a quebra será feita novamente. Eventualmente, um adaptador irá para o MTBF.
08:05:02 WARNING(64): SDLMUX: the devices in group #sdlmux.m16.11-2
08:05:02 WARNING(65): SDLMUX: are not exchanging test packets with each other
08:05:02 WARNING(66): SDLMUX: but the active adapter is able to communicate wi
+th other hosts!
08:05:02 WARNING(67): SDLMUX: This indicates some sort of network or cabling i
+ssue!
08:05:02 WARNING(68): SDLMUX: breaking adapter %phx_vos#enet.m16.10.11-2: XID
+communication issue
08:05:02 PCI 10/11/2           enet.m16.10.11-2 Break Requested
08:05:02 WARNING(69): SDLMUX: device name %phx_vos#enet.m16.10.11-2 is broken
08:05:02 PCI 10/11/2           enet.m16.10.11-2 Adding
08:05:04 PCI 10/11/2           enet.m16.10.11-2 Online
08:05:04 WARNING(70): genet in (10/11/2) Link is Up.
08:05:04 WARNING(71): SDLMUX: device %phx_vos#enet.m16.10.11-2 back to servic
+e
08:05:49 WARNING(72): SDLMUX: breaking adapter %phx_vos#enet.m16.10.11-2: XID
+communication issue
08:05:49 PCI 10/11/2           enet.m16.10.11-2 Break Requested
08:05:49 WARNING(73): SDLMUX: device name %phx_vos#enet.m16.10.11-2 is broken
08:05:49 PCI 10/11/2           enet.m16.10.11-2 Adding
08:05:52 PCI 10/11/2           enet.m16.10.11-2 Online
08:05:52 WARNING(74): genet in (10/11/2) Link is Up.
08:05:52 WARNING(75): SDLMUX: device %phx_vos#enet.m16.10.11-2 back to servic
+e
08:07:22 WARNING(76): SDLMUX: the devices in group #sdlmux.m16.11-2
08:07:22 WARNING(77): SDLMUX: are not exchanging test packets with each other
08:07:22 WARNING(78):  SDLMUX: but the active adapter is able to communicate wi
+th other hosts!
08:07:22 WARNING(79): SDLMUX: This indicates some sort of network or cabling i
+ssue!
08:07:22 WARNING(80): SDLMUX: breaking adapter %phx_vos#enet.m16.10.11-2: XID
+communication issue
08:07:22 PCI 10/11/2           enet.m16.10.11-2 Break Requested
08:07:22 WARNING(81): SDLMUX: device name %phx_vos#enet.m16.10.11-2 is broken
08:07:22 PCI 10/11/2           enet.m16.10.11-2 Adding
08:07:25 PCI 10/11/2           enet.m16.10.11-2 Online
08:07:25 WARNING(82): genet in (10/11/2) Link is Up.
08:07:25 WARNING(83): SDLMUX: device %phx_vos#enet.m16.10.11-2 back to servic
+e
08:08:10 WARNING(84): SDLMUX: breaking adapter %phx_vos#enet.m16.10.11-2: XID
+communication issue
08:08:10 PCI 10/11/2           enet.m16.10.11-2 Break Requested
08:08:10 PCI 10/11/2                             MTBF Failure
08:08:10 WARNING(85): SDLMUX: device name %phx_vos#enet.m16.10.11-2 is broken
Figura 3
dlmux_admin #sdlmux.m16.11-2 sdlmux_status
Group Name:          #sdlmux.m16.11-2
Device Name:         %phx_vos#enet.m16.11.11-2
Adapter State:       ACTIVE   UP
Partner:             %phx_vos#enet.m16.10.11-2
Partner State:       DOWN
Figura 4
Para trazer o adaptador de volta ao serviço, você precisa adicioná-lo de volta com o comando board_admin. É claro que se você fizer isso sem corrigir o problema subjacente, o adaptador irá apenas MTBF novamente.
board_admin 10/11/2 add
board_admin
device_id:    10/11/2
action:       add
Do you want to continue? (yes, no) yes
Command completed.
Figura 5
Quinto, como o adaptador ativo sempre tem o mesmo endereço MAC, o efeito de uma falha é mover o endereço MAC de uma porta de comutação para outra. Qualquer configuração de segurança nas portas do switch deve permitir esta mudança. As portas do switch também podem ser configuradas para conversar com outras portas do switch, negociando várias configurações. Estas podem ser acionadas quando o switch notar uma mudança na topologia, como um novo endereço MAC ou um link sendo restaurado. Até que estas configurações sejam negociadas, um switch não pode passar por quadros regulares. As portas do switch conectadas aos adaptadores SDLMUX devem ser configuradas para não realizar estas negociações. Além disso, as portas do switch conectadas aos adaptadores SDLMUX devem ser configuradas para não executar o protocolo spanning tree ou para pular os passos de aprendizagem e escuta (isto é chamado de portfast pela Cisco). Durante as etapas de aprendizagem e escuta, o switch não passará por quadros de dados regulares. Em casos extremos, o atraso causado por estas configurações pode ser tão longo que o SDLMUX aciona outra falha.
Finalmente, o status do link dos adaptadores precisa ser monitorado para ter certeza de que ambos os links estão funcionando. A falha de um link não fará com que o sistema ligue para casa e, devido à sua tolerância a falhas, não há perda de conectividade do sistema que eu cobri em um post de blog anterior, veja Monitoramento do status dos adaptadores de rede.

© 2024 Stratus Technologies.