1. 程式人生 > >Git 遇到了 early EOF index-pack failed 問題

Git 遇到了 early EOF index-pack failed 問題

今天想 clone 一下 boost 在 github 的 repo,結果在 clone 的過程中遇到了下面的錯誤。我原本以為是網路原因,今天學校網速廢成渣了,很多同學都去網咖擼去了,所以就 retry 了一次。還是出現了下面的錯誤,然後就不得不 google 去了。

$ git clone https://github.com/boostorg/boost.git
Cloning into 'boost'...
remote: Counting objects: 183543, done.
remote: Compressing objects: 100% (69361/69361), done.
fatal: The remote end hung up unexpectedly
fatal: early EOF
fatal: index-pack failed

後來 google 到的參考如下:

特別是第一篇(第一個QA),應該跟我的情況最為符合,不過我嘗試了第二個 QA 中Voket 的回答給出的解決方案。因為我在 WindowsWindows 下的 GitGit 作的這個死。在這裡就簡單記錄一下這個解決方案。

# 為 git 新增配置項,通過下面的命令可以簡單完成
# 在這之前可以執行 git config -l 命令看看已有配置項有哪些
git config --add core.compression -1

上面是通過命令來完成的,很方便,當然可以直接修改 .gitconfig 檔案(在使用者目錄下),如果你願意的話。部分內容如下:

[user]
    name = Ggicci
    email = ...
[core]
    compression = -1

在 [core] 這個 section 裡面新增 compression 屬性即可。至於它的取值可以參考 Git Config Manpage,這個頁面你可以通過man git configLinux) 或者 git config --help(windows)來檢視本地版本。

core.compression

An integer -1..9, indicating a default compression level. -1 is the zlib default. 0 means no compression, and 1..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. - From Git Manpage

compression 是壓縮的意思,從 clone 的終端輸出就知道,伺服器會壓縮目標檔案,然後傳輸到客戶端,客戶端再解壓。取值為 [-1, 9],-1 以 zlib 為預設壓縮庫,0 表示不進行壓縮,1..9 是壓縮速度與最終獲得檔案大小的不同程度的權衡,數字越大,壓縮越慢,當然得到的檔案會越小。

這之後再嘗試了一次 clone,works perfectly :)

$ git clone https://github.com/boostorg/boost.git
Cloning into 'boost'...
remote: Counting objects: 183543, done.
remote: Compressing objects: 100% (69361/69361), done.
remote: Total 183543 (delta 113990), reused 183372 (delta 113844)
Receiving objects: 100% (183543/183543), 67.89 MiB | 162.00 KiB/s, don
e.
Resolving deltas: 100% (113990/113990), done.
Checking connectivity... done.