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 / 793723
Accepted
Crash Override
Crash Override
Asked: 2016-08-04 13:48:29 +0800 CST2016-08-04 13:48:29 +0800 CST 2016-08-04 13:48:29 +0800 CST

Proibindo um intervalo de IP de sair para a Internet no Red Hat/CentOS Linux

  • 772

Eu tenho uma VPN e meu servidor frequentemente envia dados para um endereço IP privado que é roteado pela VPN. Quando o OpenVPN se estabelece ou morre, ele ativa/desativa as rotas.

Quero rotear nulo esse intervalo de IP privado de sair pela interface principal da Internet (eth0). Existe uma maneira fácil de fazer isso sem interferir nos comandos de rota provenientes do software VPN?

Iptables não vai fazer isso. eu tentei

iptables -A OUTPUT -i eth0 -p tcp -d 192.168.0.0/16 -j REJECT

Mas o iptables não funciona ao especificar uma interface na cadeia de saída.

Alguém sabe se existe uma maneira de adicionar uma rota fictícia apenas a uma interface específica (eth0), sem interferir em outras interfaces que possam estar usando essa rota?

Ps- Estou ciente de que 192.168.0.0/16 não é roteável pela INTERNET, mas por motivos de segurança, quero garantir que nenhum dado saia na rara chance de outro servidor local ou dispositivo de rede começar a escutar na sub-rede privada.

centos iptables static-routes
  • 3 3 respostas
  • 217 Views

3 respostas

  • Voted
  1. Best Answer
    Michael Hampton
    2016-08-04T13:54:06+08:002016-08-04T13:54:06+08:00

    Sua especificação de interface na regra iptables está invertida.

    Você especificou:

    iptables -A OUTPUT -i eth0 -p tcp -d 192.168.0.0/16 -j REJECT
    

    O uso -icorresponde ao tráfego que entra no sistema na interface nomeada.

    Em vez disso, você deseja corresponder ao tráfego que sai do sistema na interface nomeada, o que é feito com -o.

    iptables -A OUTPUT -o eth0 -p tcp -d 192.168.0.0/16 -j REJECT
    

    (E você provavelmente não quer -p tcpentrar lá, caso contrário, o tráfego não TCP pode passar.)

    • 5
  2. Tero Kilkanen
    2016-08-04T17:32:03+08:002016-08-04T17:32:03+08:00

    Além da resposta de Michael, acho que se deve bloquear o tráfego na FORWARDcadeia, pois a OUTPUTcadeia se aplica apenas a pacotes gerados localmente e saindo do firewall. Tanto quanto eu sei, não se aplica a pacotes roteados.

    • 2
  3. GnP
    2016-08-09T15:50:01+08:002016-08-09T15:50:01+08:00

    Você já tem a resposta que precisava para fazer isso com o iptables.

    Se você quiser fazer isso com rotas, uma boa maneira é ter uma rota para 192.168.0.0/16 e fazer com que seu servidor vpn envie duas rotas um pouco mais específicas; no seu caso, as duas rotas seriam 192.168.0.0 /17 e 192.168.128.0/17

    A rota /16 seria fixa e com roteamento nulo:

    ip route add blackhole 192.168.0.0/16
    

    E seu servidor vpn (ou script vpn-up) forneceria os outros:

    ip route add 192.168.0.0/17 via <VPNGW>
    ip route add 192.168.128.0/17 via <VPNGW>
    

    Na verdade, é isso que a def1opção do OpenVPN faz para substituir o gateway padrão sem mexer nas rotas existentes.

    • 2

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