Git server's host key not cached in registry - GitHub.com

24,668

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.

Share:
24,668
kentcdodds
Author by

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, 2022

Comments

  • kentcdodds
    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 tried ssh -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
    kentcdodds about 12 years
    ssh github.com gives me a Permission denied (publickey) and the plink.exe -agent github.com asks me whether I want to store the key in the chache. I say yes, then it says login as: and I tried my github username and also nothing and both gives me a No supported authentication methods available error. Note, in this session I've successfully authenticated with ssh -T [email protected]. I'm at a total loss...
  • kentcdodds
    kentcdodds about 12 years
    Haha, sorry about that, I should have explained what happens when I try to push. Now, when I try git push -u origin master I get FATAL ERROR: Disconnected: No support authentication methods available (server sent: publickey) and disconnects.
  • kentcdodds
    kentcdodds about 12 years
    Thanks 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 says Couldn't load this key (not a private key). When I try to add a key, the file it's looking for is a PuTTY 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
    kentcdodds about 12 years
    I 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 calling git push -u origin master it gave me the No 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
    Learath2 about 12 years
    I 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
    kentcdodds about 12 years
    The only change was before it outputted the error it outputted: Pushing to [email protected]:kentcdodds/Java-Helper.git
  • Learath2
    Learath2 about 12 years
    If 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 ~ then echo "GIT_SSH="/usr/bin/ssh.exe"" > .profile and restart the git bash
  • kentcdodds
    kentcdodds about 12 years
    Ha! 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
    Learath2 about 12 years
    No problem if you need help on that just ask ^^
  • kentcdodds
    kentcdodds about 12 years
  • Learath2
    Learath2 about 12 years
  • Sumit Ramteke
    Sumit Ramteke almost 10 years
    As per your suggestion, I have removed GIT_SSH from the env var. and find that there was another key pointing plink with name SVN_SSH which was finding ambiguity in accessing plink. So thanks your little bit part of solution works for me. I am using assembla git repo in my project.