Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to remove local git history after a commit?

I would like to switch from Dropbox to the open source Sparkleshare. It uses git for the syncing and versioning. If say I had a 1GB file I deleted in my folder, it stays within the history of the local .git folder. But I would like to have this kind of heavy data on the server and not the client. How can I commit my repository and delete the local one with git? Many thanks!

like image 319
user376244 Avatar asked Mar 22 '12 09:03

user376244


2 Answers

Solution removing the history

  1. git fetch --depth=1 to prune the old commits. This makes the old commits and their objects unreachable.
  2. git reflog expire --expire-unreachable=now --all. To expire all old commits and their objects
  3. git gc --aggressive --prune=all to remove the old objects

Specific solution just to remove the large file in the local history

  • GitHub offer's Git Large File Storage, which stores large files always on the server and fetches them only on checkouts. Very easy to setup and use - in case your repository is on GitHub, bitbucket, or gitlab.
  • git-annex - allows storing big files anywhere

Discussion: How do Git LFS and git-annex differ?

like image 108
koppor Avatar answered Oct 23 '22 09:10

koppor


Based on koppor's answer, I created this single line bash command to clear the local git history from all repositories which are in the same base folder:

for d in */; do echo $d && cd "$d" && git fetch --depth=1 && git reflog expire --expire-unreachable=now --all && git gc --aggressive --prune=all; cd ..; done

Note: you can replace */ by any specific folder criteria if you wish, such as *mobile*/ .

Windows cmd version (untested):

FOR /D %d IN (*) DO (echo $d && cd "$d" && git fetch --depth=1 && git reflog expire --expire-unreachable=now --all && git gc --aggressive --prune=all & cd ..)

This has saved me a few gigabytes !

like image 1
Murilo Perrone Avatar answered Oct 23 '22 11:10

Murilo Perrone