This causes cgit to serve error pages, which is undesirable. This reverts commit5229c9b232, reversing changes made tof2b211131f.
		
			
				
	
	
		
			162 lines
		
	
	
	
		
			5.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			162 lines
		
	
	
	
		
			5.6 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
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] [--keep-largest-pack]
 | 
						|
 | 
						|
DESCRIPTION
 | 
						|
-----------
 | 
						|
Runs a number of housekeeping tasks within the current repository,
 | 
						|
such as compressing file revisions (to reduce disk space and increase
 | 
						|
performance), removing unreachable objects which may have been
 | 
						|
created from prior invocations of 'git add', packing refs, pruning
 | 
						|
reflog, rerere metadata or stale working trees. May also update ancillary
 | 
						|
indexes such as the commit-graph.
 | 
						|
 | 
						|
When common porcelain operations that create objects are run, they
 | 
						|
will check whether the repository has grown substantially since the
 | 
						|
last maintenance, and if so run `git gc` automatically. See `gc.auto`
 | 
						|
below for how to disable this behavior.
 | 
						|
 | 
						|
Running `git gc` manually should only be needed when adding objects to
 | 
						|
a repository without regularly running such porcelain commands, to do
 | 
						|
a one-off repository optimization, or e.g. to clean up a suboptimal
 | 
						|
mass-import. See the "PACKFILE OPTIMIZATION" section in
 | 
						|
linkgit:git-fast-import[1] for more details on the import case.
 | 
						|
 | 
						|
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
 | 
						|
	mostly persistent. See the "AGGRESSIVE" section below for details.
 | 
						|
 | 
						|
--auto::
 | 
						|
	With this option, 'git gc' checks whether any housekeeping is
 | 
						|
	required; if not, it exits without performing any work.
 | 
						|
+
 | 
						|
See the `gc.auto` option in the "CONFIGURATION" section below for how
 | 
						|
this heuristic works.
 | 
						|
+
 | 
						|
Once housekeeping is triggered by exceeding the limits of
 | 
						|
configuration options such as `gc.auto` and `gc.autoPackLimit`, all
 | 
						|
other housekeeping tasks (e.g. rerere, working trees, reflog...) will
 | 
						|
be performed as well.
 | 
						|
 | 
						|
 | 
						|
--prune=<date>::
 | 
						|
	Prune loose objects older than date (default is 2 weeks ago,
 | 
						|
	overridable by the config variable `gc.pruneExpire`).
 | 
						|
	--prune=now prunes loose objects regardless of their age and
 | 
						|
	increases the risk of corruption if another process is writing to
 | 
						|
	the repository concurrently; see "NOTES" below. --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.
 | 
						|
 | 
						|
--keep-largest-pack::
 | 
						|
	All packs except the largest pack and those marked with a
 | 
						|
	`.keep` files are consolidated into a single pack. When this
 | 
						|
	option is used, `gc.bigPackThreshold` is ignored.
 | 
						|
 | 
						|
AGGRESSIVE
 | 
						|
----------
 | 
						|
 | 
						|
When the `--aggressive` option is supplied, linkgit:git-repack[1] will
 | 
						|
be invoked with the `-f` flag, which in turn will pass
 | 
						|
`--no-reuse-delta` to linkgit:git-pack-objects[1]. This will throw
 | 
						|
away any existing deltas and re-compute them, at the expense of
 | 
						|
spending much more time on the repacking.
 | 
						|
 | 
						|
The effects of this are mostly persistent, e.g. when packs and loose
 | 
						|
objects are coalesced into one another pack the existing deltas in
 | 
						|
that pack might get re-used, but there are also various cases where we
 | 
						|
might pick a sub-optimal delta from a newer pack instead.
 | 
						|
 | 
						|
Furthermore, supplying `--aggressive` will tweak the `--depth` and
 | 
						|
`--window` options passed to linkgit:git-repack[1]. See the
 | 
						|
`gc.aggressiveDepth` and `gc.aggressiveWindow` settings below. By
 | 
						|
using a larger window size we're more likely to find more optimal
 | 
						|
deltas.
 | 
						|
 | 
						|
It's probably not worth it to use this option on a given repository
 | 
						|
without running tailored performance benchmarks on it. It takes a lot
 | 
						|
more time, and the resulting space/delta optimization may or may not
 | 
						|
be worth it. Not using this at all is the right trade-off for most
 | 
						|
users and their repositories.
 | 
						|
 | 
						|
CONFIGURATION
 | 
						|
-------------
 | 
						|
 | 
						|
The below documentation is the same as what's found in
 | 
						|
linkgit:git-config[1]:
 | 
						|
 | 
						|
include::config/gc.txt[]
 | 
						|
 | 
						|
NOTES
 | 
						|
-----
 | 
						|
 | 
						|
'git gc' tries very hard not to delete objects that are referenced
 | 
						|
anywhere in your repository. 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/, reflogs (which may reference commits in branches
 | 
						|
that were later amended or rewound), and anything else in the refs/* namespace.
 | 
						|
If you are expecting some objects to be deleted and they aren't, check
 | 
						|
all of those locations and decide whether it makes sense in your case to
 | 
						|
remove those references.
 | 
						|
 | 
						|
On the other hand, when 'git gc' runs concurrently with another process,
 | 
						|
there is a risk of it deleting an object that the other process is using
 | 
						|
but hasn't created a reference to. This may just cause the other process
 | 
						|
to fail or may corrupt the repository if the other process later adds a
 | 
						|
reference to the deleted object. Git has two features that significantly
 | 
						|
mitigate this problem:
 | 
						|
 | 
						|
. Any object with modification time newer than the `--prune` date is kept,
 | 
						|
  along with everything reachable from it.
 | 
						|
 | 
						|
. Most operations that add an object to the database update the
 | 
						|
  modification time of the object if it is already present so that #1
 | 
						|
  applies.
 | 
						|
 | 
						|
However, these features fall short of a complete solution, so users who
 | 
						|
run commands concurrently have to live with some risk of corruption (which
 | 
						|
seems to be low in practice).
 | 
						|
 | 
						|
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
 |