J'ai essayé de cloner mon référentiel que je garde sur mon dossier Ubuntu sur une nouvelle machine et j'ai obtenu ceci:
christopher@christopher-laptop:~/source/personal$ git clone ~/Ubuntu\ One\ Side\ Work/projects.git/
Cloning into 'projects'...
done.
fatal: unable to read tree 29a422c19251aeaeb907175e9b3219a9bed6c616
christopher@christopher-laptop:~/source/personal$
J'ai donc essayé de regarder les nombreuses autres questions comme celle-ci qui ont été posées ici et la plupart d'entre elles disent de courir git fsck --full
et puis j'obtiens ceci quand j'essaye cela.
christopher@christopher-laptop:~/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
Cela semble vraiment mauvais. Quand je fais un git log | head
je reçois ça
christopher@christopher-laptop:~/Ubuntu One Side Work/projects.git$ git log | head
error: Could not read 984c11abfc9c2839b386f29c574d9e03383fa589
fatal: Failed to traverse parents of commit 235ae1f48701d577d71ebd430344a159e5ba4881
commit 2fb0d2d0643b445440f01b164f11ee9ee71fca48
Author: christopher <[email protected]>
Date: Wed Aug 7 15:51:42 2013 -0400
finishing chapter 7
D'autres questions ici ont dit à regarder ./git/refs/heads/master
. C'est un repo nu et refs/heads/
existe mais refs/heads/master
pas. HEAD dans le repo nu dit ref: refs/heads/master
cependant
packed-refs
dit cela cependant
# pack-refs with: peeled
2fb0d2d0643b445440f01b164f11ee9ee71fca48 refs/heads/master
D'autres questions ont suggéré de courir git reflog
et aucune sortie n'apparaît lorsque je l'exécute.
Donc, je ne sais vraiment pas quoi faire ici. Quelle stratégie adopter? Est-il possible de réinitialiser head sur ce dernier commit le 7 août
ÉDITER:
Faire un journal git et aller au bas de la sortie de l'écran montre ceci:
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
Cela semble empêcher le git prune de fonctionner
git-repair
est un programme qui s'exécuteragit fsck
et essaiera très fort de résoudre les problèmes qu'il rencontre. git-repair.branchable.com Cela semble tout à fait capable, et bien que vous puissiez finir par devoir copier (si vous le pouvez!) des objets à partir d'une sauvegarde (vous avez une sauvegarde, non?), cela devrait vous faire gagner beaucoup de temps en récupérer tout ce qu'il peut et vous laisser le vrai travail, pas beaucoup de tâches automatisables. Aucune affiliation, etc.Réponses:
Comme alternative à la dernière option de CodeGnome, si seul le dépôt local est corrompu et que vous connaissez l'URL de la télécommande, vous pouvez l'utiliser pour réinitialiser votre
.git
pour qu'il corresponde à la télécommande (en remplaçant${url}
par l'URL distante):Cela laisse votre arbre de travail intact et n'affecte que la comptabilité de git.
J'ai aussi récemment créé un script bash à cette fin (Annexe A), qui englobe un peu de sécurité autour de cette opération.
Remarque:
Si votre dépôt a des sous-modules, ce processus les gâchera d'une manière ou d'une autre, et la seule solution que j'ai trouvée jusqu'à présent est de les supprimer puis de les utiliser
git submodule update --init
(ou de re-cloner le dépôt, mais cela semble trop drastique).Annexe A - Script complet
la source
.git
dossier après avoir fait cela. J'ai trouvé quegit reset origin/master --hard
c'était plus utile que--mixed
.TL; DR
Git ne stocke pas vraiment l'historique comme vous le pensez. Il calcule l' historique au moment de l'exécution sur la base d'une chaîne d'ancêtres. S'il manque des blobs, des arbres ou des validations à votre ascendance, vous ne pourrez peut-être pas récupérer complètement votre historique.
Restaurer les objets manquants à partir des sauvegardes
La première chose que vous pouvez essayer est de restaurer les éléments manquants de la sauvegarde. Par exemple, voyez si vous avez une sauvegarde de la validation stockée sous
.git/objects/98/4c11abfc9c2839b386f29c574d9e03383fa589
. Si c'est le cas, vous pouvez le restaurer.Vous pouvez également consulter les objets git-verify-pack et git-unpack-objects dans le cas où le commit a déjà été compressé et que vous souhaitez le renvoyer à un objet lâche à des fins de chirurgie du dépôt.
Résection chirurgicale
Si vous ne pouvez pas remplacer les éléments manquants d'une sauvegarde, vous pourrez peut-être supprimer l'historique manquant. Par exemple, vous pouvez examiner votre historique ou reflog pour trouver un ancêtre du commit 984c11abfc9c2839b386f29c574d9e03383fa589. Si vous en trouvez un intact, alors:
Si cela fonctionne, vous perdrez bien sûr l'histoire intermédiaire. À ce stade, si vous disposez d'un journal d'historique de travail, il est judicieux d'élaguer votre historique et les reflogs de tous les commits et objets inaccessibles.
Restaurations complètes et réinitialisation
Si votre référentiel est toujours cassé, nous espérons que vous disposez d'une sauvegarde ou d'un clone non corrompu à partir de laquelle vous pouvez restaurer. Sinon, mais votre répertoire de travail actuel contient des fichiers valides, vous pouvez toujours réinitialiser Git. Par exemple:
C'est drastique, mais cela peut être votre seule option si l'historique de votre référentiel est vraiment irrécupérable. YMMV.
la source
error: Could not read abcde
Mon dépôt est géré par GitLab et il créait des fichiers que mon utilisateur ne pouvait pas lire. Unsudo chown
plus tard et j'étais prêt à partir.Si vous avez une télécommande configurée et que vous avez / ne vous souciez pas de perdre du code non poussé, vous pouvez faire:
la source
fatal: pack has 13 unresolved deltas
.Voici un script (bash) pour automatiser la première solution de @CodeGnome pour restaurer à partir d'une sauvegarde (exécutée à partir du niveau supérieur du dépôt corrompu). La sauvegarde n'a pas besoin d'être complète, elle n'a besoin que des objets manquants.
la source
Avant d'essayer l'un des correctifs décrits sur cette page, je vous conseillerais de faire une copie de votre dépôt et de travailler uniquement sur cette copie. Ensuite, à la fin, si vous pouvez le réparer, comparez-le avec l'original pour vous assurer que vous n'avez perdu aucun fichier lors du processus de réparation.
Une autre alternative qui a fonctionné pour moi était de réinitialiser la tête git et l'index à son état précédent en utilisant:
git reset --keep
Vous pouvez également faire la même chose manuellement en ouvrant l'interface graphique de Git et en sélectionnant chaque "Modifications par étapes" et en cliquant sur "Annuler la mise en scène". Lorsque tout n'est pas mis en scène, vous devriez maintenant pouvoir compresser votre base de données, vérifier votre base de données et valider.
J'ai également essayé les commandes suivantes mais elles n'ont pas fonctionné pour moi, mais elles pourraient vous convenir en fonction du problème exact que vous rencontrez:
Enfin, pour éviter ce problème de synchronisation qui endommage votre index git (ce qui peut arriver avec DropBox, SpiderOak ou tout autre disque cloud), vous pouvez effectuer les opérations suivantes:
.git
dossier en un seul fichier git "bundle" en utilisant :,git bundle create my_repo.git --all
alors cela devrait fonctionner comme avant, mais comme tout est dans un seul fichier, vous ne risquez plus que la synchronisation endommage votre dépôt git.la source
Si vous êtes désespéré, vous pouvez essayer ceci:
Il obtiendra vos données, mais vous perdrez l'historique. Je suis allé avec essais et erreurs sur mon repo et j'ai
--depth=10
travaillé, mais--depth=50
j'ai échoué.la source
J'ai essayé de déplacer les fichiers objets avec 0 octet et de les récupérer à nouveau à partir de la télécommande, et cela a fonctionné:
Il a récupéré les objets manquants de la télécommande et m'a permis de continuer à travailler sans réinitialiser l'ensemble du dépôt.
la source
J'étais confronté au même problème, j'ai donc remplacé le dossier ".git" par une version sauvegardée et cela ne fonctionnait toujours pas car le fichier .gitconfig était corrompu. Le BSOD sur mon ordinateur portable l'a corrompu. Je l'ai remplacé par le code suivant et sourcetree a restauré tous mes référentiels.
Je ne sais pas si cela aidera quelqu'un, mais ce n'est qu'une autre solution qui a fonctionné pour moi.
la source
Supprimer l'index et réinitialiser
la source
J'ai rencontré des problèmes similaires en utilisant la version 2.7.1 de git sous Ubuntu 18.04.3 récemment. Voici comment j'ai fait:
La plupart du temps, le processus de récupération a réussi
la source
Dans mon cas, je créais le référentiel à partir du code source déjà dans mon PC et cette erreur est apparue. J'ai supprimé le dossier .git et tout fait à nouveau et cela a fonctionné :)
la source
Je voulais ajouter ceci en commentaire sous la réponse géniale de Zoey Hewil ci-dessus, mais je n'ai actuellement pas assez de représentants pour le faire, je dois donc l'ajouter ici et donner du crédit pour son travail: P
Si vous utilisez Poshgit et que vous vous sentez exceptionnellement paresseux, vous pouvez utiliser ce qui suit pour extraire automatiquement votre URL de votre configuration git et rendre le travail encore plus facile. Les mises en garde standard s'appliquent au sujet du test sur une copie / sauvegarde de votre dépôt local en premier au cas où il vous exploserait au visage.
la source
Un moyen rapide si vous avez des modifications sur votre projet actuel et que vous ne voulez pas les perdre, déplacez votre projet actuel quelque part, clonez le projet de github vers ce dossier et effectuez des modifications et essayez à nouveau de valider. Ou supprimez simplement le dépôt et clonez-le à nouveau, cela a fonctionné pour moi.
la source
Cette commande a fonctionné pour moi:
la source