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 / server / Perguntas / 995399
Accepted
JoBe
JoBe
Asked: 2019-12-13 13:42:55 +0800 CST2019-12-13 13:42:55 +0800 CST 2019-12-13 13:42:55 +0800 CST

É possível rotear toda a comunicação para uma porta, para outra interface de rede?

  • 772

Curto: Gostaria de saber se é possível rotear (com iptables), então todas as comunicações que são direcionadas para/de 192.168.1.10 (eth0) porta 40000 são enviadas para tun0? (VPN)

Mais: Quando estou me conectando ao meu servidor VPN, todos os dados são roteados pela rede tun0, exceto este aplicativo (que não vai a lugar nenhum) que se recusa totalmente a entender (programação ruim). Isso faz com que o aplicativo dê uma cabeçada no sistema sem sair.

É possível forçá-lo roteando todos os dados que vão para 192.168.1.10:40000 para serem enviados para tun0 (interface de rede VPN) e rotear todos os dados de entrada de tun0:40000 para serem roteados de volta para 192.168.1.10

Atualização: Este é o resultado da rota IP -4:

*0.0.0.0/1 via 10.128.0.1 dev tun0 
default via 192.168.1.1 dev enp0s3 proto dhcp metric 20100 
10.128.0.0/22 dev tun0 proto kernel scope link src 10.128.2.129 
128.0.0.0/1 via 10.128.0.1 dev tun0 
169.254.0.0/16 dev tun0 scope link metric 1000 
192.168.1.0/24 dev enp0s3 proto kernel scope link src 192.168.1.173 metric 100 
217.64.xxx.xx via 192.168.1.1 dev enp0s3* 
linux
  • 1 1 respostas
  • 648 Views

1 respostas

  • Voted
  1. Best Answer
    Piotr P. Karwasz
    2019-12-14T11:55:04+08:002019-12-14T11:55:04+08:00

    Quando estou me conectando ao meu servidor VPN, todos os dados são roteados pela rede tun0, exceto este aplicativo, que se recusa totalmente a entender (programação ruim).

    A programação de rede tem um modelo em camadas , significa que o autor do aplicativo apenas diz ao sistema para se conectar a um determinado endereço IP em uma determinada porta, ele não precisa se preocupar com o resto, pois como chegar a esse soquete TCP/IP é até o sistema operacional.

    Seu problema é causado por uma configuração de roteamento ruim. Vamos pegar algumas linhas como esta:

    1.2.3.0/29 dev tun0
    1.2.0.0/22 dev tun0 via 1.2.3.4 
    

    A primeira significa: se os 29 bits mais à esquerda do endereço de destino são idênticos aos de 1.2.3.0(ou seja, de 1.2.3.0para 1.2.3.7) envie o pacote diretamente em tun0. A segunda linha significa que os endereços de 1.2.0.0para 1.2.3.255, que não estão na /29linha, devem ser enviados para 1.2.3.4. O kernel sabe como encontrar 1.2.3.4desde a primeira linha.

    As tabelas de roteamento do Windows são quase idênticas (eles originalmente pegaram a pilha TCP/IP do BSD).

    Agora a sua situação. Você tem duas entradas de roteamento:

    0.0.0.0/1 via 10.128.0.1 dev tun0 
    default via 192.168.1.1 dev enp0s3
    

    onde defaulté um atalho para 0.0.0.0/0(todos os endereços). Assim: se o endereço de destino começa com 0até 128, ele é enviado por tun0, caso contrário, é enviado por enp0s3.

    Se você deseja rotear quase todo o tráfego através tun0de , primeiro encontre o endereço do outro endpoint do túnel VPN (provavelmente ip linkpode ajudar, mas você não disse o que está usando para o seu túnel). Vamos dizer que é 5.5.5.5. tun0é uma interface virtual, que criptografa os pacotes enviados por ela e os envia para o outro endpoint por meio de uma interface física. Então, precisamos adicionar uma rota para que os pacotes 5.5.5.5sejam enviados por enp0s3:

    ip route add 5.5.5.5 via 192.168.1.1 dev enp0s3
    

    (Edit: depois de ler novamente sua tabela de roteamento, isso já está lá, na última linha)

    Então você pode rotear o tráfego restante através de tun0:

    ip route del default
    ip route add default via 10.128.0.1 dev tun0
    

    Dependendo da maneira como você configura suas interfaces (e túnel), você pode fazer essas coisas automaticamente, quando as interfaces forem ativadas.

    TL;DR Basta substituir 0.0.0.0/1por default, onde quer que você o coloque.

    • 1

relate perguntas

  • Como descobrir detalhes sobre hardware na máquina Linux?

Sidebar

Stats

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

    Você pode passar usuário/passar para autenticação básica HTTP em parâmetros de URL?

    • 5 respostas
  • Marko Smith

    Ping uma porta específica

    • 18 respostas
  • Marko Smith

    Verifique se a porta está aberta ou fechada em um servidor Linux?

    • 7 respostas
  • Marko Smith

    Como automatizar o login SSH com senha?

    • 10 respostas
  • Marko Smith

    Como posso dizer ao Git para Windows onde encontrar minha chave RSA privada?

    • 30 respostas
  • Marko Smith

    Qual é o nome de usuário/senha de superusuário padrão para postgres após uma nova instalação?

    • 5 respostas
  • Marko Smith

    Qual porta o SFTP usa?

    • 6 respostas
  • Marko Smith

    Linha de comando para listar usuários em um grupo do Windows Active Directory?

    • 9 respostas
  • Marko Smith

    O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL?

    • 3 respostas
  • Marko Smith

    Como determinar se uma variável bash está vazia?

    • 15 respostas
  • Martin Hope
    Davie Ping uma porta específica 2009-10-09 01:57:50 +0800 CST
  • Martin Hope
    kernel O scp pode copiar diretórios recursivamente? 2011-04-29 20:24:45 +0800 CST
  • Martin Hope
    Robert ssh retorna "Proprietário incorreto ou permissões em ~/.ssh/config" 2011-03-30 10:15:48 +0800 CST
  • Martin Hope
    Eonil Como automatizar o login SSH com senha? 2011-03-02 03:07:12 +0800 CST
  • Martin Hope
    gunwin Como lidar com um servidor comprometido? 2011-01-03 13:31:27 +0800 CST
  • Martin Hope
    Tom Feiner Como posso classificar a saída du -h por tamanho 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich O que é um arquivo Pem e como ele difere de outros formatos de arquivo de chave gerada pelo OpenSSL? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent Como determinar se uma variável bash está vazia? 2009-05-13 09:54:48 +0800 CST

Hot tag

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

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