萌新筆記——git的問題(error: object file .git/objects/* is empty...)的解決方案及對git版本庫文件的瞭解

来源:http://www.cnblogs.com/chinxi/archive/2016/12/06/6139469.html
-Advertisement-
Play Games

由於操作不當,導致git版本庫出了大問題,如下所示: 即提示xx文件是空的。在使用git log、git commit、git status等命令都會出此錯誤(文件名可能不一樣)。如果把.git刪掉,重新init,那會很輕鬆地暴力地解決了這個問題。但是,這樣的話之前的版本信息就全部丟失了,這並不是想 ...


  由於操作不當,導致git版本庫出了大問題,如下所示:

error: object file .git/objects/8b/61d0135d3195966b443f6c73fb68466264c68e is empty
fatal: loose object 8b61d0135d3195966b443f6c73fb68466264c68e (stored in .git/objects/8b/61d0135d3195966b443f6c73fb68466264c68e) is corrupt

 

  即提示xx文件是空的。在使用git log、git commit、git status等命令都會出此錯誤(文件名可能不一樣)。如果把.git刪掉,重新init,那會很輕鬆地暴力地解決了這個問題。但是,這樣的話之前的版本信息就全部丟失了,這並不是想要的結果。於是,我打算修複它。

 

  首先,貼上找到的正確解決方法的鏈接:http://stackoverflow.com/questions/11706215/how-to-fix-git-error-object-file-is-empty

  如果看不懂,最後有簡單的版本

 

  然後是說說我自己瞎搗鼓的過程:

 

  當時我想,既然它提示那個文件是有問題的,那我把它刪了會怎麼樣呢?結果是提示另一個文件是空白的。也就是說,還得刪。我空發奇想,如果我修改了它的日誌會怎麼樣?於是,我查看的它的日誌文件:

cd .git
cd logs
vim HEAD

 

  我發現日誌文件前面都是我之前提交的版本信息,唯獨最後一行是亂碼。於是,我把亂碼行刪了。同時,cd 進另當前目錄下的一個子目錄中

cd refs
cd heads
vim master

 

  把這裡最後一行的亂碼也刪了。

 

  然後,我發現.git另一個子目錄refs里,存著好像是當前版本信息的東西,參考之前的HEAD文件,把它改成了一個正常的版本號。此時,我使用git log,居然可以正常地顯示出日誌了!然後我嘗試add了一下,發現OK,沒有提示任何東西。據說,沒有提示就是好事。可是,萬萬沒想到的是,在commit的時候,又開始提示xx文件是空的了。

 

  看來,我是哪裡搞錯了什麼。

  雖然自己瞎搗鼓沒有成功,但是似乎對git版本庫的文件結構稍微瞭解了一些:

[ccx@ubuntu ~/miniSearchEngin]$>cd .git/
[ccx@ubuntu ~/miniSearchEngin/.git]$>l
branches/  COMMIT_EDITMSG  config  description  HEAD  hooks/  index  info/  logs/  objects/  refs/

 

  一個一個來看,首先,branches是一個空文件(我的是),“樹枝”的意思,大概是與分支有關的文件,我暫時沒用到分支,並不是很清楚。

  COMMIT_EDITMSG,看文件名大概猜到是commit時的編輯信息,結果和猜測的一樣:

[ccx@ubuntu ~/miniSearchEngin/.git]$>cat COMMIT_EDITMSG 
詞典聯想功能OK,目測可以多線程服務

  與日誌文件最後一行呼應:

 31 e5085f07d6f8578bad1ae39d85bf88db6886c51d bd9a33f13603ef3b53184e3b9ce9408638b71fb4 ccx19930930 <461661280@qq.com>
1480909458 +0800 commit: 詞典聯想功能OK,目測可以多線程服務

 

  然後是description文件,好吧我不知道它是幹嘛用的(下麵省略掉不知道的吧,哪天搞明白了再補)

  

  HEAD,裡面是一個文件路徑:

[ccx@ubuntu ~/miniSearchEngin/.git]$>cat HEAD
ref: refs/heads/master
[ccx@ubuntu ~/miniSearchEngin/.git]$>cat refs/heads/master
bd9a33f13603ef3b53184e3b9ce9408638b71fb4

  文件內容與日誌文件最後一項的後一個大數字相同。於是我猜測它可能是當前版本信息。

 

  如果把HEAD刪了,或者裡面的路徑改了,會怎麼樣呢:

  刪除的情況:

[ccx@ubuntu ~/miniSearchEngin/.git]$>mv HEAD HEAD.h
[ccx@ubuntu ~/miniSearchEngin/.git]$>cd ..
[ccx@ubuntu ~/miniSearchEngin]$>git log
fatal: Not a git repository (or any of the parent directories): .git

  改了的情況:

[ccx@ubuntu ~/miniSearchEngin]$>git log 
fatal: Not a git repository (or any of the parent directories): .git

  就提示沒有git版本庫了。

 

  如果手動把refs/heads/master改成之前的一個版本號,在git log的時候會顯示為之前的日誌信息。就像是日誌回檔了,但是文件還是原樣。反正我做了這個操作之後使用git status,會提示一堆紅色未提交的文件。進行add 和commit也是可以。此時查看日誌文件,會發現最後一行新增了新信息。不妨把此操作命名為操作A。

  這裡要說一下日誌文件,截取部分如下:

  1 0000000000000000000000000000000000000000 541115f2d1f08d2fe58a768e5a9d3a809bab1131 ccx19930930 <461661280@qq.com>               1480061835 +0800 commit (initial): build git                                                                               
  2 541115f2d1f08d2fe58a768e5a9d3a809bab1131 31db0463027e42718de8e2bbd826586a89316723 ccx19930930 <461661280@qq.com>               1480082783 +0800 commit: 中文、英文單詞詞頻統計,不包含全、半形標點符號
  3 31db0463027e42718de8e2bbd826586a89316723 1a5c8107af4852b0d8d36a76d988cb2a0b06cc10 ccx19930930 <461661280@qq.com>               1480128209 +0800 commit: 去停用詞
  4 1a5c8107af4852b0d8d36a76d988cb2a0b06cc10 959fa05c58dbcb6837d7b7a9062bf2f542a15a6b ccx19930930 <461661280@qq.com>               1480176053 +0800 commit: 分組OK

  前兩個數字就好像是表示從哪個數字開始,到哪個數字,然後下一行的起始就是上一行的結束。由於refs/heads/master中存著當前版本號,於是我很happy地把它看成一個鏈表,以當前版本為頭結點的鏈表:

+=======+   +=======+         +========+   +=========+
|當前版本|-->|上一版本|-->...-->|第二個版本|-->|第一個版本|
+=======+ +=======+ +========+ +=========+

  做了操作A之後:

+=======+             +=============+         +===============+         +========+
|當前版本|--+ |操作A之前的版本|-->...+->|操作A中設定的版本|-->...-->|第一個版本|
+=======+ | +=============+ | +===============+ +========+
| |
+-------------------------------+

  就成這樣了。

 

  objects文件夾里存的應該是不同版本的文件,可能是經過了加密演算法還是什麼演算法,打開看基本是亂七八糟的不知道寫的什麼。

  logs文件夾之前提到了,存的是日誌文件。

  refs文件夾存的是當前版本信息,“鏈表的頭結點”。

 

  好了,裝逼(賣弄)了這麼久,回歸正題。

  我最後是用一開始的鏈接里的方法解決瞭解個問題:

 

  在最最開始,要先備份一下.git文件夾,萬一搞壞了呢

 

  首先,刪除所有的空白文件:

cd .git
find . -type f -empty -delete -print

 

  然後,列印出日誌文件最後兩行:

tail -n 2 .git/logs/refs/heads/master

 

  接著,查看xx版本是否正常,即上一步列印出來的第一條

git show xxxx(版本號)

 

  之後,回檔:

git update-ref HEAD xxxx(版本號)

 

  檢查一下:

git fsck

 

  我到這一步就已經OK能用了,鏈接後面還有一些處理我並沒有繼續做下去(我比較懶,目的就只是修複一下版本庫,既然能用了我就不繼續搞了,萬一又壞了呢)

 

  鏈接中剩餘的操作:

rm .git/index
git reset
git fsck

  然而,在寫此文的時候我發現,那位大神這樣做了之後並沒有什麼用,他也說了他並不想繼續搞了(英語渣,大概應該可能也許是這個意思),將就用吧--!

 

  最後看了一下修複後的日誌信息,發現就是相當於做了“鏈表刪除節點”的操作,那個錯誤的日誌信息還是亂碼。我也不想去刪了,就怕又刪出迷之問題。

 

後記:

  寫此文時,已距離我修複好git版本庫一周有餘,備份的錯誤庫早已刪除(永久刪除,前幾天剛清了一次回收站--!),有些地方可能描述得不太清楚,忘見諒。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • CentOS 6.5 x86_64系統下安裝Apache-2.4.10,並且根據生產環境需要做了一定的安全配置。 ...
  • 設備驅動充當了硬體和應用軟體之間的紐帶,它使得應用軟體只需要調用系統軟體的應用編程介面(API)就可讓硬體去完成要求的工作。本文主要講解了Linux設備驅動與硬體的關係,Linux設備驅動的開發模式以及內核中相關的重要基礎數據結構。 ...
  • CentOS 6.5 x86_64系統下安裝Nginx-1.6.2,並且根據生產環境需要做了一定的安全配置。 ...
  • MII(media-independent interface)提供了MAC(media access control)與PHY(Ethernet physical layer)之間的互聯技術,該介面支持10Mb/s與100Mb/s的數據傳輸速率,數據傳輸的位寬為4位。MDIO(Management... ...
  • SDRAM(Synchronous Dynamic Random Access Memory,同步動態隨機存儲器)也就是通常所說的記憶體。同步是指其時鐘頻率與CPU前端匯流排的系統時鐘頻率相同;動態是指存儲陣列需要不斷的刷新來保證數據不丟失;隨機是指數據不是線性依次存儲的。 ...
  • CentOS 6.5 x86_64系統下安裝MySQL-5.6.10,並且根據生產環境需要做了一定的安全配置。 ...
  • ARM彙編語言(Assembly Language)是ARM CPU所能接受的最底層唯一語言(所有的高級語言最終都要轉換成彙編語言然後彙編成processor instruction codes)。ARM彙編的核心是ARM指令集。理解ARM彙編有助於理解底層processor內部的工作原理,有助於對... ...
  • ARM(Advanced RISC Machine)採用的是RISC精簡指令集,Load/Store架構,所有指令必須載入到寄存器才能進行運算。7種工作模式。31個通用寄存器,6個狀態寄存器。大小端可配置。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...