2012-04-07 2 views
4

У меня есть поврежденный свободный объект.Вернитесь в историю к неповрежденной версии?

Я пробовал проверять, возвращать, переустанавливать и может быть несколько других вещей, чтобы перейти к первоначальной фиксации. В каждом случае я побежал git fsck и по-прежнему была та же проблема:

> git fsck 
error: corrupt loose object '25a196217ebb6e341909205575f491022eafc4d9' 
fatal: loose object 25a196217ebb6e341909205575f491022eafc4d9 (stored in .git/objects/25/a196217ebb6e341909205575f491022eafc4d9) is corrupt 

есть способ избавиться от поврежденных объектов без удаления просто .git? У меня нет другой резервной копии, поэтому я не могу заменить поврежденный объект.

Это более узкий вопрос, который возник из этого git "error: corrupt loose object" after moving a directory

обновление (1):

> git gc 
Counting objects: 747, done. 
Delta compression using up to 8 threads. 
error: corrupt loose object '25a196217ebb6e341909205575f491022eafc4d9' 
fatal: loose object 25a196217ebb6e341909205575f491022eafc4d9 (stored in .git/objects/25/a196217ebb6e341909205575f491022eafc4d9) is corrupt 
error: failed to run repack 

обновление (2): это не сработало Remove file from git repository (history)

обновление (3): клонирование d idn't не работает:

> git clone ../dynamicsCode_good/ . 
Cloning into .... 
done. 
error: corrupt loose object '25a196217ebb6e341909205575f491022eafc4d9' 
fatal: loose object 25a196217ebb6e341909205575f491022eafc4d9 (stored in .git/objects/25/a196217ebb6e341909205575f491022eafc4d9) is corrupt 

. Справочник не заполнен

обновление (4): удаление поврежденного объекта.

> git --version 
git version 1.7.5.4 


> rm -f .git/objects/25/a196217ebb6e341909205575f491022eafc4d9 
13:42:57 ~/Dropbox/work/dev/dynamicsCode_torek 
> git fsck --full 
missing blob 25a196217ebb6e341909205575f491022eafc4d9 
dangling tree 64a970c878fef7deeeb4ce2ffc5e6234a72894ad 
dangling tree 528e6c121fb8e56097462b2ebb9ec4de66388ce2 

первый (первоначальный) комментарий. этот комментарий даже не имеет поврежденного файла.

> git log |tail -5 
commit 150ceebafb9c20769386cc7ffba07f6e6565fae6 
Author: Kirill ...gmail.com> 
Date: Tue Sep 27 22:51:15 2011 -0400 

    state takes input as input 
checkout: 

> git checkout -b 150ceebafb9c20769386cc7ffba07f6e6565fae6 
Switched to a new branch '150ceebafb9c20769386cc7ffba07f6e6565fae6' 

> git gc 
Counting objects: 783, done. 
error: unable to find 25a196217ebb6e341909205575f491022eafc4d9 
Compressing objects: 100% (776/776), done. 
fatal: unable to read 25a196217ebb6e341909205575f491022eafc4d9 
error: failed to run repack 
> git fsck --full 
broken link from tree 4668817140320ad2e04aa946d95dec2c3885d97b 
       to blob 25a196217ebb6e341909205575f491022eafc4d9 
missing blob 25a196217ebb6e341909205575f491022eafc4d9 
dangling tree 64a970c878fef7deeeb4ce2ffc5e6234a72894ad 
dangling tree 528e6c121fb8e56097462b2ebb9ec4de66388ce2 

Я также попытался распаковать только объект в каталоге .git/objects/pack/. не помогло.

Я также клонировали это состояние в новый каталог:

> git gc 
Counting objects: 662, done. 
error: unable to find 25a196217ebb6e341909205575f491022eafc4d9 
Compressing objects: 100% (656/656), done. 
fatal: unable to read 25a196217ebb6e341909205575f491022eafc4d9 
error: failed to run repack 
14:40:34 ~/Dropbox/work/dev/dynamicsCode_torek_commit_clone 
> git fsck 
broken link from tree b5ab6b287804d5069a3c8648ace38d9d9feac1a5 
       to blob 25a196217ebb6e341909205575f491022eafc4d9 
dangling commit dad8edc620248d3911b7b1c0a99608a64e0288a3 
missing blob 25a196217ebb6e341909205575f491022eafc4d9 
dangling tree 64a970c878fef7deeeb4ce2ffc5e6234a72894ad 
dangling commit ae2b2a9edb744d9e91aa78891c849d5a0040ea94 
dangling commit 32ed79bd4ac70b118d046cb6093a4710562e95ba 
dangling commit 7e45ef0c6ffc46401b1f82bcbf0f7e843abf9e31 
dangling tree 528e6c121fb8e56097462b2ebb9ec4de66388ce2 
14:40:40 ~/Dropbox/work/dev/dynamicsCode_torek_commit_clone 
> git branch 
* 150ceebafb9c20769386cc7ffba07f6e6565fae6 

не помогло.

Поврежденный файл tags от ctags. Мне это не нужно. странно, что я не могу перестроить git без этого файла. Самое главное, что из всех моих исследований я не вижу ни того, как это можно сделать, ни почему это невозможно.

обновление (5): выезд без ветвления

> git checkout 150ceebafb9c20769386cc7ffba07f6e6565fae6 
Note: checking out '150ceebafb9c20769386cc7ffba07f6e6565fae6'. 

You are in 'detached HEAD' state. You can look around, make experimental 
changes and commit them, and you can discard any commits you make in this 
state without impacting any branches by performing another checkout. 

If you want to create a new branch to retain commits you create, you may 
do so (now or later) by using -b with the checkout command again. Example: 

    git checkout -b new_branch_name 

HEAD is now at 150ceeb... state takes input as input 
16:41:40 ~/Dropbox/work/dev/dynamicsCode_torek_commit 
> git fsck --full 
broken link from tree 4668817140320ad2e04aa946d95dec2c3885d97b 
       to blob 25a196217ebb6e341909205575f491022eafc4d9 
missing blob 25a196217ebb6e341909205575f491022eafc4d9 
dangling tree 64a970c878fef7deeeb4ce2ffc5e6234a72894ad 
dangling tree 528e6c121fb8e56097462b2ebb9ec4de66388ce2 
+1

«git gc» очистить его? – Andy

+0

нет, я обновлен в обновлении (1) –

+0

Вы можете попробовать клонировать этот репозиторий. Клонирование должно принимать только «необходимые» объекты в новое репо, поэтому, если этот свободный объект действительно «не нужен» для вашего клона, у вас может быть репо без коррупции в вашем клоне. –

ответ

2

Если удалить поврежденный объект вручную, мерзавец, как правило, позволяют получить на все остальное. Я намеренно испорчен в GIT блоба (просто вынужден несколько плохих байт спереди) и получил следующее:

$ git fsck 
fatal: object bd1b260b0ef92d1a219e1183953fa1ac7cdb4cad is corrupted 
$ git gc 
Counting objects: 23, done. 
error: unable to unpack bd1b260b0ef92d1a219e1183953fa1ac7cdb4cad header 
error: inflateEnd: failed 
Delta compression using up to 2 threads. 
Compressing objects: 100% (12/12), done. 
fatal: object bd1b260b0ef92d1a219e1183953fa1ac7cdb4cad is corrupted 
error: failed to run repack 
$ git fsck --full 
fatal: object bd1b260b0ef92d1a219e1183953fa1ac7cdb4cad is corrupted 
$ rm -f .git/objects/bd/1b260b0ef92d1a219e1183953fa1ac7cdb4cad 
$ git fsck --full 
broken link from tree a3070cb66fd169e1443867a8bb137a44103c9f24 
       to blob bd1b260b0ef92d1a219e1183953fa1ac7cdb4cad 
missing blob bd1b260b0ef92d1a219e1183953fa1ac7cdb4cad 
$ git cat-file -p 2418b6ba8fd0289933c9351260a272b8e410867f 
tree a3070cb66fd169e1443867a8bb137a44103c9f24 
parent 8d945134b0cead535d66af29c8eb4228b5dc3763 
author [redacted] 1333789753 -0600 
committer [redacted] 1333789753 -0600 

test corrupted object 
$ git checkout 2418b6ba8fd0289933c9351260a272b8e410867f 
error: git checkout-index: unable to read sha1 file of morefile (bd1b260b0ef92d1a219e1183953fa1ac7cdb4cad) 
D morefile 
Note: checking out '2418b6ba8fd0289933c9351260a272b8e410867f'. 

You are in 'detached HEAD' state. ... 

Примечания, где-то по пути он вновь указал на ветку master к предыдущему «хорошо» совершить (а не сразу-предыдущий, и я понятия не имею, почему), поэтому вам может понадобиться восстановить историю фиксации и т. д. Но все было там, за исключением отсутствующего файла «morefile», чей blob я испортил.(Я восстановил из резервной копии я сделал заранее, и даже был в состоянии получить файл обратно, с git checkout -- morefile. Вы можете mv поврежденные блобы где-нибудь и посмотреть, если вы можете восстановить некоторые данные из него.)

Я бы наверняка поддержал сломанный git-репо первым, Just In Case. :-)

+0

наш git fsck немного отличается. Я сделал то же самое, что и ты. И, попробовал клонирование. не работает. см. обновление (4). В любом случае, я ценю подробный ответ от вас. –

+0

Кстати, магическое число выше (2418b ...) произошло от прокрутки назад, чтобы посмотреть, что это было до того, как я разбил один объект-блок. Когда вы говорите «не работает», вы имеете в виду «git checkout », не получаете ли вы заполненного рабочего дерева? Я тестировал это на своем ноутбуке, где у меня установлен 1.7.0.3. – torek

+0

1) Да, я понял это. Я использовал свой первоначальный комментарий (см. 'Git log | tail -n5' в обновлении (4)). в комментарии нет даже поврежденного файла; так что это хороший комментарий. 2) Я не уверен, заполняет ли это дерево или нет, но 'fit fsck' все еще дает ошибку, см. Обновление (5). –