AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / user-1718216

Nykau's questions

Martin Hope
Nykau
Asked: 2024-06-26 23:19:44 +0800 CST

nftables não captura um pacote que já viu

  • 6

Eu configurei uma rede local segmentada, onde cada segmento é VLAN e o switch na raiz de todas as VLANs também atua como roteador entre todos os segmentos IP/VLAN (o switch é o Dell S4810 executando DNOS 9.14). gateway para a Internet e o endereço IP local do gateway da Internet é o endereço IP do gateway padrão do S4810. Antes de encaminhar pacotes para o exterior, aplica-se SNAT (masquerade) para que o pacote encaminhado para a Internet tenha como endereço de origem o endereço público do roteador padrão. Nada sofisticado aqui. Quase tudo parece funcionar conforme o esperado: um nó em qualquer segmento pode entrar em contato com outros nós em outros segmentos, todos eles podem acessar a Internet e obter uma resposta, e os nós fora desta LAN veem o endereço IP de origem mascarado correto.

As coisas ficam complicadas quando a máquina de gateway da Internet (NÃO o S4810) também executa VMs com Proxmox. Esta máquina executa o Debian 12.5 e é configurada com interfaces VLAN sobre a física que vai para o S4810, e as próprias interfaces VLAN são agrupadas em pontes, uma por VLAN. A interface para a internet também está envolvida em sua própria ponte. Eu uso pontes para que o Proxmox VM possa usá-las para conectar-se a qualquer uma das redes. Quando uma VM rodando nesta máquina com uma interface virtual na ponte da Internet, ela pode acessar a Internet corretamente, mas com um endereço IP de origem que não precisa de SNAT e não é SNAT.

Quando outra VM com uma interface virtual em uma das interfaces/pontes da VLAN, ela pode alcançar outras máquinas na VLAN correspondente. Além disso, qualquer máquina em segmentos VLAN consegue acessar a Internet usando o S4810 como gateway padrão sem problemas, incluindo VM, desde que não sejam executadas no gateway de Internet/hipervisor Proxmox, mas em qualquer outra máquina hipervisor Proxmox. No entanto, quando uma VM em execução no gateway de Internet/hipervisor Proxmox deseja acessar a Internet por meio de uma das VLANs, ela não consegue. Assim como outras máquinas que funcionam conforme esperado, a VM está configurada para usar o S4810 como gateway padrão. O S4810 redireciona para o gateway de Internet/hipervisor Proxmox qualquer um dos pacotes destinados à Internet que dele recebe, e esse gateway deve encaminhar o pacote com mascaramento.

Posso ver os pacotes indo para o S4810, posso ver o S4810 enviando de volta o pacote para o gateway da Internet, posso ver o pacote duas vezes tsharkno gateway da Internet (uma vez com ttl 64, a segunda vez com ttl 62, ou seja, após o segundo roteamento ser executada), mas a tabela nftablesde nat postrouting(prioridade srcnat) parece capturá-la apenas uma vez, com ttl 64, ou seja, antes de ser enviada para qualquer lugar e antes que o mascaramento precise ser aplicado. Quando o pacote está de volta e o mascaramento precisa ser aplicado, parece que nftablesnão o vê, conforme afirmado com meta nftrace set 1a regra no topo da tabela e o comando nat postroutingcorrespondente . nft monitor traceComo resultado, o mascaramento não é aplicado e o nó externo que recebe o pacote o recebe com o endereço de origem não SNAT e não pode enviar uma resposta.

Existe tal recurso nftablesque aceitaria ver um determinado pacote apenas uma vez? Se sim, como posso desativá-lo para aplicar a máscara no momento certo? Ou é algo totalmente diferente que acontece? Ficarei feliz em fornecer qualquer registro ou captura necessária para me ajudar a solucionar o problema.

debian
  • 1 respostas
  • 16 Views
Martin Hope
Nykau
Asked: 2023-05-05 02:50:16 +0800 CST

Gerenciando dispositivo raid6 com marcapasso

  • 6

Estou configurando 4 hosts, cada um exportando um dispositivo de armazenamento local iscsicom target. Todos os outros hosts o importam de forma que cada host tenha acesso simultâneo a todos os 4 dispositivos de armazenamento. Criei um LVMgrupo de volume compartilhado que inclui todos esses 4 iscsidispositivos. Neste grupo de volumes, criei 4 volumes lógicos, cada um com um dos iscsidispositivos importados. Por fim, uso o mecanismo de sincronização LVMcompartilhada VG, usando lvmlockdedlm para garantir que apenas um host possa usar esses volumes lógicos por vez. Por fim, construí um raid6array em cima desses 4 volumes lógicos, para que a princípio eu possa ter até 2 hosts inativos sem interromper o serviço de armazenamento.

Eu gerencio tudo usando pacemaker, desde a exportação iscside volumes targetaté a construção da raid6matriz. Até agora, tudo funciona perfeitamente, exceto gerenciar cenários em que 1 ou 2 nós estão inativos; os dados estão seguros, mas como defino restrições para iniciar a raid6matriz depois que os recursos de 4 volumes lógicos são iniciados, pacemakerdesativa a matriz assim que pelo menos 1 host fica offline. Eu gostaria pacemakerde continuar o serviço até a perda de 2 hosts.

Para isso, eu precisaria de restrições de ordem (e colocation) que habilitassem o raid6array se e somente se pelo menos 2 desses volumes lógicos estivessem online. Melhor ainda: habilite o raid6array se e somente se no máximo 2 volumes lógicos não puderem ser colocados online, por qualquer motivo. Infelizmente, pacemakerpermite apenas que conjuntos de recursos predecessores em ordem e restrições de colocação (ou seja, o recurso ou conjunto de recursos que deve iniciar primeiro) sejam considerados como iniciados se todos os recursos do conjunto forem iniciados ( require-all=true) ou se pelo menos um for iniciado ( require-all=false) , mas não se pelo menos dois forem iniciados ou no máximo dois estiverem ausentes.

Como solução alternativa, considero criar 11 raid6recursos, um para cada cenário utilizável possível, ou seja, um para cada cenário possível em que faltam no máximo 2 dispositivos lógicos:

  • LVs1 e 2 estão disponíveis
  • LVs1 e 3 estão disponíveis
  • LVs1 e 4 estão disponíveis
  • LVs2 e 3 estão disponíveis
  • LVs2 e 4 estão disponíveis
  • LVs3 e 4 estão disponíveis
  • LVs1, 2 e 3 estão disponíveis
  • LVs1, 2 e 4 estão disponíveis
  • LVs1, 3 e 4 estão disponíveis
  • LVs2, 3 e 4 estão disponíveis
  • LVs1, 2, 3 e 4 estão disponíveis

Eu criaria raid6recursos com restrições de ordem e colocação, cada uma correspondendo a uma linha na enumeração acima. Em seguida, preciso de uma restrição adicional que exclua cada um desses raid6recursos mutuamente, de modo que, a qualquer momento, o array real seja montado apenas uma vez.

Então aqui vão minhas 3 perguntas:

  1. Existe alguma maneira de expressar "no máximo 2 ausentes" no predecessor definido na ordem e na restrição de colocação ou, se não, existe alguma construção de restrição semelhante "pelo menos 2 ativos"?
  2. Se a resposta da questão 1 for não, existe alguma maneira de expressar a exclusão mútua entre um par ou recursos, ou dentro de um conjunto de recursos, preferencialmente com configurações de prioridade que favoreçam as variantes de recursos que usam o maior número de dispositivos?
  3. Existe alguma outra solução alternativa que qualquer assistente de marca-passo possa sugerir?
software-raid
  • 1 respostas
  • 21 Views

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    Vickel O Firefox não permite mais colar no WhatsApp web? 2023-08-18 05:04:35 +0800 CST
  • Martin Hope
    Saaru Lindestøkke Por que os arquivos tar.xz são 15x menores ao usar a biblioteca tar do Python em comparação com o tar do macOS? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve