cannot fetch arm git tree
Russell King - ARM Linux
linux at arm.linux.org.uk
Sun Jan 16 08:42:48 EST 2011
On Sun, Jan 16, 2011 at 09:10:17PM +0800, Jello huang wrote:
> yes,git doesn't handle that case and i rename the pack name,but there is
> also the similar error.Now i just delet the git tree and clone it again
> tonight .
_Always_ without fail fetch Linus' tree before pulling my tree.
My tree is a rsync clone of the objects and pack files in Linus' tree,
plus whatever git decided to build on top of that - for local commits
that's individual object files. For remote pulls, that's probably a few
small pack files.
There is *no* repacking of my tree. So the only times it gets 'repacked'
is when Linus repacks his tree.
Let's say you already have a copy of my tree from a month ago, and Linus
has pulled some work from me into his tree, and repacked his tree into one
single pack file. At the moment, the largest pack file from Linus is
400MB plus a 50MB index.
You already have most of the contents of that 400MB pack file, but if
you're missing even _one_ object which is contained within it, git will
have to download the _entire_ 400MB pack file and index file to retrieve
it.
However, if you first fetch Linus' tree via the git protocol, it can just
request the objects it doesn't have from the git server. That will mean
you'll have all the objects in the large pack files before you start trying
to pull my tree, and git won't have to download 400MB for the sake of
retrieving just maybe 10k that you didn't have.
This isn't something special with my tree - it's a side effect of the
http protocol git uses. So, before you fetch _any_ http-based git tree,
first make sure you're up to date with Linus'.
(I update my tree from Linus' in rsync mode to make http-based stuff a
lot more friendly to people using it - some of whom are stuck behind
firewalls which can only do http. Fetching a constantly repacked git
tree via http results in hundreds of megabytes needing to be fetched
every time.)
So please, whenever possible, always fetch Linus' latest tree _first_
and then mine. Same goes for any other http based tree which doesn't
auto-repack.
More information about the linux-arm-kernel
mailing list