From looking at what the importer plugin is doing, I get the impression that the problem is not that this method hangs a long time on one call. It is just that the importer deletes (one by one) a
few thousand refs, and calls this method for every single one. As there is a sleep in here, the chance to see this method in any stack dump is just very high
J…
Cheers,
Markus
From: Duft Markus
Sent: Friday, September 15, 2017 1:51 PM
To: 'Sohn, Matthias' <matthias.sohn@xxxxxxx>; JGit Developers list (jgit-dev@xxxxxxxxxxx) <jgit-dev@xxxxxxxxxxx>
Subject: RE: [jgit-dev] Hang in LockFile#waitForStatChange
Hey,
-rw-r--r-- 1 mduft salomon 125956 Sep 14 08:40 packed-refs
There are about 2000 refs in there (many refs/changes/xxx from gerrit of course), so it’s not exactly large – other repos here have 80000+ refs :D
Cheers,
Markus
So your filesystem has a timer resolution of 1 hour :-?
How large is that packed-refs file ?
Hi,
Thanks. It turns out that it did finish. After like one hour or more…
J
Cheers,
Markus
See line 432 in
https://git.eclipse.org/r/plugins/gitiles/jgit/jgit/+/master/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/LockFile.java#416
The thread waits for a lockfile to see the modification time of the packed-ref’s file advance
by one tick of the clock with the resolution of the filesystem’s timestamps. It’s saving the
locked file in a loop with a 25ms sleep until the modification timestamp increases by at least one tick.
This shouldn’t take 5 minutes.
This is done to prevent issues regarding “racy git” problem caused by granularity of timer resolution
https://github.com/git/git/blob/master/Documentation/technical/racy-git.txt
Hey,
I observed this hang (over at least 5 minutes in the same frame – right now it looks like infinite) while testing the gerrit importer plugin:
"HTTP-91" #91 prio=5 os_prio=0 tid=0x00007f96ac020000 nid=0x575b waiting on condition [0x00007f97a87cf000]
java.lang.Thread.State: TIMED_WAITING (sleeping)
at java.lang.Thread.sleep(Native Method)
at org.eclipse.jgit.internal.storage.file.LockFile.waitForStatChange(LockFile.java:432)
at org.eclipse.jgit.internal.storage.file.RefDirectory$1.writeFile(RefDirectory.java:892)
at org.eclipse.jgit.lib.RefWriter.writePackedRefs(RefWriter.java:195)
at org.eclipse.jgit.internal.storage.file.RefDirectory.commitPackedRefs(RefDirectory.java:904)
at org.eclipse.jgit.internal.storage.file.RefDirectory.delete(RefDirectory.java:597)
at org.eclipse.jgit.internal.storage.file.RefDirectoryUpdate.doDelete(RefDirectoryUpdate.java:146)
at org.eclipse.jgit.lib.RefUpdate$2.execute(RefUpdate.java:571)
at org.eclipse.jgit.lib.RefUpdate.updateImpl(RefUpdate.java:653)
at org.eclipse.jgit.lib.RefUpdate.delete(RefUpdate.java:568)
at org.eclipse.jgit.lib.RefUpdate.delete(RefUpdate.java:540)
at com.googlesource.gerrit.plugins.importer.CompleteProjectImport.deleteImportRefs(CompleteProjectImport.java:99)
at com.googlesource.gerrit.plugins.importer.CompleteProjectImport.apply(CompleteProjectImport.java:68)
at com.googlesource.gerrit.plugins.importer.CompleteProjectImport.apply(CompleteProjectImport.java:1)
It seems rather unrelated to the actual plugin, and more in the JGit area. Reading the code it does not really make much sense that it is hanging there – any idea what this could mean?
Cheers,
Markus
--
Mit freundlichen Grüßen / Best regards
Markus Duft | Software Architect
SSI SCHÄFER | SSI Schäfer IT Solutions GmbH | Friesachstraße 15 | 8114 Friesach bei Graz | Austria
Phone +43 3127 200-575 | Fax +43 3127 200-22
markus.duft@xxxxxxxxxxxxxxxx
Website
| Blog |
YouTube |
Facebook
SSI Schäfer IT Solutions GmbH | Friesachstrasse 15 | 8114 Friesach | Austria
Registered Office: Friesach | Commercial Register: 49324 K | VAT no. ATU28654300
Commercial Court: Landesgericht für Zivilrechtssachen Graz
SSI Schäfer IT Solutions GmbH | Friesachstrasse 15 | 8114 Friesach | Austria
Registered Office: Friesach | Commercial Register: 49324 K | VAT no. ATU28654300
Commercial Court: Landesgericht für Zivilrechtssachen Graz