37

Я устранял неполадки, связанные с PubkeyAuthentication . Когда я использую подробный режим, я вижу много «key_load_public: нет такого файла или каталога» .

Очевидно, что ключи выходят в файловой системе, поэтому сообщение не имеет обычного значения:

$ ls -al ~/.ssh/id_*
-rw-------  1 jwalton  staff   751 Feb  4  2013 id_dsa
-rw-------  1 jwalton  staff   608 Feb 18  2015 id_dsa.pub
-rw-------  1 jwalton  staff   314 Feb  4  2013 id_ecdsa
-rw-------  1 jwalton  staff   180 Feb 18  2015 id_ecdsa.pub
-rw-------  1 jwalton  staff   464 Aug 23 18:15 id_ed25519
-rw-------  1 jwalton  staff   103 Aug 23 18:15 id_ed25519.pub
-rw-------  1 jwalton  staff  2546 Feb  4  2013 id_rsa
-rw-------  1 jwalton  staff   572 Feb 18  2015 id_rsa.pub

Что именно означает «key_load_public: нет такого файла или каталога» ?


Мой файл .ssh/config имеет:

$ cat ~/.ssh/config
IdentityFile ~/.ssh/id_ed25519
IdentityFile ~/.ssh/id_ecdsa
IdentityFile ~/.ssh/id_dsa
IdentityFile ~/.ssh/id_rsa

Добавление расширения *.pub не имеет никакого эффекта. Я пробовал как с *.pub так и без него, потому что страница руководства неоднозначна в отношении того, какой ключ должен быть указан - открытый или закрытый. (Открытый ключ - это все, что нужно для идентификации; закрытый ключ необходим для подтверждения владения ключом в ответе на вызов / ответ):

IdentityFile
    Specifies a file from which the user's DSA, ECDSA or DSA authen-
    tication identity is read...

$ ssh -v -p 1522 jwalton@192.168.1.11
OpenSSH_7.1p1, OpenSSL 1.0.2d 9 Jul 2015
debug1: Reading configuration data /Users/jwalton/.ssh/config
debug1: Reading configuration data /usr/local/etc/ssh_config
debug1: Connecting to 192.168.1.11 [192.168.1.11] port 1522.
debug1: Connection established.
debug1: identity file /Users/jwalton/.ssh/id_ed25519.pub type 4
debug1: key_load_public: No such file or directory
debug1: identity file /Users/jwalton/.ssh/id_ed25519.pub-cert type -1
debug1: identity file /Users/jwalton/.ssh/id_ecdsa.pub type 3
debug1: key_load_public: No such file or directory
debug1: identity file /Users/jwalton/.ssh/id_ecdsa.pub-cert type -1
debug1: identity file /Users/jwalton/.ssh/id_dsa.pub type 2
debug1: key_load_public: No such file or directory
debug1: identity file /Users/jwalton/.ssh/id_dsa.pub-cert type -1
debug1: identity file /Users/jwalton/.ssh/id_rsa.pub type 1
debug1: key_load_public: No such file or directory
debug1: identity file /Users/jwalton/.ssh/id_rsa.pub-cert type -1
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_7.1
...

1 ответ1

58

В буквальном смысле это означает, что в нем нет такого файла или каталога, к которым ssh хотел бы получить доступ.

Тем не менее, речь идет о файле, упомянутом ниже, а не выше. У вас есть только обычные открытые ключи, но у вас нет для них сертификатов SSH (предположительно потому, что они вам просто не нужны). Однако OpenSSH всегда будет пытаться загрузить связанный .pub-cert для каждого ключа идентификации.


В руководстве ssh-keygen(1) рассказывается о создании центра сертификации OpenSSH и подписи сертификатов, если вам это интересно. (Примечание: здесь не используется X.509, только собственный формат сертификата OpenSSH.)

Обычно сертификаты полезны, только если у вас огромное количество пользователей (и / или серверов), но вы не хотите использовать Kerberos.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .