136 lines
4.4 KiB
136 lines
4.4 KiB
git-repack(1) |
|
============= |
|
|
|
NAME |
|
---- |
|
git-repack - Pack unpacked objects in a repository |
|
|
|
|
|
SYNOPSIS |
|
-------- |
|
'git repack' [-a] [-A] [-d] [-f] [-l] [-n] [-q] [--window=N] [--depth=N] |
|
|
|
DESCRIPTION |
|
----------- |
|
|
|
This script is used to combine all objects that do not currently |
|
reside in a "pack", into a pack. It can also be used to re-organize |
|
existing packs into a single, more efficient pack. |
|
|
|
A pack is a collection of objects, individually compressed, with |
|
delta compression applied, stored in a single file, with an |
|
associated index file. |
|
|
|
Packs are used to reduce the load on mirror systems, backup |
|
engines, disk storage, etc. |
|
|
|
OPTIONS |
|
------- |
|
|
|
-a:: |
|
Instead of incrementally packing the unpacked objects, |
|
pack everything referenced into a single pack. |
|
Especially useful when packing a repository that is used |
|
for private development. Use |
|
with '-d'. This will clean up the objects that `git prune` |
|
leaves behind, but `git fsck --full` shows as |
|
dangling. |
|
+ |
|
Note that users fetching over dumb protocols will have to fetch the |
|
whole new pack in order to get any contained object, no matter how many |
|
other objects in that pack they already have locally. |
|
|
|
-A:: |
|
Same as `-a`, unless '-d' is used. Then any unreachable |
|
objects in a previous pack become loose, unpacked objects, |
|
instead of being left in the old pack. Unreachable objects |
|
are never intentionally added to a pack, even when repacking. |
|
This option prevents unreachable objects from being immediately |
|
deleted by way of being left in the old pack and then |
|
removed. Instead, the loose unreachable objects |
|
will be pruned according to normal expiry rules |
|
with the next 'git-gc' invocation. See linkgit:git-gc[1]. |
|
|
|
-d:: |
|
After packing, if the newly created packs make some |
|
existing packs redundant, remove the redundant packs. |
|
Also run 'git-prune-packed' to remove redundant |
|
loose object files. |
|
|
|
-l:: |
|
Pass the `--local` option to 'git-pack-objects'. See |
|
linkgit:git-pack-objects[1]. |
|
|
|
-f:: |
|
Pass the `--no-reuse-object` option to `git-pack-objects`, see |
|
linkgit:git-pack-objects[1]. |
|
|
|
-q:: |
|
Pass the `-q` option to 'git-pack-objects'. See |
|
linkgit:git-pack-objects[1]. |
|
|
|
-n:: |
|
Do not update the server information with |
|
'git-update-server-info'. This option skips |
|
updating local catalog files needed to publish |
|
this repository (or a direct copy of it) |
|
over HTTP or FTP. See linkgit:git-update-server-info[1]. |
|
|
|
--window=[N]:: |
|
--depth=[N]:: |
|
These two options affect how the objects contained in the pack are |
|
stored using delta compression. The objects are first internally |
|
sorted by type, size and optionally names and compared against the |
|
other objects within `--window` to see if using delta compression saves |
|
space. `--depth` limits the maximum delta depth; making it too deep |
|
affects the performance on the unpacker side, because delta data needs |
|
to be applied that many times to get to the necessary object. |
|
The default value for --window is 10 and --depth is 50. |
|
|
|
--window-memory=[N]:: |
|
This option provides an additional limit on top of `--window`; |
|
the window size will dynamically scale down so as to not take |
|
up more than N bytes in memory. This is useful in |
|
repositories with a mix of large and small objects to not run |
|
out of memory with a large window, but still be able to take |
|
advantage of the large window for the smaller objects. The |
|
size can be suffixed with "k", "m", or "g". |
|
`--window-memory=0` makes memory usage unlimited, which is the |
|
default. |
|
|
|
--max-pack-size=<n>:: |
|
Maximum size of each output packfile, expressed in MiB. |
|
If specified, multiple packfiles may be created. |
|
The default is unlimited. |
|
|
|
|
|
Configuration |
|
------------- |
|
|
|
When configuration variable `repack.UseDeltaBaseOffset` is set |
|
for the repository, the command passes `--delta-base-offset` |
|
option to 'git-pack-objects'; this typically results in slightly |
|
smaller packs, but the generated packs are incompatible with |
|
versions of git older than (and including) v1.4.3; do not set |
|
the variable in a repository that older version of git needs to |
|
be able to read (this includes repositories from which packs can |
|
be copied out over http or rsync, and people who obtained packs |
|
that way can try to use older git with it). |
|
|
|
|
|
Author |
|
------ |
|
Written by Linus Torvalds <torvalds@osdl.org> |
|
|
|
Documentation |
|
-------------- |
|
Documentation by Ryan Anderson <ryan@michonline.com> |
|
|
|
SEE ALSO |
|
-------- |
|
linkgit:git-pack-objects[1] |
|
linkgit:git-prune-packed[1] |
|
|
|
GIT |
|
--- |
|
Part of the linkgit:git[1] suite
|
|
|