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 / 457025
Accepted
TheDiveO
TheDiveO
Asked: 2018-07-19 06:59:31 +0800 CST2018-07-19 06:59:31 +0800 CST 2018-07-19 06:59:31 +0800 CST

Mudar para um namespace de rede não altera /sys/class/net?

  • 772

A página de manual do Linux para namespaces de rede(7) diz:

Os namespaces de rede fornecem isolamento dos recursos do sistema associados à rede: [...], o diretório /sys/class/net, [...].

No entanto, simplesmente mudar para um namespace de rede diferente não parece alterar o conteúdo de /sys/class/net(veja abaixo como reproduzir). Estou apenas enganado aqui ao pensar que o namespace setns()da rede já é suficiente? É sempre necessário remontar /syspara obter a /sys/class/netcorrespondência correta do namespace de rede atualmente associado? Ou estou perdendo alguma coisa aqui?

Exemplo para reproduzir

Pegue um sistema *ubuntu, encontre o PID do rtkit-daemon, insira o namespace de rede do daemon, mostre suas interfaces de rede e verifique /sys/class/net:

$ PID=`sudo lsns -t net -n -o PID,COMMAND | grep rtkit-daemon | cut -d ' ' -f 2`
$ sudo nsenter -t $PID -n
# ip link show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default qlen 1000
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
# ls /sys/class/net
docker0  enp3s0  lo  lxcbr0  ...

Observe que, embora ip link showcorretamente mostre apenas lo, /sys/class/netmostra todas as interfaces de rede visíveis no namespace de rede "raiz" (e no namespace de montagem "raiz").

No caso de rtkit-daemontambém entrar no namespace mount dele não faz diferença: sudo nsenter -t $PID -n -me depois ls /sys/class/netainda mostra as interfaces de rede não presentes no namespace da rede.

"Fixar"

Muitos elogios para @Danila Kiver por explicar o que realmente está acontecendo nos bastidores do kernel Linux. A remontagem sysfs enquanto o namespace de rede correto é associado mostrará as entradas corretas/sys/class/net em :

$ PID=`sudo lsns -t net -n -o PID,COMMAND | grep rtkit-daemon | cut -d ' ' -f 2`
$ sudo nsenter -t $PID -n
# MNT=`mktemp -d`
# mount -t sysfs none $MNT
# ls $MNT/class/net/
lo
# umount $MNT
# rmdir $MNT
# exit

Portanto, isso agora produz os resultados corretos em /sys/class/net.

linux namespace
  • 1 1 respostas
  • 2540 Views

1 respostas

  • Voted
  1. Best Answer
    Danila Kiver
    2018-07-21T00:46:47+08:002018-07-21T00:46:47+08:00

    Vamos analisar man 5 sysfs:

    /sys/class/net
        Each  of the entries in this directory is a symbolic link representing
        one of the real or virtual networking devices that are visible in 
        the network namespace of the process that is accessing the directory.
    

    Portanto, de acordo com esta página de manual, a saída de ls /sys/class/netdeve depender do namespace de rede do lsprocesso. Mas... O comportamento real não parece ser o descrito nesta página de manual. Existe uma boa documentação do kernel sobre como ele funciona .

    Cada sysfsmontagem tem uma tag de namespace associada a ela. Essa tag é definida quando o sysfs é montado e depende do namespace de rede do processo de chamada . Cada entrada sysfs (por exemplo, uma entrada em /sys/class/net) também pode ter uma tag namespace associada a ela.

    Quando você itera sobre o diretório sysfs, o kernel obtém a tag namespace do sysfs mount e, em seguida, itera sobre as entradas, filtrando aquelas que têm tag namespace diferente .

    Então, acontece que os resultados da iteração sobre o /sys/class/netdependem do namespace de rede do processo que iniciou a /sysmontagem em vez do namespace de rede do processo atual, portanto, você deve sempre montar /sysno namespace de rede atual (de qualquer processo pertencente para este namespace) para ver os resultados corretos.

    • 10

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