Fixing the order of locks acquired in the KahaDB journal to prevent a
deadlock during file rotation

(cherry picked from commit 5fd63a0e4e)
This commit is contained in:
Christopher L. Shannon (cshannon) 2016-12-16 12:27:34 -05:00
parent 1c625e116e
commit fc3897af67
1 changed files with 14 additions and 3 deletions

View File

@ -977,6 +977,16 @@ public class Journal {
}
public DataFile getCurrentDataFile(int capacity) throws IOException {
//First just acquire the currentDataFile lock and return if no rotation needed
synchronized (currentDataFile) {
if (currentDataFile.get().getLength() + capacity < maxFileLength) {
return currentDataFile.get();
}
}
//AMQ-6545 - if rotation needed, acquire dataFileIdLock first to prevent deadlocks
//then re-check if rotation is needed
synchronized (dataFileIdLock) {
synchronized (currentDataFile) {
if (currentDataFile.get().getLength() + capacity >= maxFileLength) {
rotateWriteFile();
@ -984,6 +994,7 @@ public class Journal {
return currentDataFile.get();
}
}
}
public Integer getCurrentDataFileId() {
synchronized (currentDataFile) {