Árvore de páginas

Neste documento, você verá como configurar uma conexão SSH utilizando uma chave pública. Este processo facilita a automação de scripts, pois após esta configuração não será solicitada a senha ao tentar acessar um servidor remoto. Mas atenção: cuidado para não expor a chave privada.

Informações adicionais

Os links a seguir são referenciados ao longo desta página, e podem ser de interesse:

Cartilha de Segurança para Internet

Confira, no Medium, o artigo original escrito por um dos integrantes da área clicando aqui

Para quem está iniciando e quer saber um pouco mais sobre criptografia, faça a leitura da cartilha de segurança para internet. Esta cartilha ajudará nos seus primeiros passos.

Antes de iniciar o procedimento, verifique se possui as ferramentas ssh, ssh-keygen e ssh-copy-id instaladas nos servidores. Caso não possua, realize a instalação com o comando a seguir:

Red Hat, Oracle Linux e CentOS
# yum install ssh ssh-keygen ssh-copy-id
Debian, Ubuntu
# apt-get install ssh ssh-keygen ssh-copy-id

Procedimento

Ilustração de como ficará a conexão após a troca de chave pública

Ilustração de como ficará a conexão após a troca de chave pública

Gerando a chave pública (SEM SENHA)

Na máquina onde será executado o comando remoto (ou os scripts), utilize o usuário que terá acesso na máquina remota. Apenas este usuário poderá acessar a máquina com a chave gerada.

Para gerar a chave, execute o comando abaixo:

ssh-keygen -t dsa -f ~/.ssh/id_dsa

Após digitar o comando acima, pressione ENTER para as próximas fases, assim o ssh-keygen irá gerar uma chave pública e privada sem senha.

RETORNO ESPERADO

Generating public/private dsa key pair.
Enter passphrase (empty for no passphrase): [Apenas pressione ENTER]
Enter same passphrase again: [Apenas pressione ENTER]
Your identification has been saved in /home/user/.ssh/id_dsa.
Your public key has been saved in /home/user/.ssh/id_dsa.pub.
The key fingerprint is:
f6:63:ra:34:b5:60:22:01:3v:31:3a:59:ca:1d:6c:7b [MD5] user@vm67183
The key’s randomart image is:
+ — [ DSA 1024] — — +
|o+=. |
|o*o+. |
|=.+.o o . |
| . o E o = |
| . o S . |
| . = |
| . |
| |
| |
+ — [MD5] — — — — — +


retorno do comando — ssh-keygen -t dsa -f ~/.ssh/id_dsa

Compartilhando a chave pública

Utilize o comando abaixo para copiar a chave pública do servidor local para os outros servidores.

Cópia da chave pública do servidor
$ ssh-copy-id [usuario]@[maquina_remota]

Este comando deve ser repetido para todos os servidores que desejar acessar.

retorno do comando — ssh-copy-id usuario@maquina_remota

Teste de conexão

Realize o teste conectando na máquina remota:

Conectando-se à máquina remota
$ ssh [usuario]@[maquina_remota]

retorno do comando — ssh usuario@maquina_remota

Lembre-se: o acesso está autorizado apenas para o usuário que gerou a chave, ou seja, se for gerada a chave com o usuário root, apenas quando estiver logado com o usuário root poderá acessar a máquina remota (sem solicitar senha). O mesmo ocorre se for gerada a chave com outro usuário.
  • Sem rótulos