Все, что вам нужно сделать, это сгенерировать пару секретных / открытых ключей на вашем ПК, скопировать открытый ключ на сервер и затем подключиться. Это можно сделать, запустив ssh-keygen -t rsa
на вашем локальном компьютере. Вывод будет похож на ниже:
td512@kettecomp2:~$ ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/home/td512/.ssh/id_rsa):
Created directory '/home/td512/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /home/td512/.ssh/id_rsa.
Your public key has been saved in /home/td512/.ssh/id_rsa.pub.
The key fingerprint is:
f9:cd:fe:c1:77:90:40:34:9c:34:cb:f6:2c:cc:32:6a td512@kettecomp2
The key's randomart image is:
+--[ RSA 2048]----+
| +*. |
| oo+ |
| = |
| . + + . |
| S o + = |
| o = o . |
| E . o o o|
| . . o.|
| ... |
+-----------------+
td512@kettecomp2:~$
После этого вам необходимо скопировать открытый ключ на сервер. Мой любимый способ - открыть открытый ключ ssh в textedit и скопировать его. Ключ можно найти в ~/.ssh/id_rsa.pub
где ~
обозначает ваш домашний каталог.
После копирования в буфер обмена, выполните команду ssh на сервере и выполните эту команду (будьте осторожны, не копируйте и не вставляйте, так как у вас уже есть открытый ключ в буфере обмена):
cd && mkdir .ssh && chmod 700 .ssh && touch .ssh/authorized_keys && chmod 600 .ssh/authorized_keys && nano .ssh/autorized_keys
Приведенный выше код создаст требуемый каталог и файл, а затем предоставит им необходимые разрешения. после чего вы должны открыть nano
. Вставьте свой открытый ключ, нажмите Ctrl + X, ответьте «да» на запросы и выйдите из ssh.
Следующая часть заключается в реализации вашего кода. Это можно сделать так:
diff foo <(ssh myServer -l user -i .ssh/id_rsa 'cat foo')
где user
- это ваше имя пользователя для сервера, а .ssh/id_rsa
- ваш закрытый ключ. Это должно остановить запросы пароля.