Ich habe versehentlich eine riesige Binärdatei hinzugefügt, festgeschrieben und mit meinem neuesten Commit in ein Git-Repository verschoben.
Wie kann ich Git veranlassen, die Objekte zu entfernen, die für dieses Commit erstellt wurden / wurden, damit mein .git
Verzeichnis wieder auf eine normale Größe verkleinert wird?
Edit : Danke für deine Antworten; Ich habe verschiedene Lösungen ausprobiert. Keiner hat funktioniert. Zum Beispiel hat der von GitHub die Dateien aus dem Verlauf entfernt, aber die .git
Verzeichnisgröße hat sich nicht verringert:
$ BADFILES=$(find test_data -type f -exec echo -n "'{}' " \;)
$ git filter-branch --index-filter "git rm -rf --cached --ignore-unmatch $BADFILES" HEAD
Rewrite 14ed3f41474f0a2f624a440e5a106c2768edb67b (66/66)
rm 'test_data/images/001.jpg'
[...snip...]
rm 'test_data/images/281.jpg'
Ref 'refs/heads/master' was rewritten
$ git log -p # looks nice
$ rm -rf .git/refs/original/
$ git reflog expire --all
$ git gc --aggressive --prune
Counting objects: 625, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (598/598), done.
Writing objects: 100% (625/625), done.
Total 625 (delta 351), reused 0 (delta 0)
$ du -hs .git
174M .git
$ # still 175 MB :-(
git-repack -a
gefolgt von git-prune-packed
zum Beispiel. Siehe blog.felipebalbi.com/2007/12/19/…
filter-branch
, gc
, repack
, ...), nein, Sie sollten nicht schlecht sehen überhaupt begehen. Dies ist ein Zeichen dafür, dass die Reinigung nicht wie erwartet stattgefunden hat.