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 / 525695
Accepted
Jake
Jake
Asked: 2019-06-19 10:05:32 +0800 CST2019-06-19 10:05:32 +0800 CST 2019-06-19 10:05:32 +0800 CST

Seleção de rota do Linux não seguindo a regra esperada

  • 772

Eu tenho as seguintes regras de roteamento (exibidas usando route -n):

Kernel IP routing table
Destination  Gateway    Genmask         Flags Metric Ref Use Iface
0.0.0.0      10.0.2.1   0.0.0.0         UG    100    0     0 enp0s3
10.0.2.0     0.0.0.0    255.255.255.192 U     100    0     0 enp0s3.100
10.0.2.0     0.0.0.0    255.255.255.0   U     100    0     0 enp0s3
169.254.0.0  0.0.0.0    255.255.0.0     U     1000   0     0 enp0s3

A interface enp0s3.100é uma interface com ID de VLAN 100.

Se eu tentar obter a rota para 10.0.2.70, espero que use a interface VLAN, mas não:

# ip route get 10.0.2.70
10.0.2.70 dev enp0s3  src 10.0.2.11 
    cache

Alguém sabe por que a correspondência de prefixo mais longa não está sendo usada aqui?

routing vlan
  • 1 1 respostas
  • 140 Views

1 respostas

  • Voted
  1. Best Answer
    wurtel
    2019-06-19T23:04:31+08:002019-06-19T23:04:31+08:00

    Em primeiro lugar, é melhor usar apenas os ipcomandos, então você deveria ter usado ip route show(ou ip rabreviado) para listar a tabela de roteamento.

    Nesse caso, a rota pela VPN é para 10.0.2.0/255.255.255.192 ou 10.0.2.0/26. Essa sub-rede é de 0 a 63. Seu destino de exemplo 10.0.2.70 está fora desse intervalo, portanto, não é roteado pela VPN, mas usa a próxima rota mais específica de 10.0.2.0/24, que é sobre enp0s3.

    Você menciona a "correspondência de prefixo mais longo", eu costumo ouvir "correspondência mais específica", ou seja, onde o intervalo é o menor, o que de fato implica o prefixo mais longo. No entanto, como dito acima, o endereço IP que você está testando não está dentro do prefixo que você acha que está.

    No Debian (e derivados) existe um utilitário muito útil netmask, que pode ajudar a tornar as coisas mais claras:

    $ netmask -r 10.0.2.0/255.255.255.192
           10.0.2.0-10.0.2.63       (64)
    

    Observe que ip route shownão mostra toda a história, é possível que o roteamento baseado em política esteja em jogo. Você também precisa listar todas as regras de roteamento, esta é a saída normal:

    $ ip rule show
    0:  from all lookup local 
    32766:  from all lookup main 
    32767:  from all lookup default 
    

    Você pode então listar as entradas de roteamento em uma determinada tabela desta forma, aqui para a tabela "local":

    $ ip route show table local
    

    Isso é chamado de roteamento baseado em política. Normalmente você não usará isso (você usará se tiver mais de uma conexão com a Internet, por exemplo), mas ajuda estar ciente disso ao solucionar problemas de roteamento em sistemas que você não configurou.

    • 2

relate perguntas

  • iptables: proxy de tráfego tcp transparente

  • O que iptables -j REDIRECT *realmente* faz nos cabeçalhos dos pacotes?

  • Alterar a métrica de uma interface permanentemente

  • Alguma distribuição criada para comutação/roteamento de camada 3?

  • Debian 9; configurando dispositivos de rede para um servidor www

Sidebar

Stats

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

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

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

    • 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

    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
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • 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
    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

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