This article will document some of the common errors you encounter with Git and their solutions (updated continuously)


Error 1

> git push
# fatal: unable to access 'https://github.com/xxx/xxx.git/': Failed to connect to github.com port 443: Timed out
Copy the code

[Solution]

This may be caused by network fluctuation. You can change the network environment or try several times


Error 2

> git push
# fatal: repository 'https://github.com/xxx/xxx.git/' not found
Copy the code

[Solution]

This may be caused by a permission validation error. Try uninstalling and reinstalling Git credential manager

> git credential-manager uninstall # uninstall

> git credential-manager install   # installation
Copy the code


Mistake 3

> git push
# fatal: unable to access 'https://github.com/xxx/xxx.git/': OpenSSL SSL_read: Connection was reset, errno 10054
Copy the code

[Solution]

This may be caused by SSL authentication failure, and we can simply disable SSL authentication

git config --global http.sslVerify "false"
Copy the code

HTTP. SslVerify:

Whether to verify the SSL certificate when fetching or pushing over HTTPS. Defaults to true. Can be overridden by the GIT_SSL_NO_VERIFY environment variable.

Whether to perform SSL authentication when fetching and pushing through HTTPS. The default is true. This can be overridden using the environment variable GIT_SSL_NO_VERIFY.


Mistake 4

> git push
# Enumerating objects: 76, done.
# Counting objects: 100% (76/76), done.
# Delta compression using up to 4 threads
# Compressing objects: 100% (59/59), done.
# Writing objects: 100% (60/60), 808.06 MiB | 10.78 MiB/s, done.
# Total 60 (delta 32), reused 0 (delta 0), pack-reused 0
# error: RPC failed; curl 18 transfer closed with outstanding read data remaining
# send-pack: unexpected disconnect while reading sideband packet
# fatal: the remote end hung up unexpectedly
# Everything up-to-date
Copy the code

[Solution]

  • This situation may be caused by too small cache, we can try to increase the cache (cache size is set according to the actual situation)
git config --global http.postBuffer 1048576000

#The unit is Byte. For example, 1048576000B indicates 1 gb
Copy the code

What does http.postBuffer actually do? Git Git Git Git Git Git Git Git

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 maximum size of the cache when smart HTTP is used to post data to a remote location, in bytes. For requests larger than this cache size, HTTP/1.1 and Transfer-Encoding: chunked are used to avoid creating a large package file locally. The default is 1 MiB, which is sufficient for most requests.

Note that raising this limit is only effective for disabling chunked transfer encoding and therefore should be used only Where the remote server or a proxy only supports HTTP/1.0 or is noncompliant with the HTTP standard not, in general, an effective solution for most push problems, but can increase memory consumption significantly since the entire buffer is allocated even for small pushes.

Note that raising this limit only works with encodings that disable chunked transport, so it should only be used when the remote service or proxy only supports HTTP/1.0 or does not conform to the HTTP standard. In general, increasing this limit is not an effective solution for most push problems, but can greatly increase memory consumption because even for small pushes the entire buffer is allocated.

  • This situation may also be caused by network fluctuations, and we can try to remove the relevant network restrictions
git config --global http.lowSpeedLimit 0
git config --global http.lowSpeedTime 999999
Copy the code

What do http.lowSpeedLimit and http.lowSpeedTime actually do? There is a relevant explanation on the website:

If the HTTP transfer speed is less than http.lowSpeedLimit for longer than http.lowSpeedTime seconds, the transfer is aborted. Can be overridden by the GIT_HTTP_LOW_SPEED_LIMIT and GIT_HTTP_LOW_SPEED_TIME environment variables.

If the HTTP transfer speed is less than http.lowSpeedLimit or the transfer time is longer than http.lowSpeedTime, the transfer is interrupted. This can be overridden using the environment variables GIT_HTTP_LOW_SPEED_LIMIT and GIT_HTTP_LOW_SPEED_TIME.

  • If the file size is too large, try increasing the compression ratio (set the compression ratio according to the actual situation).
git config --global core.compression 3
Copy the code

What does core.com actually do? There is a relevant explanation on the website:

An integer 1… 29, Indicating that IT was a default compression level.-1 is the Zlib default. 29, Indicating that it was a default compression level.-1 is the Zlib default. 9 are various speed/size tradeoffs, 9 being slowest. If set, this provides a default to other compression variables, such as core.looseCompression and pack.compression.

Use an integer -1… 9 indicates the compression level. -1 indicates that the default zlib value is used. 0 means no compression, 1… 9 is the tradeoff between compression speed and compression size. 9 is the slowest compression speed and the smallest compression size. If this value is set, it will provide a default value for other compression-related variables, such as core.loosecompression and pack.compression.

  • If multiple submissions are pushed together, you can try to push multiple submissions. [Important]
Git push < remote repository name > <commit ID >
#This command pushes all unpushed commits before 
      
        is specified
      
Copy the code