11

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!

user376244
  • 331
  • 2
  • 4
  • 9

3 Answers3

28

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?

koppor
  • 19,079
  • 15
  • 119
  • 161
3

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 !

Murilo Perrone
  • 452
  • 4
  • 7
0

Add the below commands in cmd or sh file and should help in clearing the history git fetch --depth=1 to prune the old commits. This makes the old commits and their objects unreachable. git reflog expire --expire-unreachable=now --all. To expire all old commits and their objects git gc --aggressive --prune=all to remove the old objects