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 / 777718
Accepted
QF0
QF0
Asked: 2024-06-04 20:08:03 +0800 CST2024-06-04 20:08:03 +0800 CST 2024-06-04 20:08:03 +0800 CST

sshd: combinando AllowUsers e DenyUsers

  • 772

Eu tenho uma sshdconfiguração parecida com esta:

DenyUsers  *
AllowUsers root@*
AllowUsers user1@*
AllowUsers user2@*

Os documentos sshd afirmam que "As diretivas de permissão/negação de usuários são processadas na seguinte ordem: DenyUsers, AllowUsers", e a intenção aqui é que ninguém tenha permissão para usar sshalém dos três usuários listados.

No entanto, isso não funciona: se algum desses usuários tentar se conectar ssh, os logs ( systemctl status ssh) informam que "Usuário foo do abcd não permitido porque listado em DenyUsers".

Então parece que DenyUserssempre tem prioridade (estou no OpenSSH_8.9p1, no Ubuntu 22.04).

Existe alguma maneira de contornar isso? Eu preciso de alguma forma DenyUsersporque a configuração deste sistema é automatizada e todos os três usuários podem ter acesso negado comentando seus dados individuais AllowUsers, o que daria:

# AllowUsers root@*
# AllowUsers user1@*
# AllowUsers user2@*

O problema agora é que todos têm acesso, e não ninguém.

ssh
  • 1 1 respostas
  • 69 Views

1 respostas

  • Voted
  1. Best Answer
    Sotto Voce
    2024-06-04T20:42:35+08:002024-06-04T20:42:35+08:00

    Veja esta resposta para obter uma descrição da maneira inesperada como as quatro diretivas de permissão/negação funcionam. As quatro diretivas são AllowUsers, AllowGroups, DenyUsers, e DenyGroups. A parte da resposta que descreve isso está perto do fim porque a pergunta tratava de um tópico um pouco diferente (como funcionam as diretivas dentro Matchdos blocos).


    A maneira de obter o comportamento de negação desejado é especificar quem deve ter acesso ao servidor nas diretivas AllowUsersou .AllowGroups

    Quando usei isso, segui a convenção comum do Linux de que cada conta de usuário no servidor local é criada com um grupo primário com o mesmo nome do usuário. Ou seja, a conta de John Doe seria nomeada johndoee um grupo nomeado johndoeseria criado. Pessoas que deveriam ter acesso devido à sua função (como administradores de sistema Linux) teriam suas contas adicionadas a grupos funcionais secundários, como sysadmins. Com esta configuração a linha:

    AllowGroups sysadmins
    

    me permitiria (sottovoce) fazer ssh no servidor porque estou no grupo sysadmin. Se eu quiser que alguém tenha acesso sem estar em um grupo, essa conta seria nomeada na mesma linha:

    AllowGroups sysadmins johndoe
    

    Agora, junto com os administradores de sistemas, John Doe também é permitido porque é membro do johndoegrupo. Todos os outros são negados.

    Não usei AllowUsersporque isso bloquearia o pessoal do administrador de sistemas. Adicionar e remover o acesso de administrador de sistema exigiria a alteração do sshd_configarquivo, o que é mais intrusivo e sensível do que editar o /etc/grouparquivo. Gerenciar o acesso por meio de associação ao grupo é melhor.

    • 3

relate perguntas

  • Por que o utilitário ssh é considerado um pty?

  • Auto-SSH funciona manualmente, mas não em segundo plano

  • Execute o aplicativo X remotamente, execute a GUI no host remoto [fechado]

  • rsync porta 22 e 873 uso

  • Aborto repentino do SCP: tubo quebrado, código de autenticação de mensagem incorreto

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