From: Neal Kreitzinger <nkreitzinger@gmail.com>
To: Jeff King <peff@peff.net>
Cc: Shawn Pearce <spearce@spearce.org>,
Neal Kreitzinger <neal@rsss.com>,
git@vger.kernel.org
Subject: Re: concurrent fetches to update same mirror
Date: Wed, 05 Jan 2011 16:42:49 -0600 [thread overview]
Message-ID: <4D24F3E9.3070904@gmail.com> (raw)
In-Reply-To: <20110105211313.GB7808@sigill.intra.peff.net>
On 1/5/2011 3:13 PM, Jeff King wrote:
> On Wed, Jan 05, 2011 at 03:53:25PM -0500, Jeff King wrote:
>
>>> If both fetch processes try to update the same ref at the same time,
>>> one will get the lock and continue, and the other will crash with an
>>> error (because the lock was busy). If one is slightly slower than the
>>> other, they will probably update the refs twice, with the slower fetch
>>> updating what the faster one had just updated. :-)
>>
>> I assumed it would take the "old" value at the very beginning of the
>> fetch (before talking with the remote), and then see that the ref was
>> changed under our feet. Or does it simply do it at the end?
>
> Hmm. Weirder even, builtin/fetch.c:s_update_ref takes a "check_old"
> flag, and we do always use it for branch updates. But not for tag
> updates. I can't think of why. The code blames all the way back to the
> original builtin-fetch.
>
> Anyway, when we do check, we check the value from the beginning of the
> fetch. So you can get lock conflicts. For example, doing this:
>
> mkdir repo&& cd repo&& git init
> echo contents>foo&& git add .&& git commit -m one
> git update-ref refs/remotes/origin/master refs/heads/master
> git remote add origin some-remote-repo-that-takes-a-few-seconds
> xterm -e 'git fetch -v; read'& xterm -e 'git fetch -v; read'
>
> I.e., putting some cruft into the ref and then updating it. One fetch
> will force-write over the ref properly:
>
> + ac32203...4e64590 master -> origin/master (forced update)
>
> but the other one will barf on the lock:
>
> error: Ref refs/remotes/origin/master is at 4e6459052ab329914c7712a926773e566b8c821d but expected ac32203727daa3bcb5fc041786aa45adbbe86299
> ...
> ! ac32203...4e64590 master -> origin/master (unable to update local ref)
>
> Interestingly, in the case of ref _creation_, not update, like this:
>
> mkdir repo&& cd repo&& git init
> git remote add origin some-remote-repo-that-takes-a-few-seconds
> xterm -e 'git fetch -v; read'& xterm -e 'git fetch -v; read'
>
> then both will happily update, the second one overwriting the results of
> the first. It seems in the case of locking a ref which previously didn't
> exist, we don't enforce that it still doesn't exist.
>
> I wonder if we should, but perhaps there is some corner case I am not
> considering. The code is in lock_ref_sha1_basic, but blaming didn't turn
> up anything helpful.
>
> -Peff
In the case of concurrent pulls to the same non-bare repo, could the
working tree or index get corrupted, or does git have concurrency
control mechanisms for this too?
v/r,
Neal
next prev parent reply other threads:[~2011-01-05 22:43 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-01-05 20:33 concurrent fetches to update same mirror Neal Kreitzinger
2011-01-05 20:47 ` Jeff King
2011-01-05 20:51 ` Shawn Pearce
2011-01-05 20:53 ` Jeff King
2011-01-05 21:13 ` Jeff King
2011-01-05 22:34 ` Neal Kreitzinger
2011-01-05 22:42 ` Neal Kreitzinger [this message]
2011-01-05 22:57 ` Jeff King
2011-01-05 23:29 ` Junio C Hamano
2011-01-06 23:45 ` Jeff King
2011-01-07 14:50 ` Marc Branchaud
2011-01-07 14:51 ` Marc Branchaud
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4D24F3E9.3070904@gmail.com \
--to=nkreitzinger@gmail.com \
--cc=git@vger.kernel.org \
--cc=neal@rsss.com \
--cc=peff@peff.net \
--cc=spearce@spearce.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).