Skip to content

Commit

Permalink
SPVBlockStore: lock the store file as early as possible
Browse files Browse the repository at this point in the history
  • Loading branch information
schildbach committed Jun 29, 2024
1 parent de8afc6 commit 351fbc0
Showing 1 changed file with 9 additions and 6 deletions.
15 changes: 9 additions & 6 deletions core/src/main/java/org/bitcoinj/store/SPVBlockStore.java
Original file line number Diff line number Diff line change
Expand Up @@ -117,8 +117,16 @@ public SPVBlockStore(NetworkParameters params, File file, int capacity, boolean
checkArgument(capacity > 0);
try {
boolean exists = file.exists();
// Set up the backing file.
// Set up the backing file, empty if it doesn't exist.
randomAccessFile = new RandomAccessFile(file, "rw");
FileChannel channel = randomAccessFile.getChannel();

// Lock the file.
fileLock = channel.tryLock();
if (fileLock == null)
throw new ChainFileLockedException("Store file is already locked by another process");

// Ensure expected file size, grow if desired.
fileLength = getFileSize(capacity);
if (!exists) {
log.info("Creating new SPV block chain file " + file);
Expand All @@ -140,11 +148,6 @@ else if (fileLength < randomAccessFile.length())
}
}

FileChannel channel = randomAccessFile.getChannel();
fileLock = channel.tryLock();
if (fileLock == null)
throw new ChainFileLockedException("Store file is already locked by another process");

// Map it into memory read/write. The kernel will take care of flushing writes to disk at the most
// efficient times, which may mean that until the map is deallocated the data on disk is randomly
// inconsistent. However the only process accessing it is us, via this mapping, so our own view will
Expand Down

0 comments on commit 351fbc0

Please sign in to comment.