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 / 466770
Accepted
lonix
lonix
Asked: 2018-09-05 04:15:43 +0800 CST2018-09-05 04:15:43 +0800 CST 2018-09-05 04:15:43 +0800 CST

Devo excluir as senhas dos usuários depois de configurar a autenticação de chave pública para SSH?

  • 772

É melhor usar chaves públicas para SSH. Então o meu sshd_configtem PasswordAuthentication no.

Alguns usuários nunca fazem login, por exemplo, um usuário sftp com shell /usr/sbin/nologin. Ou uma conta do sistema.

Para que eu possa criar esse usuário sem uma senha com adduser gary --shell /usr/sbin/nologin --disabled-password.

Isso é uma boa/má ideia? Existem ramificações que não considerei?

ubuntu ssh
  • 2 2 respostas
  • 5654 Views

2 respostas

  • Voted
  1. Best Answer
    Daniele Santi
    2018-09-05T04:23:38+08:002018-09-05T04:23:38+08:00

    Se você tiver acesso root ao servidor e puder gerar novamente chaves ssh para seus usuários caso eles as percam

    E

    você tem certeza de que um usuário (como pessoa) não terá várias contas de usuário e precisará alternar entre aquelas em uma sessão SSH (bem, eles também podem abrir várias sessões SSH, se necessário)

    E

    eles nunca precisarão de acesso "físico" (via teclado + monitor ou console remoto para uma VM) ao servidor

    E

    nenhum usuário tem acesso por senha sudo(ou seja, eles não têm acesso sudo ou têm acesso sudo com NOPASSWD)

    Acho que você vai ficar bem.

    Temos muitos servidores em funcionamento configurados assim (apenas algumas contas precisam de acesso à VM via console remoto vmware, as outras se conectam apenas via SSH com autenticação pubkey).

    • 35
  2. telcoM
    2018-09-05T04:48:07+08:002018-09-05T04:48:07+08:00

    Esta questão originalmente mencionou o passwd --delete <username> que não é seguro : com isso, o campo de senha criptografada /etc/shadowestará completamente vazio.

    username::...
    

    Se você configurou seu sshdpara recusar a autenticação de senha, então isso é seguro com SSH ... Você não quer isso.


    adduser --disabled-passwdirá produzir uma /etc/shadowentrada onde o campo de senha criptografada é apenas um asterisco, ou seja

    username:*:...
    

    Esta é "uma senha criptografada que nunca pode ser inserida com sucesso", ou seja, isso significa que a conta é válida e tecnicamente permite logins, mas impossibilita a autenticação por senha de sucesso . Portanto, se você tiver outros serviços baseados em autenticação de senha em seu servidor, esse usuário será bloqueado para eles.

    Apenas métodos de autenticação que usam algo diferente da senha de conta padrão (por exemplo, as chaves SSH) funcionarão para este usuário, para qualquer serviço que use os arquivos de senha do sistema neste sistema. Quando você precisa de um usuário que possa fazer login apenas com chaves SSH, é isso que você deseja.

    Se você precisar definir uma conta existente para esse estado, poderá usar este comando:

    echo 'username:*' | chpasswd -e
    

    Há um terceiro valor especial para o campo de senha criptografada: adduser --disabled-login, então o campo conterá apenas um único ponto de exclamação.

    username:!:...
    

    Assim como o asterisco, isso impossibilita o sucesso da autenticação por senha, mas também tem um significado adicional: marca a senha como "bloqueada" para algumas ferramentas de administração. passwd -ltem o mesmo efeito ao prefixar o hash de senha existente com um ponto de exclamação, o que novamente torna a autenticação de senha impossível de usar.

    Mas aqui está uma armadilha para os incautos: no ano de 2008, a versão de passwdcomando que vem do shadowpacote antigo foi alterada para redefinir passwd -lde "bloquear a conta" para apenas "bloquear a senha". O motivo declarado é "para compatibilidade com outra versão passwd".

    Se você (como eu) aprendeu isso há muito tempo, pode ser uma surpresa desagradável. Também não ajuda questões que adduser(8)aparentemente ainda não estão cientes dessa distinção.

    A parte que desabilita a conta para todos os métodos de autenticação é, na verdade, definir um valor de data de expiração de 1 para a conta: usermod --expiredate 1 <username>. Antes do ano de 2008, passwd -lisso se originava do shadowkit de origem usado para fazer isso , além de prefixar a senha com um ponto de exclamação - mas não faz mais isso.

    O changelog do pacote Debian diz:

    • debian/patches/494_passwd_lock-no_account_lock: Restaura o comportamento anterior de passwd -l (que mudou em #389183): bloqueia apenas a senha do usuário, não a conta do usuário. Também documente explicitamente as diferenças. Isso restaura um comportamento comum com as versões anteriores do passwd e com outras implementações. Fecha: #492307

    Os históricos de bugs do bug 492307 e bug 389183 do Debian podem ser úteis para entender o pensamento por trás disso.

    • 31

relate perguntas

  • 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

  • Instale várias distribuições Linux em paralelo

  • O OpenVPN auto-compilado não inicia a partir do systemd

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