| git-gc(1) |
| ========= |
| |
| NAME |
| ---- |
| git-gc - Cleanup unnecessary files and optimize the local repository |
| |
| |
| SYNOPSIS |
| -------- |
| [verse] |
| 'git gc' [--aggressive] [--auto] [--quiet] [--prune=<date> | --no-prune] [--force] |
| |
| DESCRIPTION |
| ----------- |
| Runs a number of housekeeping tasks within the current repository, |
| such as compressing file revisions (to reduce disk space and increase |
| performance) and removing unreachable objects which may have been |
| created from prior invocations of 'git add'. |
| |
| Users are encouraged to run this task on a regular basis within |
| each repository to maintain good disk space utilization and good |
| operating performance. |
| |
| Some git commands may automatically run 'git gc'; see the `--auto` flag |
| below for details. If you know what you're doing and all you want is to |
| disable this behavior permanently without further considerations, just do: |
| |
| ---------------------- |
| $ git config --global gc.auto 0 |
| ---------------------- |
| |
| OPTIONS |
| ------- |
| |
| --aggressive:: |
| Usually 'git gc' runs very quickly while providing good disk |
| space utilization and performance. This option will cause |
| 'git gc' to more aggressively optimize the repository at the expense |
| of taking much more time. The effects of this optimization are |
| persistent, so this option only needs to be used occasionally; every |
| few hundred changesets or so. |
| |
| --auto:: |
| With this option, 'git gc' checks whether any housekeeping is |
| required; if not, it exits without performing any work. |
| Some git commands run `git gc --auto` after performing |
| operations that could create many loose objects. |
| + |
| Housekeeping is required if there are too many loose objects or |
| too many packs in the repository. If the number of loose objects |
| exceeds the value of the `gc.auto` configuration variable, then |
| all loose objects are combined into a single pack using |
| `git repack -d -l`. Setting the value of `gc.auto` to 0 |
| disables automatic packing of loose objects. |
| + |
| If the number of packs exceeds the value of `gc.autoPackLimit`, |
| then existing packs (except those marked with a `.keep` file) |
| are consolidated into a single pack by using the `-A` option of |
| 'git repack'. Setting `gc.autoPackLimit` to 0 disables |
| automatic consolidation of packs. |
| |
| --prune=<date>:: |
| Prune loose objects older than date (default is 2 weeks ago, |
| overridable by the config variable `gc.pruneExpire`). |
| --prune=all prunes loose objects regardless of their age (do |
| not use --prune=all unless you know exactly what you are doing. |
| Unless the repository is quiescent, you will lose newly created |
| objects that haven't been anchored with the refs and end up |
| corrupting your repository). --prune is on by default. |
| |
| --no-prune:: |
| Do not prune any loose objects. |
| |
| --quiet:: |
| Suppress all progress reports. |
| |
| --force:: |
| Force `git gc` to run even if there may be another `git gc` |
| instance running on this repository. |
| |
| Configuration |
| ------------- |
| |
| The optional configuration variable `gc.reflogExpire` can be |
| set to indicate how long historical entries within each branch's |
| reflog should remain available in this repository. The setting is |
| expressed as a length of time, for example '90 days' or '3 months'. |
| It defaults to '90 days'. |
| |
| The optional configuration variable `gc.reflogExpireUnreachable` |
| can be set to indicate how long historical reflog entries which |
| are not part of the current branch should remain available in |
| this repository. These types of entries are generally created as |
| a result of using `git commit --amend` or `git rebase` and are the |
| commits prior to the amend or rebase occurring. Since these changes |
| are not part of the current project most users will want to expire |
| them sooner. This option defaults to '30 days'. |
| |
| The above two configuration variables can be given to a pattern. For |
| example, this sets non-default expiry values only to remote-tracking |
| branches: |
| |
| ------------ |
| [gc "refs/remotes/*"] |
| reflogExpire = never |
| reflogExpireUnreachable = 3 days |
| ------------ |
| |
| The optional configuration variable `gc.rerereResolved` indicates |
| how long records of conflicted merge you resolved earlier are |
| kept. This defaults to 60 days. |
| |
| The optional configuration variable `gc.rerereUnresolved` indicates |
| how long records of conflicted merge you have not resolved are |
| kept. This defaults to 15 days. |
| |
| The optional configuration variable `gc.packRefs` determines if |
| 'git gc' runs 'git pack-refs'. This can be set to "notbare" to enable |
| it within all non-bare repos or it can be set to a boolean value. |
| This defaults to true. |
| |
| The optional configuration variable `gc.aggressiveWindow` controls how |
| much time is spent optimizing the delta compression of the objects in |
| the repository when the --aggressive option is specified. The larger |
| the value, the more time is spent optimizing the delta compression. See |
| the documentation for the --window' option in linkgit:git-repack[1] for |
| more details. This defaults to 250. |
| |
| Similarly, the optional configuration variable `gc.aggressiveDepth` |
| controls --depth option in linkgit:git-repack[1]. This defaults to 250. |
| |
| The optional configuration variable `gc.pruneExpire` controls how old |
| the unreferenced loose objects have to be before they are pruned. The |
| default is "2 weeks ago". |
| |
| |
| Notes |
| ----- |
| |
| 'git gc' tries very hard to be safe about the garbage it collects. In |
| particular, it will keep not only objects referenced by your current set |
| of branches and tags, but also objects referenced by the index, |
| remote-tracking branches, refs saved by 'git filter-branch' in |
| refs/original/, or reflogs (which may reference commits in branches |
| that were later amended or rewound). |
| |
| If you are expecting some objects to be collected and they aren't, check |
| all of those locations and decide whether it makes sense in your case to |
| remove those references. |
| |
| HOOKS |
| ----- |
| |
| The 'git gc --auto' command will run the 'pre-auto-gc' hook. See |
| linkgit:githooks[5] for more information. |
| |
| |
| SEE ALSO |
| -------- |
| linkgit:git-prune[1] |
| linkgit:git-reflog[1] |
| linkgit:git-repack[1] |
| linkgit:git-rerere[1] |
| |
| GIT |
| --- |
| Part of the linkgit:git[1] suite |