Git server's host key not cached in registry - GitHub.com
Solution 1
The ideal solution would be (if you really don't need to use plink in git) removing the GIT_SSH environment variable and generating a new keypair with command ssh-keygen -t rsa -C "youremail"
on Git Bash then change your ssh key in github because from what I've understood from the comments is putty and openssh is conflicting.
However, if you still want to use plink you can use PuTTYgen to generate a PuTTY format key then change your public key in github and load your private key in PuTTYagent then you should do a connect to github.com with PuTTY this would add githubs fingerprint to known_hosts and you are good to go. This would be a resource to github with PuTTY http://nathanj.github.com/gitguide/tour.html
Solution 2
Using git-for-windows with GIT_SSH pointing to plink.exe, opening a putty to the server and accepting the host key (and then killing the putty session, not even proceeding with logging in) was enough to solve this issue for me.
Solution 3
On Windows, it seems that sometimes you don't get to actually accept a server's host key.
Try one of the following commands from the Power Shell:
ssh github.com
Or
plink.exe -agent github.com
Run these standalone and press y
when asked to accept the host key.
Use ssh-add
to add your private key to the current Power Shell session:
C:> ssh-add PATH\TO\PRIVATE\KEY
Afterwards, you should be able to successfully run git push
.
Source: http://help.github.com/ssh-issues/
Solution 4
Adding info to the post of @Name (for the sake of completeness), as I just had (again) this issue today.
Putty stores its SSH known hosts in a registry key, not in the ~/.ssh/known_hosts file like SSH. So to make Git work with PLink and Pagent, you just have to start a Putty session on the remote Git server, and accept the key. This way, you won't have the message again.
This is disturbing, as you have to accept the SSH key twice : one for SSH-ing the server, one for Putty/Plink/Pagent, but once you do it, it works like a charm.
kentcdodds
I am Kent C. Dodds. I work at PayPal as a full stack JavaScript engineer. I host JavaScript Air, the live video broadcast podcast about JavaScript and the web platform. I spend a bit of time on GitHub and Twitter. I'm an Egghead.io instructor. I'm happily married and the father of three kids. I like code. I care about craft, design, and architecture. I like to talk about it. Come chat with me :-)
Updated on July 09, 2022Comments
-
kentcdodds almost 2 years
Continuation of issue here: I'm trying to set up my first Git Repository on GitHub. (Note, this means I can't use putty, I'm using openssh, or at least I'm supposed to and I think I am). I've been following the documentation on GitHub's website here. I get everything right up until the very last command:
git push -u origin master
. It gives me the following error:The server's host key is not cached in the registry. You have no guarantee that the server is the computer you think it is. The server's rsa2 key fingerprint is: ssh-rsa 2048 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48 Connection abandoned. fatal: The remote end hung up unexpectedly
I'm guessing this means that in my
known_hosts
file their ssh-rsa key isn't found, but I'm not sure how to fix that. I've triedssh -T [email protected]
and I log on just fine. I've also tried closing the git bash and re-opening in case it's a cache issue. This doesn't fix the problem. This is the only output I get that differs from what the documentation indicates. I'm hoping to put up a sweet Java Helper Library, so any help would be greatly appreciated! -
kentcdodds about 12 years
ssh github.com
gives me aPermission denied (publickey)
and theplink.exe -agent github.com
asks me whether I want to store the key in the chache. I say yes, then it sayslogin as:
and I tried my github username and also nothing and both gives me aNo supported authentication methods available
error. Note, in this session I've successfully authenticated withssh -T [email protected]
. I'm at a total loss... -
kentcdodds about 12 yearsHaha, sorry about that, I should have explained what happens when I try to push. Now, when I try
git push -u origin master
I getFATAL ERROR: Disconnected: No support authentication methods available (server sent: publickey)
and disconnects. -
kentcdodds about 12 yearsThanks for the edit. Unfortunately, when I try to add the private key generated from Git Bash, pageant gives me
Can't load this key (OpenSSH SSH-2 private key)
. Just for kicks, I tried the public key file and it saysCouldn't load this key (not a private key)
. When I try to add a key, the file it's looking for is aPuTTY private key file (*.ppk)
. My private key generated by the Git Bash doesn't have a file extension and the public key has a pub extension... Also, I'm pretty sure my private key is supposed to be OpenSSH not PuTTY (per the github.com documentation). -
kentcdodds about 12 yearsI removed the environment variable (because if GitHub is telling the truth I can only use OpenSSH) and tried creating a new keypair. I successfully added it to my account on GitHub and authenticated with
ssh -T [email protected]
but when I tried callinggit push -u origin master
it gave me theNo supported authentication methods available
error again. I'm guessing this is because I don't have an alternative to plink.exe in my environment variables, but... yeah, how do I give a supported authentication method using OpenSSH? -
Learath2 about 12 yearsI don't have a GIT_SSH variable aswell mine works just fine its not the case can you try running that command in verbose mode
git push -vu origin master
that would output some debug info about what really failed. -
kentcdodds about 12 yearsThe only change was before it outputted the error it outputted:
Pushing to [email protected]:kentcdodds/Java-Helper.git
-
Learath2 about 12 yearsIf ssh [email protected] works and push doesnt there is only one explaination git is somehow still using plink.exe either reinstall msysgit with openssh selected or do
cd ~
thenecho "GIT_SSH="/usr/bin/ssh.exe"" > .profile
and restart the git bash -
kentcdodds about 12 yearsHa! It worked! I have no idea how, but it worked! Haha, thanks a ton. Hopefully I can get this setup with Netbeans now so I don't have to worry about the Bash as much... We'll see. Thanks!
-
Learath2 about 12 yearsNo problem if you need help on that just ask ^^
-
kentcdodds about 12 yearsAsking... ;) stackoverflow.com/questions/10195384/…
-
Learath2 about 12 years
-
Sumit Ramteke almost 10 yearsAs per your suggestion, I have removed
GIT_SSH
from the env var. and find that there was another key pointingplink
with nameSVN_SSH
which was finding ambiguity in accessingplink
. So thanks your little bit part of solution works for me. I am using assembla git repo in my project.