Назад | Перейти на главную страницу

Почему git не использует идентификатор, установленный в файле конфигурации ssh?

Я пытаюсь подключиться к своему местному Гитеа сервер. Я настроил его на использование встроенного SSH-сервера на порту 2222. Я работаю в Windows. Гитеа работает нормально.

Теперь я хочу подключиться, используя Мерзавец Cygwin. Для тестирования подключения к моему репозиторию я использую ls-remote команда, которая отлично работает, если я использую GIT_SSH_COMMAND такой вариант:

GIT_SSH_COMMAND="ssh -i ~/.ssh/id_rsa" git ls-remote --exit-code -h ssh://username@localhost:2222/username/Repo.git

Далее я хочу упростить жизнь, используя ~/.ssh/config:

host gitea
 HostName localhost
 Port 2222
 IdentityFile ~/.ssh/id_rsa
 User username

Однако это не срабатывает с ошибкой Unable to open connection:

git ls-remote --exit-code -h ssh://gitea/username/Repo.git

Проблема: IdentityFile не применяется. Это работает:

GIT_SSH_COMMAND="ssh -i ~/.ssh/id_rsa" git ls-remote --exit-code -h ssh://gitea/username/Repo.git

Я уверен, что мой ~/.ssh/config правильно, потому что подключение напрямую ssh -vv gitea работает. Вывод (выдержка):

[...]
debug1: Connecting to localhost [::1] port 2222.
debug1: Connection established.
[...]
debug1: Offering public key: RSA SHA256:XXX /home/username/.ssh/id_rsa
debug2: we sent a publickey packet, wait for reply
debug1: Server accepts key: pkalg ssh-rsa blen 535
debug2: input_userauth_pk_ok: fp SHA256:XXX
debug1: Authentication succeeded (publickey).
Authenticated to localhost ([::1]:2222).
[...]

Так почему git не используя IdentityFile из ~/.ssh/config?

Оказалось, что установка GIT_SSH_COMMAND="ssh" было достаточно. Это означает, что git использовал другой SSH-клиент. Вероятно, тот из OpenSSH, который оказался на системном пути:

$ whereis ssh
ssh: /usr/bin/ssh.exe /cygdrive/c/WINDOWS/System32/OpenSSH/ssh.exe /usr/share/man/man1/ssh.1.gz

Я исправил проблему, добавив export GIT_SSH_COMMAND="/usr/bin/ssh" к ~/.bash_profile