一、問題
有時候在 git stash 非常有用,但是我們能由于一些錯誤的操作,導(dǎo)致將 git stash 中內(nèi)容被刪除掉,誤刪 stash.
二、知識點
git fsck命令用于檢查 Git 倉庫中的對象的完整性和一致性。它可以發(fā)現(xiàn)和報告一些潛在的問題,比如損壞的對象、丟失的對象引用等。
-
檢查對象完整性:確保所有的對象(提交、文件樹、文件等)在物理上存在且沒有損壞。如果有對象損壞,
git fsck將報告并顯示問題。 -
尋找不可達(dá)對象:Git 使用引用來跟蹤對象,如果某個對象沒有任何引用指向它(即不可達(dá)對象),
git fsck會發(fā)現(xiàn)并報告這些不可達(dá)的對象。 -
查找丟失的對象引用:它會檢查是否存在引用(比如分支、標(biāo)簽等),但沒有對應(yīng)的對象存在。這可能是因為刪除了對象或引用指向了一個不存在的對象。
-
輸出報告:將列出發(fā)現(xiàn)的問題,并提供相應(yīng)的修復(fù)建議或提示。
三、復(fù)制一個副本
為了安全和不熟練操作 git stash 的同學(xué),將當(dāng)前項目準(zhǔn)備一個副本,在副本中進(jìn)行操作,防止第一個現(xiàn)場丟失。
四、查看 unreachable 列表
切換到副本中,所有的操作放在副本進(jìn)行:
git fsck --unreachable
查看所有unreachable的記錄, 如同下面的例子:
git fsck --unreachable
Checking object directories: 100% (256/256), done.
unreachable blob 08a0724cff104d83f3c261b68487e5b5dfb0bc92
unreachable blob 09e0e7369d8c60923a53c8097674dde7f71a0cc0
unreachable blob 0b00205b03a9d5a7c311907b968d41da09ee0662
unreachable blob 0ba035459d1ce597a1cbba64a5f1073c467af198
unreachable blob 0f8093bb5835971fad89f8274387d15d38eba9c7
unreachable blob 11205462d9730314c6ac8f0320ef0c6247af4b7a
五、將 unreachable 內(nèi)容提取到編輯器中
最好準(zhǔn)備一個編輯器,將所有的內(nèi)容復(fù)制出來,因為這個列表可能很長,在終端展示有限,也不好搜索,將其復(fù)制出來放在編輯器中(vscode)在內(nèi)過多的時候有查找等優(yōu)勢。
六、 認(rèn)識 unreachable 分類
| 類型 | 描述 |
|---|---|
| Commit | 不再有分支或標(biāo)簽指向的提交 |
| Tree | 不再有提交指向的文件樹 |
| Blob | 不再有文件樹指向的文件對象 |
| Tag | 不再有分支或提交指向的標(biāo)簽 |
| unreachable | 一般表示 Git 對象的一部分,但由于沒有引用指向它們,因此被視為不可達(dá) |
這里我們重點關(guān)注
commit對象。
七、git show +展示信息
git show <sha>
根據(jù)返回的信息,判斷是不是我們需要恢復(fù)的內(nèi)容,根據(jù)個人經(jīng)驗, commit 是我們需要恢復(fù)的內(nèi)容可能比較大
八、恢復(fù)
有目標(biāo)的 sha key, 然后切換到 stash 的分支, 執(zhí)行:
git stash apply + <sha>
可能會出現(xiàn)如下的錯誤:
fatal: '' is not a stash-like commit
解決辦法:使用 merge 命令
# 如果有合并沖突,解決沖突
git merge +<sha>
在副本中已經(jīng)完成,相同的操作在目標(biāo)項目中重新實現(xiàn)一次即可。
九、小結(jié)
本文主旨在恢復(fù)刪除的 git stash 存儲的內(nèi)容,從副本出發(fā),結(jié)合git fsck命令獲取unreachable列表,然后,根據(jù)自己的項目 使用git show 查看unreachable對象中的內(nèi)容,找到目標(biāo)對象,然后使用git stash apply 或者git merge 進(jìn)行合并。如果這些操作符合我們的目標(biāo),在正式項目中重新演繹一次即可。
-
終端
+關(guān)注
關(guān)注
1文章
1258瀏覽量
31677 -
編輯器
+關(guān)注
關(guān)注
1文章
828瀏覽量
32898 -
Git
+關(guān)注
關(guān)注
0文章
207瀏覽量
16930
原文標(biāo)題:恢復(fù)被刪除的Git stash 記錄
文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
git shell 常用命令
手機通訊記錄被刪除怎么辦?
QQ聊天記錄怎么恢復(fù)
恢復(fù)Unix系統(tǒng)被刪除地文件
蘋果手機備忘錄刪除了怎么恢復(fù)?誤刪備忘錄找回教程
蘋果手機短信刪除了怎么恢復(fù)?就用開心手機恢復(fù)大師
陌陌恢復(fù)大師:蘋果陌陌聊天記錄恢復(fù)教程
蘋果恢復(fù)大師告訴你:微信刪除后怎么恢復(fù)聊天記錄
恢復(fù)被刪除的Git stash記錄
評論