141

Ubuntu Oneフォルダーに保持しているリポジトリを新しいマシンに複製しようとしたところ、次のようになりました。

cd ~/source/personal
git clone ~/Ubuntu\ One\ Side\ Work/projects.git/

Cloning into 'projects'...
done.
fatal: unable to read tree 29a422c19251aeaeb907175e9b3219a9bed6c616

そこで、ここで尋ねられたこのような他の多くの質問を調べてみましたが、ほとんどの人は実行するように言ってgit fsck --fullいます。

cd ~/Ubuntu\ One\ Side\ Work/projects.git
git fsck --full

Checking object directories: 100% (256/256), done.
Checking objects: 100% (447/447), done.
broken link from  commit 235ae1f48701d577d71ebd430344a159e5ba4881
              to  commit 984c11abfc9c2839b386f29c574d9e03383fa589
broken link from    tree 632a9cf0ef9fccea08438b574e2f1c954f4ff08b
              to    blob 25a742dff0a403b2b3884f2ffddf63eb45721fac
broken link from    tree 632a9cf0ef9fccea08438b574e2f1c954f4ff08b
              to    blob dd4e97e22e159a585b20e21028f964827d5afa4e
broken link from    tree 632a9cf0ef9fccea08438b574e2f1c954f4ff08b
              to    tree 29a422c19251aeaeb907175e9b3219a9bed6c616
broken link from    tree 632a9cf0ef9fccea08438b574e2f1c954f4ff08b
              to    tree 8084e8e04d510cc28321f30a9646477cc50c235c
broken link from    tree 774b5b4157b4caae1c6cad96c8eaf5d4eba2c628
              to    blob a0daa0c1567b55d8de2b4d7a3bc010f58c047eab
broken link from    tree 774b5b4157b4caae1c6cad96c8eaf5d4eba2c628
              to    blob e9052d35bfb6d30065b206fc43f4200a04d5281b
broken link from    tree 774b5b4157b4caae1c6cad96c8eaf5d4eba2c628
              to    blob 1a3a5e4dd2502ac121c22f743c4250e254a94eeb
broken link from    tree 4aa336dc1a5838e8918e03b85580069d83f4ad09
              to    tree 8cc55ec952dc192a233e062201d1e7e873ac3db0
broken link from    tree e5674a91a53e15575a1f3bf5786bc5cc719fb483
              to    blob 4a994e1e7bb7ce28dcec98bad48b9a891d7dec51
broken link from    tree e5674a91a53e15575a1f3bf5786bc5cc719fb483
              to    blob ac033bf9dc846101320c96a5ce8aceb8c96ec098
broken link from    tree 252ab84542264e1589576b6ee51e7a31e580a0e2
              to    tree 2069041cd5950e529e2991d37b7290ec021d90d4
broken link from    tree 2d4964aa4d4f5d8c7228518ce72ef6a63f820c6d
              to    blob d83690e1b9a6bdd8a08754b38231799acefcb2ab
broken link from    tree c7192e82fc581bd6448bda1a25e8729bdac5f4ff
              to    blob 30d54d47ae82add1917ca173d42e58b396df580b
broken link from    tree 7c66306901fc71389623286936cef172d4ffe408
              to    blob bc7e05d705401273b1df4e939de0f540597c0931
broken link from    tree 0940f5fd227d4c84d6e6749d872db50a4522ae3a
              to    tree 923767594ac22023e824948d65622fe5b407d1a1
broken link from    tree 8eadcd2a971e8357d24f0d80f993d2963452209f
              to    blob 2598bde3dc8cb80ee49510b8159344004b88645f
broken link from    tree ffa302dd0d969172ef23caeefe856ab2f57a4e4d
              to    blob d6925fa431be1ac585bf9a481e98f75107a6e6fb
broken link from    tree 7045b8870a49ce30a2027537a96d73d162bda773
              to    blob 25688652dea26f61f576ca1b52b9d1a18fbfd01d
broken link from    tree 37e4705d34bd440ce681ae32ae9a180a13256d72
              to    tree 246f564d4cee53339b8a4244f3173b61caa518eb
missing blob d6925fa431be1ac585bf9a481e98f75107a6e6fb
missing blob ac033bf9dc846101320c96a5ce8aceb8c96ec098
missing tree 29a422c19251aeaeb907175e9b3219a9bed6c616
missing tree 8084e8e04d510cc28321f30a9646477cc50c235c
missing blob 30d54d47ae82add1917ca173d42e58b396df580b
missing tree 8cc55ec952dc192a233e062201d1e7e873ac3db0
missing blob e9052d35bfb6d30065b206fc43f4200a04d5281b
dangling tree 4b26e95db542c72ac4a22ec25abe38fb2de79752
missing blob d83690e1b9a6bdd8a08754b38231799acefcb2ab
missing blob 25a742dff0a403b2b3884f2ffddf63eb45721fac
missing tree 923767594ac22023e824948d65622fe5b407d1a1
missing blob 25688652dea26f61f576ca1b52b9d1a18fbfd01d
missing blob 2598bde3dc8cb80ee49510b8159344004b88645f
dangling tree 3a683869f1bb0c1634de75700c316b3b36570dbd
dangling blob 4098d30843380d798a811f1aa9a02994f0dbbb27
missing tree 2069041cd5950e529e2991d37b7290ec021d90d4
missing blob 4a994e1e7bb7ce28dcec98bad48b9a891d7dec51
missing blob 1a3a5e4dd2502ac121c22f743c4250e254a94eeb
missing blob a0daa0c1567b55d8de2b4d7a3bc010f58c047eab
dangling tree 6c7b5162aa7a303fa3fe8dc393c5da564e309521
missing commit 984c11abfc9c2839b386f29c574d9e03383fa589
missing blob bc7e05d705401273b1df4e939de0f540597c0931
missing blob dd4e97e22e159a585b20e21028f964827d5afa4e
missing tree 246f564d4cee53339b8a4244f3173b61caa518eb
dangling commit a01f5c1e5315dc837203d6dee00d3493be9c5db9

それは本当に悪いようです。私がするとき、git log | head私はこれを得る

git log | head

error: Could not read 984c11abfc9c2839b386f29c574d9e03383fa589
fatal: Failed to traverse parents of commit 235ae1f48701d577d71ebd430344a159e5ba4881
commit 2fb0d2d0643b445440f01b164f11ee9ee71fca48
Author: christopher <christopher@christopher.christopher>
Date:   Wed Aug 7 15:51:42 2013 -0400

    finishing chapter 7

その他の質問はこちらをご覧ください./git/refs/heads/master。それは裸のレポであり、存在しますが、refs/heads/存在refs/heads/masterしません。ベアリポジトリのHEADはそう言ってref: refs/heads/masterいます。

packed-refsこれは言うけど

# pack-refs with: peeled
2fb0d2d0643b445440f01b164f11ee9ee71fca48 refs/heads/master

さらに他の質問が実行を示唆してgit reflogおり、それを実行しても出力が表示されません。

だから私は本当にここで何をすべきか分かりません。どのような戦略を取るべきですか?8 月 7 日にこの最後のコミットに頭をリセットすることは可能ですか?

agit logを実行して画面出力の下部に移動すると、次のようになります。

commit 996e03b949aea176238e3c7a8452700bbb987ac9
Author: christopher <christopher@christopher>
Date:   Wed Jul 3 23:00:44 2013 -0400

    many many changes
error: Could not read 984c11abfc9c2839b386f29c574d9e03383fa589
fatal: Failed to traverse parents of commit 235ae1f48701d577d71ebd430344a159e5ba4881

それが Git prune の動作を妨げているようです。

4

14 に答える 14

58

TL;DR

Git は、あなたが思っているような方法で履歴を保存するわけではありません。祖先チェーンに基づいて実行時に履歴を計算します。祖先にブロブ、ツリー、またはコミットがない場合、履歴を完全に回復できない可能性があります。

不足しているオブジェクトをバックアップから復元する

最初に試すことができるのは、不足しているアイテムをバックアップから復元することです。たとえば、として保存されているコミットのバックアップがあるかどうかを確認します.git/objects/98/4c11abfc9c2839b386f29c574d9e03383fa589。そうすれば元に戻せます。

また、コミットがすでに圧縮されていて、リポジトリ操作のためにルーズ オブジェクトに戻したい場合は、git-verify-packgit-unpack-objectsを調べることもできます。

外科的切除

不足しているアイテムをバックアップから置き換えることができない場合は、不足している履歴を削除できる場合があります。たとえば、履歴または reflog を調べて、コミット 984c11abfc9c2839b386f29c574d9e03383fa589 の祖先を見つけることができます。無傷のものが見つかった場合は、次のようにします。

  1. Git 作業ディレクトリを一時ディレクトリにコピーします。
  2. 破損していないコミットにハード リセットを実行します。
  3. 現在のファイルを Git 作業ツリーにコピーして戻しますが、.git フォルダーをコピーして戻さないでください。
  4. 現在の作業ツリーをコミットし、不足しているすべての履歴の押しつぶされたコミットとして扱うように最善を尽くします。

それが機能する場合、もちろん、介在する履歴は失われます。この時点で、作業履歴ログがある場合は、到達不能なすべてのコミットとオブジェクトの履歴と reflog を整理することをお勧めします。

完全な復元と再初期化

リポジトリがまだ破損している場合は、復元できる破損していないバックアップまたはクローンがあることを願っています。そうでない場合でも、現在の作業ディレクトリに有効なファイルが含まれている場合は、いつでも Git を再初期化できます。例えば:

rm -rf .git
git init
git add .
git commit -m 'Re-initialize repository without old history.'

これは劇的ですが、リポジトリの履歴が完全に回復できない場合は、これが唯一の選択肢になる可能性があります。YMMV。

于 2013-09-08T18:31:32.913 に答える
6

最近、 Ubuntu 18.04.3 (Bionic Beaver)で Git バージョン 2.7.1 を使用して同様の問題が発生しました。これが私がした方法です:

sudo apt install git-repair
git-repair  # Fix a broken Git repository
or
git-repair --force  # Force repair, even if data is lost
git fsck  # To verify it was fixed

ほとんどの場合、回復プロセスは成功しました。

于 2019-12-18T07:20:55.470 に答える
3

絶望的な場合は、これを試すことができます:

git clone ssh://me@my.git.server/path/to/project destination --depth=1

データは取得されますが、履歴は失われます。私は自分のレポで試行錯誤を繰り返して--depth=10作業しましたが、--depth=50失敗しました。

于 2015-03-27T14:24:51.700 に答える