176

Git push hangs everytime I try to push to github. I am using Cygwin and Windows 7. Git functions fine locally tracking branches, providing status, setting global user.name and user.email and allowing commits.

I'm still new and learning.

I enter git push , git push origin master or git push -u origin master and I get nothing but a blank line requiring me to ctl-c to get the prompt back.

ssh-keygen -t rsa -C "me@example.com" asks me for a file name and hangs

git push heroku master hangs

$ git status returns On branch master nothing to commit, working directory clean

$ git pull returns Already up to date

$ git remote -v returns:

heroku  git@heroku.com:myherokusite.git (fetch)

heroku  git@heroku.com:myherokusite.git (push) origin  

https://github.com/gitusername/appname.git (fetch) origin  

https://github.com/gitusername/appname.git (push)

or the correct ssh remote settings are returned when trying this with ssh

Updated: Using the SSH url git@github.com:gitusername/gitrepo.git also hangs

git remote set-url origin https://github.com/gitusername/appname.git is correct

Updated: I can see the git processes running in Windows Task Manager while it hangs.

I've tried:

Using different internet connection locations

switching between https and ssh and it hangs

Uninstalled git. Reinstalled from: https://code.google.com/p/msysgit/downloads/list

Uninstalled git. Installed Cygwin's git

Uninstalled git. Installed Github for Windows GUI app and it I WAS able to push. But this app has limited functionality, forces me out of my Cygwin window into another app which then forces me into a Windows command prompt for complete functionality which I thought I had escaped by using Cygwin.

Spent many, many hours trying to resolve this, it worked faultlessly before, thanks.

UPDATE 4/2014: I rebuilt my entire machine Win 7, Cygwin etc and all is now working fine

Matt Singer
  • 1,917
  • 2
  • 14
  • 12
  • 4
    Are you behind a firewall or a proxy ? – Guillaume Darmont Jun 03 '13 at 21:41
  • I tried different internet connections without success, yes I have anti-virus which had never caused a problem previously. No proxy. – Matt Singer Jun 04 '13 at 00:38
  • 6
    Any luck? I am encountering the same issue with cygwin. A fix: if I use the native windows shell (cmd.exe) however, `git push origin master` works fine. – skilbjo Aug 12 '13 at 00:12
  • 6
    For me restarting computer helped. – ktamas Sep 20 '19 at 09:12
  • When this happens for me, I've found deleting `~/.ssh/git@github.com:22.connection` fixes the issue (I have some settings in ~/.ssh/config to persist connections). – erwaman Dec 09 '20 at 16:59
  • 3
    I had to logout from VPN. – 42n4 Apr 28 '21 at 06:13
  • Another reason might be that the git server has reached its resource limits, and there's nothing wrong with your local git setup. – PetMarion Jun 22 '20 at 08:12
  • For the sake of completeness (sometimes problems like this are not as complicated as they might seem): Having a non-existing remote repository configured can also result in this behavior - I recently found out by accidentally changing my origin's URL to `githu.com`. – Michael Trojanek Jan 30 '17 at 22:48
  • Funny, cos I had this issue and had to **log into VPN** to solve it... weird. – trojanfoe Oct 29 '22 at 15:30
  • I've encountered this issue when doing some local website development. I was running a local server to test the content, and `git push` hung until I remembered to stop the local server process. All other git commands worked without issue throughout development. – jdobres Dec 25 '22 at 19:21

37 Answers37

173

Restart your ssh agent!

killall ssh-agent; eval `ssh-agent`
jburtondev
  • 2,827
  • 1
  • 14
  • 20
91
git config --global core.askpass "git-gui--askpass"

This worked for me. It may take 3-5 secs for the prompt to appear just enter your login credentials and you are good to go.

markphd
  • 1,394
  • 1
  • 12
  • 17
  • 1
    I ran this and now it keeps saying `error: cannot run git-gui--askpass: No such file or directory`, could you advise me on how to reverse this please? – hello_there_andy May 18 '15 at 20:21
  • 2
    @hello_there_andy [this](http://stackoverflow.com/questions/30294980/git-gui-askpass-no-such-file-or-directory) may help you. – markphd May 21 '15 at 02:54
  • 30
    This line did nothing for me. Empty output. – AlwaysLearning Nov 12 '18 at 14:48
  • 2
    After running this line, the problem is not solved and now when pushing, git keeps saying `error: cannot run git-gui--askpass: No such file or directory`. The solution added by @forloop helped me to reverse it. – Sebasthian Ogalde Apr 03 '19 at 23:32
  • 2
    Worked perfectly fine for me. I didn't even have to enter any credentials. – Flip Nov 11 '21 at 12:36
  • If using git on command line only, such as via remote SSH, I expect this solution is not applicable. – pd_au Mar 13 '23 at 03:29
49

Try creating a script like ~/sshv.sh that will show you what ssh is up to:

#!/bin/bash
ssh -vvv "$@"

Allow execution of the ~/sshv.sh file for the owner of the file:

chmod u+x ~/sshv.sh

Then invoke your git push with:

GIT_SSH=~/sshv.sh git push ...

In my case, this helped me figure out that I was using ssh shared connections that needed to be closed, so I killed those ssh processes and it started working.

mik13ST
  • 95
  • 7
Matt Montag
  • 7,105
  • 8
  • 41
  • 47
  • 9
    For debug, it's simpler to add `LogLevel DEBUG3` in `~/.ssh/config` – Jérémie Lesage Feb 11 '19 at 17:46
  • 1
    I tried `git push -u origin master --verbose` but even that didn't show anything useful. After reading this solution I copied the whole `~/.ssh` from my older Linux pc to my Windows Cygwin64 home/user folder, worked like a charm. – Matteljay Oct 19 '19 at 12:52
  • Thank you. In my case it was enough to restart sshd: `sudo systemctl restart sshd` – Albert Mosiałek Mar 21 '20 at 17:28
  • After Adding logLevel Debug3, is ssh reload needed? I do not think so due to client side. – Timo Nov 03 '20 at 17:46
  • `GIT_SSH=~/sshv.sh git push ...`: Is this a GIT var and also a cmd to run/execute? Why is the var defined and not the script run with the git push param. I tested this: ssh -vvv 'git push', but no avail. – Timo Nov 03 '20 at 18:01
  • This was a good hint: I just did `ps aux | grep ssh` then killed anything that came up. Then push worked after that! – sh37211 Sep 24 '22 at 07:55
42

Try GIT_CURL_VERBOSE=1 git push

...Your problem may occur due to proxy settings, for instance if git is trying to reach github.com via a proxy server and the proxy is not responding.

With GIT_CURL_VERBOSE=1 it will show the target IP address and some information. You can compare this IP address with the output of the command: host www.github.com. If these IPs are different then you can set https_proxy="" and try again.

Scott Anderson
  • 631
  • 5
  • 26
30

I had the same problem with absolutely same symptoms… I was about to rebuild my whole system in my despair)). I also tried git config --global core.askpass "git-gui--askpass", but it didn't work.

The solution was to restart the ssh-agent:

launchctl stop /System/Library/LaunchAgents/org.openbsd.ssh-agent 

launchctl start /System/Library/LaunchAgents/org.openbsd.ssh-agent

If needed, prefix these with sudo.

PatrickT
  • 10,037
  • 9
  • 76
  • 111
Drew
  • 594
  • 10
  • 25
  • 5
    how do you restart ssh-agent? I'm using linux – Yan King Yin Nov 16 '15 at 16:33
  • I restarted ssh-agent by terminating the `ssh-agent.exe` process. On windows, you can use `ps -ef | grep ssh` to find it, and `kill` to exterminate it. Restarting is probably safer. @YanKingYin – ashes999 Dec 30 '16 at 06:50
  • 3
    @Yan King Yin Nov, I'm not sure about linux, but on mac I've done it using LaunchControl GUI or running: `sudo launchctl stop /System/Library/LaunchAgents/org.openbsd.ssh-agent` and `sudo launchctl start /System/Library/LaunchAgents/org.openbsd.ssh-agent`... Pretty sure linux should have something similar to bsd launchd… Like init-v or systemd way of stopping/starting agents/daemons… You could try this spell: `killall ssh-agent; eval $(ssh-agent)`. Let me know if it's working for you. – Drew Dec 31 '16 at 08:15
  • thanks, just ran into this problem and it was my ssh agent hanging too! would have taken me ages to figure it out myself – Martin DeMello Jun 30 '20 at 05:12
  • This does work for me but I have to run both commands before every single push. – Ray Jennings Feb 24 '23 at 23:03
  • On my Mac I needed to use: `launchctl stop /System/Library/LaunchAgents/com.openssh.ssh-agent.plist` `launchctl start /System/Library/LaunchAgents/com.openssh.ssh-agent.plist` – Peter Svehla Apr 16 '23 at 07:35
25
  1. Had the same problem. Was a little bit confused but the thing was I had make a git init --bare on root, that means that you won't be able to push because of you don't have any rights. Instead make a new User or in my case I used Pi User and made git init --bare there, which then later on it worked.

  2. git config --global http.postBuffer 524288000

Maximum size in bytes of the buffer used by smart HTTP transports when POSTing data to the remote system. For requests larger than this buffer size, HTTP/1.1 and Transfer-Encoding: chunked is used to avoid creating a massive pack file locally. Default is 1 MiB, which is sufficient for most requests.

the_Begin
  • 391
  • 4
  • 6
  • 3
    I ended up setting the buffer for the local repo only, but it solved my issue `git config --local http.postBuffer 524288000` – user212514 Apr 16 '22 at 14:19
  • 3
    Thanks a lot! If somebody has this problem with a somewhat larger repo (like a monorepo) try this solution first. – zeekrey Oct 20 '22 at 11:10
  • 1
    This worked for my repo with larger files, I added several mp3 files between 5 and 20MB. I just updated the config for the local repo – B Rad C Nov 30 '22 at 22:42
22

Using "Command Prompt" (cmd) instead of git bash for initial push resolved the hang up for me. Since then I use git bash without any issues.

21

In my case, the issue was the https seems to be no longer supported and I had to switch all my origins from the old https://github.com/username/myrepo to git@github.com:username/myrepo.git.

I did this with

git remote set-url origin git@github.com:username/myrepo.git
bstricks
  • 823
  • 8
  • 14
12

I had the same issue. Stop worrying and searching endless complicated solutions, just remove git and reinstall it.

sudo apt-get purge git
sudo apt-get autoremove
sudo apt-get install git

Thats it. It should work now

gustavz
  • 2,964
  • 3
  • 25
  • 47
12

I was struggling with this problem on a Mac. My solution was to kill all git processes using the following command:

killall git

Hope this helps someone!

Jake Hathaway
  • 146
  • 1
  • 5
  • This does not provide an answer to the question. Once you have sufficient [reputation](https://stackoverflow.com/help/whats-reputation) you will be able to [comment on any post](https://stackoverflow.com/help/privileges/comment); instead, [provide answers that don't require clarification from the asker](https://meta.stackexchange.com/questions/214173/why-do-i-need-50-reputation-to-comment-what-can-i-do-instead). - [From Review](/review/late-answers/33478382) – コリン Dec 25 '22 at 14:45
  • 2
    This did it for me. I spent an hour trying to figure out what was wrong. I guess a stuck git process. Thanks a bunch. – Babao Jan 27 '23 at 00:24
6

Its worth checking if you are using the cygwin git or an external git (ie github).

If whereis git returns just /cygdrive/c/Program Files (x86)/Git/cmd/git.exe or similar its best to install the cygwin git package, this solved the problem for me.

Sam
  • 5,416
  • 7
  • 47
  • 49
6

For anyone experiencing this since 2021/08/13 and finding this question, it may be related to the recent auth policy changes on GitHub. They are no longer accepting username/password for authentication.

The solution is to set up ssh access or create a personal access token.

Kirk M
  • 141
  • 1
  • 5
  • According to [GitHub's suggestion](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token), I set up Git Credential Manager which resolved my issue. – Burhan Nov 04 '22 at 17:13
4

I thought my Git windows screen was struck but actually a sign in prompt comes behind it.Check for it and enter your credentials and that's it.

Thakur Karthik
  • 3,034
  • 3
  • 15
  • 24
4

I had this same issue today, all I did to resolve it was remove origin git remote remove origin and re-add it git remote add origin https://github.com/username/project.git then I was able to push successfully.

Ehi
  • 168
  • 1
  • 2
  • 12
4

This command solved it for me:

git fetch origin

Which updates your local repository with any changes from the remote repository, which can resolve conflicts that may be preventing your push from completing. After running git fetch, you can then run

 git push

to try pushing your changes to the remote repository again.

3

In my case a new public key on cPanel (my remote) was not yet authorized. My client was a new machine running Ubuntu 2020-04

git push origin

...worked, but prompted for the cPanel password.

I assume the git-gui process hung waiting for a password that I couldn't enter.

After authorizing my new key git-gui worked. It did prompt for the key store password.

BryanT
  • 412
  • 3
  • 12
2

I just wanted to say that I'm having this issue on my AWS EC2 instances. I was trying to push from my EC2 instance itself, when I have it configured to only allow traffic in from the load balancer. I changed the rule to allow HTTP in from everywhere, but it still didn't fix the problem. Then I realized it's because my security groups are configured to not allow outbound traffic from my EC2 instances over HTTPS. I didn't have allow HTTPS inbound traffic to make it work, even though it's probably a good policy for you to have HTTPS available inbound.

jdogg
  • 268
  • 2
  • 14
2

This occurred for me when my computer's disk space was full. Delete some files & empty the trash to fix.

Stephen Saucier
  • 1,925
  • 17
  • 20
2

Use Git CMD, not Cygwin Bash Terminal.

By using the Git CMD, my system was able to authenticate my information on GitHub. After that, using bash worked fine. I understand that there was some sort of authentication the program was trying to do, but couldn't do from the bash terminal for some reason. Although this answer is not comprehensive, it does get the job done.

2

Sometimes I have this hanging issue when pushing a new branch from Android Studio and it does not give an error message. Usually, if I do a simple fetch from main it will work afterwards.

Ben
  • 3,346
  • 6
  • 32
  • 51
2

Sometimes not stuck. Maybe it will be pushing. You can check progress of your push by using this command.

git push --progress

See more about how to see git push progress: How can I know how much percentage of git push is complete?

General Grievance
  • 4,555
  • 31
  • 31
  • 45
1

I'm wondering if it's the same thing I had...

  1. Go into Putty
  2. Click on "Default Settings" in the Saved Sessions. Click Load
  3. Go to Connection -> SSH -> Bugs
  4. Set "Chokes on PuTTY's SSH-2 'winadj' requests" to On (instead of Auto)
  5. Go Back to Session in the treeview (top of the list)
  6. Click on "Default Settings" in the Saved Sessions box. Click Save.

This (almost verbatim) comes from :

https://tortoisegit.org/issue/1880

Zakaria Acharki
  • 66,747
  • 15
  • 75
  • 101
Dan
  • 12,808
  • 7
  • 45
  • 54
1

In my case the issue was there was some process that had locked my keychain access...

Force quit all other apps to make sure keychain access is not locked on your Mac

vinzzz
  • 2,084
  • 2
  • 14
  • 23
  • This was the issue in my case. Fortunately, git push hanged for multiple remotes so I knew there wasn't a problem with the remote's server. – Luka Ramishvili Dec 12 '17 at 08:03
1

I'm new to this. I managed to solve my issue regarding the hanging git push command.

I recently installed git scm. In one of the installation options, I had selected to use git credential manager core. I assumed that it was installed automatically. But it looks like there was an error in that installation. I reinstalled git credential manager core from the website, and it works perfectly now.

1
  • git reset HEAD^, that will do undo your commit
  • push again in separate commits
Konstantin K.
  • 331
  • 2
  • 10
0

I also had an issue where git hangs on the "Writing objects" part on Windows 7 (using msysgit, the default windows client from git) and this is the first hit I got in google, so I will also post my answer here.

git config --global core.askpass "git-gui--askpass" did not work unfotunately, but after some researching I found the tip on Git push halts on "Writing Objects: 100%" to use git config –global sendpack.sideband false which worked perfectly.

I can finally push from the commandline again!

bas
  • 822
  • 10
  • 20
0

I spent hours trying to fix this and none of the recommendations worked. Out of frustration I moved the whole project to a backup folder, recloned a fresh and then copied over my files from backup folder. It worked!!. I suspect my issue was I committed node_module which was not excluded in .gitignore initially and removing from cache did not help/work. When I started from fresh the file size was a fraction compared to the earlier one.

Charles Moga
  • 23
  • 1
  • 6
0

This probably works for other Windows setups (I faced the issue on Windows 7 Pro 32 bits BTW and trying to push to Bitbucket, not Github).

I tried reinstalling Git and fiddling with the installer configuration.

Got it working with the OpenSSH setting left out and choosing Not to use one when choosing a credentials manager, which is probably what the SSH agent explained in other answers is called on GNU/Linux, so the hanging was probably due to waiting for an assumingly unavailable Windows credentials manager to respond.

Piovezan
  • 3,215
  • 1
  • 28
  • 45
0

So when you type & enter git pish-u origin, GUI asking for your credentials should popup. In my case, after typing git pish-u origin, nothing happens until took a look at my task manager and found something running which I was certain was the GUI that should popup to ask your credentials. I decided to end its task. I was assuming that it will show an error on my gitbash but instead, the damn GUI finally showed up and I was able to finally progress.

Dharman
  • 30,962
  • 25
  • 85
  • 135
0

I was faced with the same problem.
I use Github desktop for the normal action and it can push or pull, but it doesn't support force push, when I try to do some rebase work and it always failed to push force.
I tried add core.askpass, config the proxy but all not work. Finally I decided to watch the log of Github desktop and I found it use below command to push:

git -c credential.helper= -c protocol.version=2 push origin

I tried this one with force flag and it work, it finally ask me for the user name and password.
I am not sure which configuration make it work, but I think this may help.

EDIT: I tried to install manager-core from here and I am able to push. It seems like manager-core is not installed properly.

Loic
  • 160
  • 2
  • 13
0

If you use windows credential manager, use CMD instead of git Bash. Then you can add an authentication method to proceed. This worked for me.

0

In my case git was trying to use Ipv6 instead of Ipv4 to authenticate github and my terminal was stuck here set_sock_tos: set socket 3 IPV6_TCLASS 0x48.

To solve this I added AddressFamily option to ~/.ssh/config

Host github.com
  Hostname github.com
  AddressFamily inet 
  IdentityFile ~/.ssh/id_rsa  

test command:

ssh -vT git@github.com

bogdanoff
  • 1,705
  • 1
  • 10
  • 20
0

I experienced this in andorid studio.
Actually, on git push, the progress bar kept running and nothing happened;
I used to push code using token;

Here is what i did:

  1. in android studio opened terminal.
  2. entered
git push
  1. when email and password were asked on gui, i closed the dialogue box.
  2. after that i was prompted for user name on terminal, so i did it.
  3. after that i was asked password, where instead of password, i entered the access token.
git push
Logon failed, use ctrl+c to cancel basic credential prompt.
Username for 'https://github.com': abcxyz
Password for 'https://abcxyz@github.com': ____

and voila.

sifr_dot_in
  • 3,153
  • 2
  • 33
  • 42
0

If you are in VSCode it may also be the case that the GitHub VSCode extension wants to open GitHub to sign in.

If you click to fast you that popup and then all successive git push will get stuck even when you execute them from the VSCode terminal.

Solution: Close VSCode, open the project root again in a fresh window. When prompted follow the link and sign in. That's it.

User12547645
  • 6,955
  • 3
  • 38
  • 69
0

Turning off Virgin Media WebSafe fixed this issue for me. Assume other ISPs have similar toggle-able safety features.

0

For me none of above worked. I tried this one and it worked:

git push --set-upstream origin main

Suryakant kumar
  • 100
  • 1
  • 6
-1

I had two repositories, pushing to one of which worked fine. So, I compared their .git/config. The non-working one had at the end:

[http]
    sslVerify = false

The working one had instead:

[credential]
    helper = store

Changing .git/config solved the problem.

AlwaysLearning
  • 7,257
  • 4
  • 33
  • 68