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 / unix / Perguntas / 484453
Accepted
TheDiveO
TheDiveO
Asked: 2018-11-28 06:17:05 +0800 CST2018-11-28 06:17:05 +0800 CST 2018-11-28 06:17:05 +0800 CST

O que é uma rota IP do Linux sem interface de rede de saída (resposta RTLINK sem `RTA_OIF`) e como crio uma para teste?

  • 772

Ao usar o RTLINK para consultar a rota IP disponível de um kernel Linux (com namespace de rede), notei que em um sistema de teste o RTLINK retorna uma rota sem um RTA_OIFatributo, ou seja, sem uma interface de rede de saída especificada.

Infelizmente, não tenho ideia de como reproduzir essa situação (para teste) usando o ip route addcomando e até agora nenhuma pessoa ao meu alcance conseguiu explicar "o que" originalmente criou essa rota sem qualquer indicação de uma interface de rede de saída. De uma olhada nas fontes do kernel do Linux, notei que o atributo de interface de rede de saída na verdade é opcional. No entanto, minhas tentativas ip route addsempre acabam com uma interface de rede de saída adicionada automaticamente pelo kernel ou uma interface inacessível:

ip route add 1.1.1.1/32 via 1.1.1.2dá RTNETLINK answers: Network is unreachable.

Próxima tentativa (falhou):

ip addr add 1.1.1.2/32 dev ens33
ip route add 1.1.1.1/32 via 1.1.1.2
ip route show

... então dá 1.1.1.1 via 1.1.1.2 dev ens33, onde o kernel inseriu automaticamente uma interface de rede de saída adequada (e, portanto, RTA_OIFestá presente, mesmo que eu não a especifique no início).

Pesquisar coisas como "rota ip linux sem interface de saída" ou similar não me dá resultados utilizáveis ​​- a menos que eu esteja ignorando algo importante aqui.

Então, como posso criar um caso (de teste) em que tenho uma rota IP sem uma interface de rede de saída? O que estou negligenciando aqui?

linux routing
  • 1 1 respostas
  • 370 Views

1 respostas

  • Voted
  1. Best Answer
    TheDiveO
    2018-11-29T04:01:10+08:002018-11-29T04:01:10+08:00

    Acontece que rotas sem interfaces de rede de saída (não: regras, que estão relacionadas ao roteamento) são usadas pelo menos para estes três casos de uso:

    1. as chamadas rotas de buraco negro, onde a pilha de IP descarta silenciosamente todo o tráfego correspondente à rota.
    2. rotas inacessíveis , em que a pilha de IP descarta todo o tráfego destinado a essas rotas e, adicionalmente, aciona uma resposta inacessível ICMP(v6).
    3. proibir rotas, onde novamente a pilha de IP descarta todo o tráfego, também envia uma resposta ICMP(v6), mas desta vez um "proibido" em vez de "inacessível".

    Essas rotas podem ser facilmente criadas da seguinte forma:

    # ip route add blackhole 1.2.3.4
    # ip route add unreachable 1.2.3.5
    # ip route add prohibit 1.2.3.6
    

    Um ip route showentão confirma que essas rotas não têm interfaces de rede de saída:

    $ ip route show
    ...
    blackhole 1.2.3.4
    unreachable 1.2.3.5
    prohibit 1.2.3.6
    
    • 0

relate perguntas

  • Existe uma maneira de fazer ls mostrar arquivos ocultos apenas para determinados diretórios?

  • Inicie/pare o serviço systemd usando o atalho de teclado [fechado]

  • Necessidade de algumas chamadas de sistema

  • astyle não altera a formatação do arquivo de origem

  • Passe o sistema de arquivos raiz por rótulo para o kernel do Linux

Sidebar

Stats

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

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    ssh Não é possível negociar: "nenhuma cifra correspondente encontrada", está rejeitando o cbc

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    Como descarregar o módulo do kernel 'nvidia-drm'?

    • 13 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add retorna com: "Erro ao conectar ao agente: nenhum arquivo ou diretório" 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya Por que o Linux usa LF como caractere de nova linha? 2017-12-20 05:48:21 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk 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