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 / 457299
Accepted
koalo
koalo
Asked: 2018-07-20 12:36:06 +0800 CST2018-07-20 12:36:06 +0800 CST 2018-07-20 12:36:06 +0800 CST

Perder permissões adicionando capacidade?

  • 772

Observei o seguinte fenômeno que não consigo explicar. Depois de adicionar o CAP_SYS_ADMINrecurso, unsharenão é mais possível gravar em arquivos /proc/self/setgroups.

Na verdade, gravar nesse arquivo requer a capacidade, mas isso é obtido alterando o namespace do usuário. Então, por que adicionar o recurso ao processo pai impede a gravação nesse arquivo?

me@myhost:~$ unshare -r
root@myhost:~# exit
logout

me@myhost:~$ sudo setcap cap_sys_admin=ep /usr/bin/unshare
me@myhost:~$ unshare -r
unshare: cannot open /proc/self/setgroups: Permission denied

me@myhost:~$ sudo setcap cap_sys_admin= /usr/bin/unshare
me@myhost:~$ unshare -r
root@myhost:~#

A propósito: estou executando o Ubuntu 16.04.4 LTS com kernel versão 4.4 e a versão do util-linux (incluindo unshare) é 2.27.1.

namespace unshare
  • 1 1 respostas
  • 1785 Views

1 respostas

  • Voted
  1. Best Answer
    filbranden
    2018-08-01T12:03:42+08:002018-08-01T12:03:42+08:00

    O que está acontecendo aqui é que seu processo de "unshare" não tem acesso para gravar nos arquivos setgroups(e uid_maps, ) no namespace de usuário externo .gid_maps

    Nesse namespace, os pseudo-arquivos /proc/<PID>serão de propriedade do root e, como se seu uid efetivo ainda fosse o de seu próprio usuário, você não terá acesso para gravar nesses arquivos.

    Você pode visualizar isso facilmente executando um processo em segundo plano (como sleep) e inspecionando as permissões do setgroupsarquivo enquanto ele está em execução ( uid_mapse gid_mapsse comportando exatamente da mesma forma).

    Primeiro, com um binário que não possui recursos adicionais:

    $ cp /usr/bin/sleep .
    $ ./sleep 10 &
    [1] 11209
    $ ls -l /proc/11209/setgroups
    -rw-r--r--. 1 myuser myuser 0 Jul 31 12:33 /proc/11209/setgroups
    [1]+  Done                    ./sleep 10
    $
    

    Em seguida, vamos adicionar alguns recursos de arquivo a ele e ver a mudança de propriedade:

    $ sudo setcap cap_net_bind_service=ep sleep
    $ ./sleep 10 &
    [1] 11220
    $ ls -l /proc/11220/setgroups 
    -rw-r--r--. 1 root root 0 Jul 31 12:34 /proc/11220/setgroups
    [1]+  Done                    ./sleep 10
    $
    

    A propriedade dos arquivos /proc/<PID>é controlada pelo sinalizador "dumpable" dentro do kernel do Linux, que é usado para evitar o vazamento de informações de um processo privilegiado para um usuário não privilegiado.

    E considerando que você está executando com recursos adicionais, mas ainda com um uid efetivounshare não root , o acesso de gravação a esses pseudo-arquivos pertencentes ao root é impedido pelos controles de acesso normais do sistema operacional.


    Você pode inspecionar o valor do sinalizador "dumpable" usando o PR_GET_DUMPABLEcomando da syscall prctl(2) .

    Na descrição para PR_SET_DUMPABLEvocê também encontrará:

    Normalmente, esse sinalizador é definido como 1. No entanto, ele é redefinido para o valor atual contido no arquivo /proc/sys/fs/suid_dumpable(que por padrão tem o valor 0), nas seguintes circunstâncias:

    [...]

    • O processo executa ( execve(2)) um programa que possui recursos de arquivo (consulte capabilities(7)), mas somente se os recursos permitidos obtidos excederem os já permitidos para o processo.

    Que é exatamente o seu caso, com um unsharebinário que possui recursos de arquivo.

    Curiosamente, usar um binário setuid de propriedade de root para unsharenão se depara com esse problema exato. Sim, ele limpará os sinalizadores "dumpable" e os arquivos /proc/<PID>serão de propriedade do root. Mas considerando que seu uid efetivo também é root ao executar um binário setuid, o acesso será permitido.

    Nesse caso, você acaba se deparando com um problema diferente, que tem a ver com unsharea lógica de não ser capaz de lidar com essa configuração específica (provavelmente algo a ver com o uid efetivo e o uid real não correspondendo):

    $ cp /usr/bin/unshare .
    $ sudo setcap -r unshare
    $ sudo chown root:root unshare
    $ sudo chmod 4711 unshare
    $ ./unshare -r
    -bash: cannot set uid to 65534: effective uid 0: Invalid argument
    -bash-4.4$ 
    

    Observe também que a limpeza do sinalizador "dumpable" foi acionada pela execução de um binário com recursos de arquivo definidos. Se você obtiver recursos adicionais de uma maneira diferente, talvez não tenha esse problema. Por exemplo, usar recursos "ambientais" é uma boa maneira de obter recursos adicionais fora do namespace, sem ter problemas ao descompartilhar em um novo namespace de usuário.

    (Infelizmente, ainda não há muitas ferramentas em torno dos recursos do ambiente. libcapapenas o suporte é fornecido no git mais recente, a versão 2.25 anterior, que é a atualmente fornecida na maioria das distros. capshé de nível bastante baixo, então não é tão fácil obtê-lo Veja aqui os detalhes sobre como usar o mais recente capshpara adicionar recursos de ambiente. Também tentei systemd-run, mas não consegui configurar os recursos de ambiente lá. De qualquer forma, algo para você analisar, se precisar de recursos, não usuário root e namespaces de usuário juntos!)

    • 13

relate perguntas

  • Por que não posso ligar "/" dentro de um namespace de usuário?

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

  • Como executar chroot com namespaces do Linux?

  • Configuração de DNS separada em cada namespace de rede

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