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 / computer / Perguntas / 1731924
Accepted
LivingSilver94
LivingSilver94
Asked: 2022-07-16 13:11:12 +0800 CST2022-07-16 13:11:12 +0800 CST 2022-07-16 13:11:12 +0800 CST

Aproveite o firewall UDP com estado para servidores Wireguard em NATs

  • 772

Eu tenho uma configuração "cliente-servidor" composta por um computador servidor Wireguard e um cliente, ambos sob seus respectivos NAT. Eu quero que eles se comuniquem sem encaminhamento de porta no roteador do cliente. Obviamente, ainda preciso de encaminhamento de porta no roteador do servidor.

De acordo com este comentário , pode-se aproveitar o firewall UDP com estado se as respostas do servidor vierem da mesma porta que o cliente usou para alcançá-lo. Para fazer isso, configurei ListenPortpara 58120 em ambas as extremidades:

[Interface]
ListenPort = 51820
...snip...

Agora, com tcpdumpexecutado no roteador do cliente, posso provar que os pacotes estão saindo com a porta de origem 51820 e a porta de destino 51820. O mesmo com tcpdumpexecutado no roteador do servidor: pacotes de saída com origem e destino definidos para 51820.

No entanto, na direção de entrada, o roteador do cliente mostra que os pacotes vêm da porta 1025. Parece que o NAT do lado do servidor mudou a porta 51820 para 1025. Isso ocorre porque a porta 51820 já está ocupada pelo encaminhamento de porta? Como posso ter portas de origem e destino iguais para que o roteador do cliente detecte uma "conexão" UDP?

Detalhe da implementação: firewalls e NATs são controlados por iptables.

firewall iptables
  • 1 1 respostas
  • 100 Views

1 respostas

  • Voted
  1. Best Answer
    user1686
    2022-07-16T13:45:56+08:002022-07-16T13:45:56+08:00

    De acordo com este comentário, pode-se aproveitar o firewall UDP com estado se as respostas do servidor vierem da mesma porta que o cliente usou para alcançá-lo.

    Não é isso que o comentário diz. As portas não precisam ser iguais; eles só precisam ser simétricos. Ou seja, se os pacotes saírem com a porta de origem 51820 e a porta de destino 28150, o NAT esperará que os pacotes de entrada sejam da porta 28150 a 51820.

    (Dê uma olhada em, por exemplo, solicitações de DNS – você não verá pacotes com 53→53, verá [random]→53 e o firewall apenas esperará respostas com 53→[random].)

    No entanto, na direção de entrada, o roteador do cliente mostra que os pacotes vêm da porta 1025. Parece que o NAT do lado do servidor mudou a porta 51820 para 1025. Isso ocorre porque a porta 51820 já está ocupada pelo encaminhamento de porta?

    O mais provável é que o NAT já esteja rastreando outra conversa UDP com esse destino que usa a mesma porta local (mas talvez vindo de um endereço IP interno diferente ou indo para uma porta remota diferente).

    O módulo SNAT / MASQUERADE padrão no iptables não analisa quais regras de encaminhamento de porta você tem - ele só tem informações sobre o estado do conntrack (os fluxos rastreados atualmente), mas tentará reescrever a porta local para garantir a exclusividade da entrada host:port (veja nf_nat_used_tuple).

    Verifique conntrack -L -p udpno gateway; você pode querer liberar estados antigos se estiver editando frequentemente as regras de NAT para experimentos.

    Algumas implementações de NAT em gateways usam um módulo NAT iptables personalizado e sempre alteram a porta de origem de todas as conexões de saída. Isso geralmente vem junto com o termo "Symmetric NAT" (em oposição ao "Cone NAT" mais brando que o iptables padrão implementa).

    Artigo relevante (de desenvolvedores de um aplicativo VPN baseado em WireGuard): https://tailscale.com/blog/how-nat-traversal-works/

    • 1

relate perguntas

  • O Firewall do Windows bloqueia a solicitação de carimbo de data/hora ICMP (tipo 13) por padrão?

  • Sintaxe para perfis de aplicativos ufw, especificamente para definir interfaces e endereços IP

  • É possível bloquear a exibição de todo o conteúdo carregado de algum local? [fechado]

  • Por que o firewall do Windows não está bloqueando o acesso VNC de entrada?

  • como configurar nfs e iptables

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
    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
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +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