(git bash) push to bitbucket ignores SSH key

11,729

Solution 1

Judging by the error PuTTY Fatal Error, it looks like Git is trying to use PuTTY to authenticate with ssh. The thing is PuTTY is not aware of your setting in ~/.ssh, at all. The setting in ~/.ssh is only meaningful when using openssh, shipped with Git Bash. It looks as if you have set the GIT_SSH environment variable to plink.exe, which is a tool that's part PuTTY.

You have two choices: you can either use PuTTY and plink.exe for ssh operations, or you can use the openssh that is part of Git Bash.

If you use PuTTY, then you need to manage your ssh keys with pageant.exe, which is also part of PuTTY. It's a pretty nice tool. Run it, and in the task tray you should see an icon. Right-click on that icon to add your private key. The other step to use PuTTY is setting GIT_SSH but it looks like you've already done that. In this setup git push will use plink.exe, which being part of PuTTY, will correctly find the private keys stored by pageant.ext.

If you want to use the openssh that is part of Git Bash, then all you need to do is get rid of the GIT_SSH setting. One way to make sure the setting is really empty when using git push is if you run the command like this:

GIT_SSH= git push origin master

Solution 2

After all the other answers didnt do it for one of my collegues, I figured the following:

Since pushing to remotes like beanstalk works (https) and even ssh works using the git bash console, I figured it must have something to do with how SSH would be invoked, our remote was something like this:

user@server:/path/to/repo.git

So a simple which ssh gave us /bin/ssh

In the .bashrc profile we just added

export GIT_SSH=/bin/ssh.exe

and voila.

An easier solution would be to buy a mac! :)

Happy gitting

Solution 3

You are trying to connect to Bitbucket via SSH rather than through Git which is what the first error is telling you. That you are not allowed to connect to Bitbucket in that manner.

When you set up your repo, if you are off of a existing one in Bitbucket all you would have needed to do is:

git clone [email protected]:<UserName>/<Name of the Repo>.git

You would get a message about accepting a key and you would have been all set.

Now if you have an already existing repo, you can add the remote yourself but you would add that to .git/config

You would add [email protected]:<UserName>/<Name of the Repo>.git to the section [remote "origin"].

Solution 4

Try using cmd.exe. Git Bash seems to have issues with environment variables on my machine.

In CMD, echo %GIT_SSH% to see if it is set (PuTTY/Plink does that). If it is set, and you want to use openssh, clear it with set GIT_SSH=.

After doing that, I could push and pull using ssh in CMD with no issue, although Git Bash still does not work.

Share:
11,729
Benny Bottema
Author by

Benny Bottema

Updated on June 05, 2022

Comments

  • Benny Bottema
    Benny Bottema almost 2 years

    I followed a bunch of blog trails around the web to find out how everything should be set up and I have the following situation:

    First of all, ssh -T [email protected] returns the following result

    conq: logged in as myuser.
    You can use git or hg to connect to Bitbucket. Shell access is disabled.

    That means I have the ssh key setup properly both local and in bitbucket, agreed?

    I have a ~/.ssh/config with the following content:

    Host bitbucket.org
     IdentityFile ~/.ssh/id_rsa
    

    That key is there ofcourse.

    However, when I try the command (taken from another tutorial) git push origin master, I will get a popup saying:

    ---------------------------
    PuTTY Fatal Error
    ---------------------------
    Disconnected: No supported authentication methods available (server sent: publickey)
    ---------------------------
    OK