ARTEMIS-2584 Optimize PageTransactionInfoImpl in-memory size

This commit is contained in:
Wei Yang 2020-01-02 10:09:46 +08:00 committed by Clebert Suconic
parent 6bbd2bf857
commit 0e6a1dee47
1 changed files with 16 additions and 10 deletions

View File

@ -21,6 +21,7 @@ import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicIntegerFieldUpdater;
import org.apache.activemq.artemis.api.core.ActiveMQBuffer;
import org.apache.activemq.artemis.core.paging.PageTransactionInfo;
@ -43,6 +44,11 @@ public final class PageTransactionInfoImpl implements PageTransactionInfo {
private static final Logger logger = Logger.getLogger(PageTransactionInfoImpl.class);
private static final AtomicIntegerFieldUpdater<PageTransactionInfoImpl> numberOfMessagesUpdater =
AtomicIntegerFieldUpdater.newUpdater(PageTransactionInfoImpl.class, "numberOfMessages");
private static final AtomicIntegerFieldUpdater<PageTransactionInfoImpl> numberOfPersistentMessagesUpdater =
AtomicIntegerFieldUpdater.newUpdater(PageTransactionInfoImpl.class, "numberOfPersistentMessages");
private long transactionID;
private volatile long recordID = -1;
@ -53,9 +59,9 @@ public final class PageTransactionInfoImpl implements PageTransactionInfo {
private volatile boolean rolledback = false;
private final AtomicInteger numberOfMessages = new AtomicInteger(0);
private volatile int numberOfMessages = 0;
private final AtomicInteger numberOfPersistentMessages = new AtomicInteger(0);
private volatile int numberOfPersistentMessages = 0;
private List<LateDelivery> lateDeliveries;
@ -90,13 +96,13 @@ public final class PageTransactionInfoImpl implements PageTransactionInfo {
@Override
public boolean onUpdate(final int update, final StorageManager storageManager, PagingManager pagingManager) {
int afterUpdate = numberOfMessages.addAndGet(-update);
int afterUpdate = numberOfMessagesUpdater.addAndGet(this, -update);
return internalCheckSize(storageManager, pagingManager, afterUpdate);
}
@Override
public boolean checkSize(StorageManager storageManager, PagingManager pagingManager) {
return internalCheckSize(storageManager, pagingManager, numberOfMessages.get());
return internalCheckSize(storageManager, pagingManager, numberOfMessagesUpdater.get(this));
}
public boolean internalCheckSize(StorageManager storageManager, PagingManager pagingManager, int size) {
@ -118,13 +124,13 @@ public final class PageTransactionInfoImpl implements PageTransactionInfo {
@Override
public void increment(final int durableSize, final int nonDurableSize) {
numberOfPersistentMessages.addAndGet(durableSize);
numberOfMessages.addAndGet(durableSize + nonDurableSize);
numberOfPersistentMessagesUpdater.addAndGet(this, durableSize);
numberOfMessagesUpdater.addAndGet(this, durableSize + nonDurableSize);
}
@Override
public int getNumberOfMessages() {
return numberOfMessages.get();
return numberOfMessagesUpdater.get(this);
}
// EncodingSupport implementation
@ -132,15 +138,15 @@ public final class PageTransactionInfoImpl implements PageTransactionInfo {
@Override
public synchronized void decode(final ActiveMQBuffer buffer) {
transactionID = buffer.readLong();
numberOfMessages.set(buffer.readInt());
numberOfPersistentMessages.set(numberOfMessages.get());
numberOfMessagesUpdater.set(this, buffer.readInt());
numberOfPersistentMessagesUpdater.set(this, numberOfMessagesUpdater.get(this));
committed = true;
}
@Override
public synchronized void encode(final ActiveMQBuffer buffer) {
buffer.writeLong(transactionID);
buffer.writeInt(numberOfPersistentMessages.get());
buffer.writeInt(numberOfPersistentMessagesUpdater.get(this));
}
@Override