* [PATCH] Create 'git gc' to perform common maintenance operations.
@ 2006-12-27 7:05 Shawn O. Pearce
2006-12-27 7:12 ` Linus Torvalds
0 siblings, 1 reply; 10+ messages in thread
From: Shawn O. Pearce @ 2006-12-27 7:05 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
Junio asked for a 'git gc' utility which users can execute on a
regular basis to perform basic repository actions such as:
* prune
* repack -a -d
* reflog expire
* rerere gc
* pack-refs --prune
So here is a command which does exactly that. The parameters fed
to reflog's expire subcommand can be chosen by the user by setting
configuration options in .git/config (or ~/.gitconfig), as users may
want different expiration windows for each repository but shouldn't
be bothered to remember what they are all of the time.
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
---
.gitignore | 1 +
Documentation/git-gc.txt | 55 ++++++++++++++++++++++++++++++++++++++++++++++
Makefile | 2 +-
git-gc.sh | 30 +++++++++++++++++++++++++
4 files changed, 87 insertions(+), 1 deletions(-)
diff --git a/.gitignore b/.gitignore
index 91e6966..f92e359 100644
--- a/.gitignore
+++ b/.gitignore
@@ -41,6 +41,7 @@ git-fmt-merge-msg
git-for-each-ref
git-format-patch
git-fsck-objects
+git-gc
git-get-tar-commit-id
git-grep
git-hash-object
diff --git a/Documentation/git-gc.txt b/Documentation/git-gc.txt
new file mode 100644
index 0000000..a494b1f
--- /dev/null
+++ b/Documentation/git-gc.txt
@@ -0,0 +1,55 @@
+git-gc(1)
+===========
+
+NAME
+----
+git-gc - Cleanup unnecessary files and optimize the local repository.
+
+
+SYNOPSIS
+--------
+'git-gc'
+
+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 gitlink:git-add[1].
+
+Users are encouraged to run this task on a regular basis within
+each repository to maintain good disk space utilization and good
+operating performance.
+
+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 occuring. Since these changes
+are not part of the current project most users will want to expire
+them sooner. This option defaults to '60 days'.
+
+See Also
+--------
+gitlink:git-prune[1]
+gitlink:git-repack[1]
+gitlink:git-rerere[1]
+
+Author
+------
+Written by Shawn O. Pearce <spearce@spearce.org>
+
+GIT
+---
+Part of the gitlink:git[7] suite
+
diff --git a/Makefile b/Makefile
index b8b746f..fb6ba27 100644
--- a/Makefile
+++ b/Makefile
@@ -157,7 +157,7 @@ BASIC_LDFLAGS =
SCRIPT_SH = \
git-bisect.sh git-checkout.sh \
git-clean.sh git-clone.sh git-commit.sh \
- git-fetch.sh \
+ git-fetch.sh git-gc.sh \
git-ls-remote.sh \
git-merge-one-file.sh git-parse-remote.sh \
git-pull.sh git-rebase.sh \
diff --git a/git-gc.sh b/git-gc.sh
new file mode 100644
index 0000000..cb70412
--- /dev/null
+++ b/git-gc.sh
@@ -0,0 +1,30 @@
+#!/bin/sh
+#
+# Copyright (c) 2006, Shawn O. Pearce
+#
+# Cleanup unreachable files and optimize the repository.
+
+USAGE=''
+SUBDIRECTORY_OK=Yes
+. git-sh-setup
+
+reflog_expire=$(git-repo-config gc.reflogExpire)
+if [ -z "$reflog_expire" ]
+then
+ reflog_expire="90 days"
+fi
+
+reflog_unreachable=$(git-repo-config gc.reflogExpireUnreachable)
+if [ -z "$reflog_unreachable" ]
+then
+ reflog_unreachable="60 days"
+fi
+
+git-pack-refs --prune &&
+git-reflog expire \
+ --expire="$reflog_expire" \
+ --expire-unreachable="$reflog_unreachable" \
+ --all &&
+git-prune &&
+git-repack -a -d &&
+git-rerere gc || exit
--
1.4.4.3.gd2e4
^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH] Create 'git gc' to perform common maintenance operations.
2006-12-27 7:05 [PATCH] Create 'git gc' to perform common maintenance operations Shawn O. Pearce
@ 2006-12-27 7:12 ` Linus Torvalds
0 siblings, 0 replies; 10+ messages in thread
From: Linus Torvalds @ 2006-12-27 7:12 UTC (permalink / raw)
To: Shawn O. Pearce; +Cc: Junio C Hamano, git
On Wed, 27 Dec 2006, Shawn O. Pearce wrote:
>
> Junio asked for a 'git gc' utility which users can execute on a
> regular basis to perform basic repository actions such as:
>
> * prune
> * repack -a -d
You should do "repack -a -d" _before_ pruning, because then pruning will
be much more efficient (thanks to a more efficient repo format).
Linus
^ permalink raw reply [flat|nested] 10+ messages in thread
* [PATCH] Create 'git gc' to perform common maintenance operations.
@ 2006-12-27 7:17 Shawn O. Pearce
2006-12-27 7:46 ` Junio C Hamano
2006-12-27 13:11 ` Martin Waitz
0 siblings, 2 replies; 10+ messages in thread
From: Shawn O. Pearce @ 2006-12-27 7:17 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
Junio asked for a 'git gc' utility which users can execute on a
regular basis to perform basic repository actions such as:
* pack-refs --prune
* reflog expire
* repack -a -d
* prune
* rerere gc
So here is a command which does exactly that. The parameters fed
to reflog's expire subcommand can be chosen by the user by setting
configuration options in .git/config (or ~/.gitconfig), as users may
want different expiration windows for each repository but shouldn't
be bothered to remember what they are all of the time.
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
---
This is a resend, as Linus pointed out prune runs faster if
its done after the repack and not before. Thanks Linus!
.gitignore | 1 +
Documentation/git-gc.txt | 55 ++++++++++++++++++++++++++++++++++++++++++++++
Makefile | 2 +-
git-gc.sh | 30 +++++++++++++++++++++++++
4 files changed, 87 insertions(+), 1 deletions(-)
diff --git a/.gitignore b/.gitignore
index 91e6966..f92e359 100644
--- a/.gitignore
+++ b/.gitignore
@@ -41,6 +41,7 @@ git-fmt-merge-msg
git-for-each-ref
git-format-patch
git-fsck-objects
+git-gc
git-get-tar-commit-id
git-grep
git-hash-object
diff --git a/Documentation/git-gc.txt b/Documentation/git-gc.txt
new file mode 100644
index 0000000..a494b1f
--- /dev/null
+++ b/Documentation/git-gc.txt
@@ -0,0 +1,55 @@
+git-gc(1)
+===========
+
+NAME
+----
+git-gc - Cleanup unnecessary files and optimize the local repository.
+
+
+SYNOPSIS
+--------
+'git-gc'
+
+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 gitlink:git-add[1].
+
+Users are encouraged to run this task on a regular basis within
+each repository to maintain good disk space utilization and good
+operating performance.
+
+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 occuring. Since these changes
+are not part of the current project most users will want to expire
+them sooner. This option defaults to '60 days'.
+
+See Also
+--------
+gitlink:git-prune[1]
+gitlink:git-repack[1]
+gitlink:git-rerere[1]
+
+Author
+------
+Written by Shawn O. Pearce <spearce@spearce.org>
+
+GIT
+---
+Part of the gitlink:git[7] suite
+
diff --git a/Makefile b/Makefile
index b8b746f..fb6ba27 100644
--- a/Makefile
+++ b/Makefile
@@ -157,7 +157,7 @@ BASIC_LDFLAGS =
SCRIPT_SH = \
git-bisect.sh git-checkout.sh \
git-clean.sh git-clone.sh git-commit.sh \
- git-fetch.sh \
+ git-fetch.sh git-gc.sh \
git-ls-remote.sh \
git-merge-one-file.sh git-parse-remote.sh \
git-pull.sh git-rebase.sh \
diff --git a/git-gc.sh b/git-gc.sh
new file mode 100755
index 0000000..8b1172b
--- /dev/null
+++ b/git-gc.sh
@@ -0,0 +1,30 @@
+#!/bin/sh
+#
+# Copyright (c) 2006, Shawn O. Pearce
+#
+# Cleanup unreachable files and optimize the repository.
+
+USAGE=''
+SUBDIRECTORY_OK=Yes
+. git-sh-setup
+
+reflog_expire=$(git-repo-config gc.reflogExpire)
+if [ -z "$reflog_expire" ]
+then
+ reflog_expire="90 days"
+fi
+
+reflog_unreachable=$(git-repo-config gc.reflogExpireUnreachable)
+if [ -z "$reflog_unreachable" ]
+then
+ reflog_unreachable="60 days"
+fi
+
+git-pack-refs --prune &&
+git-reflog expire \
+ --expire="$reflog_expire" \
+ --expire-unreachable="$reflog_unreachable" \
+ --all &&
+git-repack -a -d &&
+git-prune &&
+git-rerere gc || exit
--
1.4.4.3.gd2e4
^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH] Create 'git gc' to perform common maintenance operations.
2006-12-27 7:17 Shawn O. Pearce
@ 2006-12-27 7:46 ` Junio C Hamano
2006-12-27 7:53 ` Shawn Pearce
2006-12-27 13:11 ` Martin Waitz
1 sibling, 1 reply; 10+ messages in thread
From: Junio C Hamano @ 2006-12-27 7:46 UTC (permalink / raw)
To: Shawn O. Pearce; +Cc: git
"Shawn O. Pearce" <spearce@spearce.org> writes:
> +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 occuring. Since these changes
> +are not part of the current project most users will want to expire
> +them sooner. This option defaults to '60 days'.
Should I update the default expire-unreachable in builtin-reflog
to match 60 days?
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] Create 'git gc' to perform common maintenance operations.
2006-12-27 7:46 ` Junio C Hamano
@ 2006-12-27 7:53 ` Shawn Pearce
2006-12-27 8:26 ` Junio C Hamano
0 siblings, 1 reply; 10+ messages in thread
From: Shawn Pearce @ 2006-12-27 7:53 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
Junio C Hamano <junkio@cox.net> wrote:
> "Shawn O. Pearce" <spearce@spearce.org> writes:
>
> > +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 occuring. Since these changes
> > +are not part of the current project most users will want to expire
> > +them sooner. This option defaults to '60 days'.
>
> Should I update the default expire-unreachable in builtin-reflog
> to match 60 days?
Doh, I meant for git-gc to match the default in 'git-reflog expire'.
Whoops.
I don't care either way. 60 days may be too long for some users,
but for others it may be nice to have. I think the two defaults
should match just because. Feel free to edit my patch before
applying to be whatever 'git-reflog expire' uses if you want.
--
Shawn.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] Create 'git gc' to perform common maintenance operations.
2006-12-27 7:53 ` Shawn Pearce
@ 2006-12-27 8:26 ` Junio C Hamano
2006-12-27 8:33 ` Shawn Pearce
0 siblings, 1 reply; 10+ messages in thread
From: Junio C Hamano @ 2006-12-27 8:26 UTC (permalink / raw)
To: Shawn Pearce; +Cc: git
Shawn Pearce <spearce@spearce.org> writes:
> I don't care either way. 60 days may be too long for some users,
> but for others it may be nice to have. I think the two defaults
> should match just because. Feel free to edit my patch before
> applying to be whatever 'git-reflog expire' uses if you want.
I think the built-in git-reflog should be updated to honor the
configuration in the absense of command line options; if we do
that git-gc.sh does not even have to call repo-config anymore.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] Create 'git gc' to perform common maintenance operations.
2006-12-27 8:26 ` Junio C Hamano
@ 2006-12-27 8:33 ` Shawn Pearce
2006-12-27 9:10 ` Junio C Hamano
0 siblings, 1 reply; 10+ messages in thread
From: Shawn Pearce @ 2006-12-27 8:33 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
Junio C Hamano <junkio@cox.net> wrote:
> Shawn Pearce <spearce@spearce.org> writes:
>
> > I don't care either way. 60 days may be too long for some users,
> > but for others it may be nice to have. I think the two defaults
> > should match just because. Feel free to edit my patch before
> > applying to be whatever 'git-reflog expire' uses if you want.
>
> I think the built-in git-reflog should be updated to honor the
> configuration in the absense of command line options; if we do
> that git-gc.sh does not even have to call repo-config anymore.
Sure, but then maybe the configuration options shouldn't be
'gc.reflog*' but instead 'reflog.*'.
git-gc.sh was a quick hack while I was waiting for that huge disk
IO to repack a git.git with 1.3.3. I was trying to avoid hacking
C code for it, but you are probably right, better to just make the
C code do the right thing from "day one".
--
Shawn.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] Create 'git gc' to perform common maintenance operations.
2006-12-27 8:33 ` Shawn Pearce
@ 2006-12-27 9:10 ` Junio C Hamano
0 siblings, 0 replies; 10+ messages in thread
From: Junio C Hamano @ 2006-12-27 9:10 UTC (permalink / raw)
To: Shawn Pearce; +Cc: git
Shawn Pearce <spearce@spearce.org> writes:
> Junio C Hamano <junkio@cox.net> wrote:
>> Shawn Pearce <spearce@spearce.org> writes:
>>
>> > I don't care either way. 60 days may be too long for some users,
>> > but for others it may be nice to have. I think the two defaults
>> > should match just because. Feel free to edit my patch before
>> > applying to be whatever 'git-reflog expire' uses if you want.
>>
>> I think the built-in git-reflog should be updated to honor the
>> configuration in the absense of command line options; if we do
>> that git-gc.sh does not even have to call repo-config anymore.
>
> Sure, but then maybe the configuration options shouldn't be
> 'gc.reflog*' but instead 'reflog.*'.
Actually I think gc.reflog, gc.rerere and friends make more
sense. In other words, I think it is better to match the
configuration group to what the end user primarily sees, which
is "gc"; "reflog expire" and "rerere gc" are implementation
details of it.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] Create 'git gc' to perform common maintenance operations.
2006-12-27 7:17 Shawn O. Pearce
2006-12-27 7:46 ` Junio C Hamano
@ 2006-12-27 13:11 ` Martin Waitz
2006-12-27 18:46 ` Junio C Hamano
1 sibling, 1 reply; 10+ messages in thread
From: Martin Waitz @ 2006-12-27 13:11 UTC (permalink / raw)
To: Shawn O. Pearce; +Cc: Junio C Hamano, git
hoi :)
On Wed, Dec 27, 2006 at 02:17:59AM -0500, Shawn O. Pearce wrote:
> Junio asked for a 'git gc' utility which users can execute on a
> regular basis to perform basic repository actions such as:
>
> * pack-refs --prune
> * reflog expire
> * repack -a -d
what about doing "git-repack -a -d -l" by default?
--
Martin Waitz
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH] Create 'git gc' to perform common maintenance operations.
2006-12-27 13:11 ` Martin Waitz
@ 2006-12-27 18:46 ` Junio C Hamano
0 siblings, 0 replies; 10+ messages in thread
From: Junio C Hamano @ 2006-12-27 18:46 UTC (permalink / raw)
To: Martin Waitz; +Cc: Shawn O. Pearce, git
Martin Waitz <tali@admingilde.org> writes:
> On Wed, Dec 27, 2006 at 02:17:59AM -0500, Shawn O. Pearce wrote:
>> Junio asked for a 'git gc' utility which users can execute on a
>> regular basis to perform basic repository actions such as:
>>
>> * pack-refs --prune
>> * reflog expire
>> * repack -a -d
>
> what about doing "git-repack -a -d -l" by default?
I think that is sensible.
^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2006-12-27 18:46 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-12-27 7:05 [PATCH] Create 'git gc' to perform common maintenance operations Shawn O. Pearce
2006-12-27 7:12 ` Linus Torvalds
-- strict thread matches above, loose matches on Subject: below --
2006-12-27 7:17 Shawn O. Pearce
2006-12-27 7:46 ` Junio C Hamano
2006-12-27 7:53 ` Shawn Pearce
2006-12-27 8:26 ` Junio C Hamano
2006-12-27 8:33 ` Shawn Pearce
2006-12-27 9:10 ` Junio C Hamano
2006-12-27 13:11 ` Martin Waitz
2006-12-27 18:46 ` Junio C Hamano
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).