ARTEMIS-2210 PagingStore creation is not properly synchronized
In PagingManagerImpl#getPageStore() the operations on the map 'stores' are not synchronzed and it's possible that more than one paging store is created for one address.
This commit is contained in:
parent
4179c44e7e
commit
70f8297cfa
|
@ -335,19 +335,30 @@ public final class PagingManagerImpl implements PagingManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* stores is a ConcurrentHashMap, so we don't need to synchronize this method
|
* This method creates a new store if not exist.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public PagingStore getPageStore(final SimpleString storeName) throws Exception {
|
public PagingStore getPageStore(final SimpleString storeName) throws Exception {
|
||||||
if (managementAddress != null && storeName.startsWith(managementAddress)) {
|
if (managementAddress != null && storeName.startsWith(managementAddress)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
PagingStore store = stores.get(storeName);
|
|
||||||
|
|
||||||
|
PagingStore store = stores.get(storeName);
|
||||||
if (store != null) {
|
if (store != null) {
|
||||||
return store;
|
return store;
|
||||||
}
|
}
|
||||||
return newStore(storeName);
|
//only if store is null we use computeIfAbsent
|
||||||
|
try {
|
||||||
|
return stores.computeIfAbsent(storeName, (s) -> {
|
||||||
|
try {
|
||||||
|
return newStore(s);
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} catch (RuntimeException e) {
|
||||||
|
throw (Exception) e.getCause();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -450,18 +461,15 @@ public final class PagingManagerImpl implements PagingManager {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//any caller that calls this method must guarantee the store doesn't exist.
|
||||||
private PagingStore newStore(final SimpleString address) throws Exception {
|
private PagingStore newStore(final SimpleString address) throws Exception {
|
||||||
assert managementAddress == null || (managementAddress != null && !address.startsWith(managementAddress));
|
assert managementAddress == null || (managementAddress != null && !address.startsWith(managementAddress));
|
||||||
syncLock.readLock().lock();
|
syncLock.readLock().lock();
|
||||||
try {
|
try {
|
||||||
PagingStore store = stores.get(address);
|
PagingStore store = pagingStoreFactory.newStore(address, addressSettingsRepository.getMatch(address.toString()));
|
||||||
if (store == null) {
|
store.start();
|
||||||
store = pagingStoreFactory.newStore(address, addressSettingsRepository.getMatch(address.toString()));
|
if (!cleanupEnabled) {
|
||||||
store.start();
|
store.disableCleanup();
|
||||||
if (!cleanupEnabled) {
|
|
||||||
store.disableCleanup();
|
|
||||||
}
|
|
||||||
stores.put(address, store);
|
|
||||||
}
|
}
|
||||||
return store;
|
return store;
|
||||||
} finally {
|
} finally {
|
||||||
|
|
Loading…
Reference in New Issue