diff options
author | Dariusz Luksza <dariusz.luksza@gmail.com> | 2023-11-20 11:53:19 +0000 |
---|---|---|
committer | Dariusz Ćuksza <dariusz.luksza@gmail.com> | 2024-01-28 17:54:36 +0000 |
commit | c701c01b49d92993f1c3df0a0e26a2dd68b8cec1 (patch) | |
tree | f67f985624de796002733fea83e96cc2e87b1dbc | |
parent | e0910eda3ea1c474b4cf9b00ac698f739a982f8c (diff) | |
download | jgit-c701c01b49d92993f1c3df0a0e26a2dd68b8cec1.tar.gz jgit-c701c01b49d92993f1c3df0a0e26a2dd68b8cec1.zip |
Improve handling of NFS stale handle errors
Mark packfile as invalid when NFS stale handle error occurs.
This should fix broken fetch operations when the repo is located on the
NFS system and is GC'ed on a separate system (or process). Which may
result in the index, pack or bitmap file being removed when they are
accessed from the fetch operation.
Bug: 573770
Signed-off-by: Dariusz Luksza <dariusz.luksza@gmail.com>
Change-Id: I70217bfb93bf7421ea2c1d74cbe4f15c76d9c098
-rw-r--r-- | org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java index 27ad4fb07a..3866c9fd90 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/file/Pack.java @@ -63,6 +63,7 @@ import org.eclipse.jgit.lib.Config; import org.eclipse.jgit.lib.Constants; import org.eclipse.jgit.lib.ObjectId; import org.eclipse.jgit.lib.ObjectLoader; +import org.eclipse.jgit.util.FileUtils; import org.eclipse.jgit.util.Hex; import org.eclipse.jgit.util.LongList; import org.eclipse.jgit.util.NB; @@ -682,7 +683,12 @@ public class Pack implements Iterable<PackIndex.MutableEntry> { // exceptions signaling permanent problems with a pack openFail(true, pe); throw pe; - } catch (IOException | RuntimeException ge) { + } catch (IOException ioe) { + // mark this packfile as invalid when NFS stale file handle error + // occur + openFail(FileUtils.isStaleFileHandleInCausalChain(ioe), ioe); + throw ioe; + } catch (RuntimeException ge) { // generic exceptions could be transient so we should not mark the // pack invalid to avoid false MissingObjectExceptions openFail(false, ge); @@ -1156,6 +1162,12 @@ public class Pack implements Iterable<PackIndex.MutableEntry> { // Once upon a time the bitmap or index files existed. Now one // of them has been removed. Most likely an external gc has // removed index, packfile or the bitmap + } catch (IOException e) { + if (!FileUtils.isStaleFileHandleInCausalChain(e)) { + throw e; + } + // Ignore NFS stale handle exception the same way as + // FileNotFoundException above. } bitmapIdxFile = null; return null; |