From 90c8a29045f18554fd4c2da5ad01dd00af11cae7 Mon Sep 17 00:00:00 2001 From: Robert Godfrey Date: Wed, 6 Aug 2014 11:05:05 +0000 Subject: QPID-5965 : [Java Broker] flow transient messages to disk in low memory situations git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1616155 13f79535-47bb-0310-9956-ffa450edef68 --- .../server/store/berkeleydb/AbstractBDBMessageStore.java | 13 +++++++++++++ .../virtualhost/berkeleydb/BDBHAReplicaVirtualHost.java | 12 ++++++++++++ 2 files changed, 25 insertions(+) (limited to 'qpid/java/bdbstore') diff --git a/qpid/java/bdbstore/src/main/java/org/apache/qpid/server/store/berkeleydb/AbstractBDBMessageStore.java b/qpid/java/bdbstore/src/main/java/org/apache/qpid/server/store/berkeleydb/AbstractBDBMessageStore.java index 7e5f5bbb3f..338882e6df 100644 --- a/qpid/java/bdbstore/src/main/java/org/apache/qpid/server/store/berkeleydb/AbstractBDBMessageStore.java +++ b/qpid/java/bdbstore/src/main/java/org/apache/qpid/server/store/berkeleydb/AbstractBDBMessageStore.java @@ -1424,11 +1424,24 @@ public abstract class AbstractBDBMessageStore implements MessageStore storedSizeChangeOccurred(-delta); } + @Override + public boolean isInMemory() + { + return _messageDataRef.isHardRef(); + } + private boolean stored() { return !_messageDataRef.isHardRef(); } + @Override + public boolean flowToDisk() + { + flushToStore(); + return true; + } + @Override public String toString() { diff --git a/qpid/java/bdbstore/src/main/java/org/apache/qpid/server/virtualhost/berkeleydb/BDBHAReplicaVirtualHost.java b/qpid/java/bdbstore/src/main/java/org/apache/qpid/server/virtualhost/berkeleydb/BDBHAReplicaVirtualHost.java index 74242df7c6..55805b5626 100644 --- a/qpid/java/bdbstore/src/main/java/org/apache/qpid/server/virtualhost/berkeleydb/BDBHAReplicaVirtualHost.java +++ b/qpid/java/bdbstore/src/main/java/org/apache/qpid/server/virtualhost/berkeleydb/BDBHAReplicaVirtualHost.java @@ -337,6 +337,18 @@ public class BDBHAReplicaVirtualHost extends AbstractConfiguredObject