mirror of https://github.com/apache/activemq.git
https://issues.apache.org/activemq/browse/AMQ-2843 - first stab at supporting priority for durable subs
git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@966712 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
40f921dab9
commit
4f5e620d1c
|
@ -506,9 +506,6 @@
|
||||||
<!-- breaks hudson: disable till we get a chance to give it the time that it needs - http://hudson.zones.apache.org/hudson/job/ActiveMQ/org.apache.activemq$activemq-core/199/testReport/org.apache.activemq.network/BrokerNetworkWithStuckMessagesTest/testBrokerNetworkWithStuckMessages/ -->
|
<!-- breaks hudson: disable till we get a chance to give it the time that it needs - http://hudson.zones.apache.org/hudson/job/ActiveMQ/org.apache.activemq$activemq-core/199/testReport/org.apache.activemq.network/BrokerNetworkWithStuckMessagesTest/testBrokerNetworkWithStuckMessages/ -->
|
||||||
<exclude>**/BrokerNetworkWithStuckMessagesTest.*</exclude>
|
<exclude>**/BrokerNetworkWithStuckMessagesTest.*</exclude>
|
||||||
|
|
||||||
<!-- exclude until implemented -->
|
|
||||||
<exclude>**/JDBCMessagePriorityTest.*</exclude>
|
|
||||||
|
|
||||||
</excludes>
|
</excludes>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
|
|
@ -51,19 +51,19 @@ public interface JDBCAdapter {
|
||||||
|
|
||||||
void doRecover(TransactionContext c, ActiveMQDestination destination, JDBCMessageRecoveryListener listener) throws Exception;
|
void doRecover(TransactionContext c, ActiveMQDestination destination, JDBCMessageRecoveryListener listener) throws Exception;
|
||||||
|
|
||||||
void doSetLastAck(TransactionContext c, ActiveMQDestination destination, String clientId, String subscriptionName, long seq) throws SQLException, IOException;
|
void doSetLastAck(TransactionContext c, ActiveMQDestination destination, String clientId, String subscriptionName, long seq, long prio) throws SQLException, IOException;
|
||||||
|
|
||||||
void doRecoverSubscription(TransactionContext c, ActiveMQDestination destination, String clientId, String subscriptionName, JDBCMessageRecoveryListener listener)
|
void doRecoverSubscription(TransactionContext c, ActiveMQDestination destination, String clientId, String subscriptionName, JDBCMessageRecoveryListener listener)
|
||||||
throws Exception;
|
throws Exception;
|
||||||
|
|
||||||
void doRecoverNextMessages(TransactionContext c, ActiveMQDestination destination, String clientId, String subscriptionName, long seq, int maxReturned,
|
void doRecoverNextMessages(TransactionContext c, ActiveMQDestination destination, String clientId, String subscriptionName, long seq, long priority, int maxReturned,
|
||||||
JDBCMessageRecoveryListener listener) throws Exception;
|
JDBCMessageRecoveryListener listener) throws Exception;
|
||||||
|
|
||||||
void doSetSubscriberEntry(TransactionContext c, SubscriptionInfo subscriptionInfo, boolean retroactive) throws SQLException, IOException;
|
void doSetSubscriberEntry(TransactionContext c, SubscriptionInfo subscriptionInfo, boolean retroactive) throws SQLException, IOException;
|
||||||
|
|
||||||
SubscriptionInfo doGetSubscriberEntry(TransactionContext c, ActiveMQDestination destination, String clientId, String subscriptionName) throws SQLException, IOException;
|
SubscriptionInfo doGetSubscriberEntry(TransactionContext c, ActiveMQDestination destination, String clientId, String subscriptionName) throws SQLException, IOException;
|
||||||
|
|
||||||
long getStoreSequenceId(TransactionContext c, ActiveMQDestination destination, MessageId messageID) throws SQLException, IOException;
|
long[] getStoreSequenceId(TransactionContext c, ActiveMQDestination destination, MessageId messageID) throws SQLException, IOException;
|
||||||
|
|
||||||
void doRemoveAllMessages(TransactionContext c, ActiveMQDestination destinationName) throws SQLException, IOException;
|
void doRemoveAllMessages(TransactionContext c, ActiveMQDestination destinationName) throws SQLException, IOException;
|
||||||
|
|
||||||
|
|
|
@ -284,7 +284,7 @@ public class JDBCMessageStore extends AbstractMessageStore {
|
||||||
long result = -1;
|
long result = -1;
|
||||||
TransactionContext c = persistenceAdapter.getTransactionContext();
|
TransactionContext c = persistenceAdapter.getTransactionContext();
|
||||||
try {
|
try {
|
||||||
result = adapter.getStoreSequenceId(c, destination, messageId);
|
result = adapter.getStoreSequenceId(c, destination, messageId)[0];
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
JDBCPersistenceAdapter.log("JDBC Failure: ", e);
|
JDBCPersistenceAdapter.log("JDBC Failure: ", e);
|
||||||
throw IOExceptionSupport.create("Failed to get store sequenceId for messageId: " + messageId +", on: " + destination + ". Reason: " + e, e);
|
throw IOExceptionSupport.create("Failed to get store sequenceId for messageId: " + messageId +", on: " + destination + ". Reason: " + e, e);
|
||||||
|
|
|
@ -40,6 +40,7 @@ import org.apache.activemq.wireformat.WireFormat;
|
||||||
public class JDBCTopicMessageStore extends JDBCMessageStore implements TopicMessageStore {
|
public class JDBCTopicMessageStore extends JDBCMessageStore implements TopicMessageStore {
|
||||||
|
|
||||||
private Map<String, AtomicLong> subscriberLastMessageMap = new ConcurrentHashMap<String, AtomicLong>();
|
private Map<String, AtomicLong> subscriberLastMessageMap = new ConcurrentHashMap<String, AtomicLong>();
|
||||||
|
private Map<String, AtomicLong> subscriberLastPriorityMap = new ConcurrentHashMap<String, AtomicLong>();
|
||||||
|
|
||||||
public JDBCTopicMessageStore(JDBCPersistenceAdapter persistenceAdapter, JDBCAdapter adapter, WireFormat wireFormat, ActiveMQTopic topic, ActiveMQMessageAudit audit) {
|
public JDBCTopicMessageStore(JDBCPersistenceAdapter persistenceAdapter, JDBCAdapter adapter, WireFormat wireFormat, ActiveMQTopic topic, ActiveMQMessageAudit audit) {
|
||||||
super(persistenceAdapter, adapter, wireFormat, topic, audit);
|
super(persistenceAdapter, adapter, wireFormat, topic, audit);
|
||||||
|
@ -49,8 +50,8 @@ public class JDBCTopicMessageStore extends JDBCMessageStore implements TopicMess
|
||||||
// Get a connection and insert the message into the DB.
|
// Get a connection and insert the message into the DB.
|
||||||
TransactionContext c = persistenceAdapter.getTransactionContext(context);
|
TransactionContext c = persistenceAdapter.getTransactionContext(context);
|
||||||
try {
|
try {
|
||||||
long seq = adapter.getStoreSequenceId(c, destination, messageId);
|
long[] res = adapter.getStoreSequenceId(c, destination, messageId);
|
||||||
adapter.doSetLastAck(c, destination, clientId, subscriptionName, seq);
|
adapter.doSetLastAck(c, destination, clientId, subscriptionName, res[0], res[1]);
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
JDBCPersistenceAdapter.log("JDBC Failure: ", e);
|
JDBCPersistenceAdapter.log("JDBC Failure: ", e);
|
||||||
throw IOExceptionSupport.create("Failed to store acknowledgment for: " + clientId + " on message " + messageId + " in container: " + e, e);
|
throw IOExceptionSupport.create("Failed to store acknowledgment for: " + clientId + " on message " + messageId + " in container: " + e, e);
|
||||||
|
@ -63,7 +64,6 @@ public class JDBCTopicMessageStore extends JDBCMessageStore implements TopicMess
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
public void recoverSubscription(String clientId, String subscriptionName, final MessageRecoveryListener listener) throws Exception {
|
public void recoverSubscription(String clientId, String subscriptionName, final MessageRecoveryListener listener) throws Exception {
|
||||||
|
|
||||||
TransactionContext c = persistenceAdapter.getTransactionContext();
|
TransactionContext c = persistenceAdapter.getTransactionContext();
|
||||||
try {
|
try {
|
||||||
adapter.doRecoverSubscription(c, destination, clientId, subscriptionName, new JDBCMessageRecoveryListener() {
|
adapter.doRecoverSubscription(c, destination, clientId, subscriptionName, new JDBCMessageRecoveryListener() {
|
||||||
|
@ -91,14 +91,18 @@ public class JDBCTopicMessageStore extends JDBCMessageStore implements TopicMess
|
||||||
TransactionContext c = persistenceAdapter.getTransactionContext();
|
TransactionContext c = persistenceAdapter.getTransactionContext();
|
||||||
String subcriberId = getSubscriptionKey(clientId, subscriptionName);
|
String subcriberId = getSubscriptionKey(clientId, subscriptionName);
|
||||||
AtomicLong last = subscriberLastMessageMap.get(subcriberId);
|
AtomicLong last = subscriberLastMessageMap.get(subcriberId);
|
||||||
|
AtomicLong priority = subscriberLastPriorityMap.get(subcriberId);
|
||||||
if (last == null) {
|
if (last == null) {
|
||||||
long lastAcked = adapter.doGetLastAckedDurableSubscriberMessageId(c, destination, clientId, subscriptionName);
|
long lastAcked = adapter.doGetLastAckedDurableSubscriberMessageId(c, destination, clientId, subscriptionName);
|
||||||
last = new AtomicLong(lastAcked);
|
last = new AtomicLong(lastAcked);
|
||||||
subscriberLastMessageMap.put(subcriberId, last);
|
subscriberLastMessageMap.put(subcriberId, last);
|
||||||
|
priority = new AtomicLong(Byte.MAX_VALUE - 1);
|
||||||
|
subscriberLastMessageMap.put(subcriberId, priority);
|
||||||
}
|
}
|
||||||
final AtomicLong finalLast = last;
|
final AtomicLong finalLast = last;
|
||||||
|
final AtomicLong finalPriority = priority;
|
||||||
try {
|
try {
|
||||||
adapter.doRecoverNextMessages(c, destination, clientId, subscriptionName, last.get(), maxReturned, new JDBCMessageRecoveryListener() {
|
adapter.doRecoverNextMessages(c, destination, clientId, subscriptionName, last.get(), priority.get(), maxReturned, new JDBCMessageRecoveryListener() {
|
||||||
|
|
||||||
public boolean recoverMessage(long sequenceId, byte[] data) throws Exception {
|
public boolean recoverMessage(long sequenceId, byte[] data) throws Exception {
|
||||||
if (listener.hasSpace()) {
|
if (listener.hasSpace()) {
|
||||||
|
@ -106,6 +110,7 @@ public class JDBCTopicMessageStore extends JDBCMessageStore implements TopicMess
|
||||||
msg.getMessageId().setBrokerSequenceId(sequenceId);
|
msg.getMessageId().setBrokerSequenceId(sequenceId);
|
||||||
listener.recoverMessage(msg);
|
listener.recoverMessage(msg);
|
||||||
finalLast.set(sequenceId);
|
finalLast.set(sequenceId);
|
||||||
|
finalPriority.set(msg.getPriority());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -120,13 +125,15 @@ public class JDBCTopicMessageStore extends JDBCMessageStore implements TopicMess
|
||||||
JDBCPersistenceAdapter.log("JDBC Failure: ", e);
|
JDBCPersistenceAdapter.log("JDBC Failure: ", e);
|
||||||
} finally {
|
} finally {
|
||||||
c.close();
|
c.close();
|
||||||
last.set(finalLast.get());
|
subscriberLastMessageMap.put(subcriberId, finalLast);
|
||||||
|
subscriberLastPriorityMap.put(subcriberId, finalPriority);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void resetBatching(String clientId, String subscriptionName) {
|
public void resetBatching(String clientId, String subscriptionName) {
|
||||||
String subcriberId = getSubscriptionKey(clientId, subscriptionName);
|
String subcriberId = getSubscriptionKey(clientId, subscriptionName);
|
||||||
subscriberLastMessageMap.remove(subcriberId);
|
subscriberLastMessageMap.remove(subcriberId);
|
||||||
|
subscriberLastPriorityMap.remove(subcriberId);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -52,6 +52,7 @@ public class Statements {
|
||||||
private String deleteSubscriptionStatement;
|
private String deleteSubscriptionStatement;
|
||||||
private String findAllDurableSubMessagesStatement;
|
private String findAllDurableSubMessagesStatement;
|
||||||
private String findDurableSubMessagesStatement;
|
private String findDurableSubMessagesStatement;
|
||||||
|
private String findDurableSubMessagesByPriorityStatement;
|
||||||
private String findAllDestinationsStatement;
|
private String findAllDestinationsStatement;
|
||||||
private String removeAllMessagesStatement;
|
private String removeAllMessagesStatement;
|
||||||
private String removeAllSubscriptionsStatement;
|
private String removeAllSubscriptionsStatement;
|
||||||
|
@ -86,7 +87,7 @@ public class Statements {
|
||||||
+ ", SUB_DEST " + stringIdDataType
|
+ ", SUB_DEST " + stringIdDataType
|
||||||
+ ", CLIENT_ID " + stringIdDataType + " NOT NULL" + ", SUB_NAME " + stringIdDataType
|
+ ", CLIENT_ID " + stringIdDataType + " NOT NULL" + ", SUB_NAME " + stringIdDataType
|
||||||
+ " NOT NULL" + ", SELECTOR " + stringIdDataType + ", LAST_ACKED_ID " + sequenceDataType
|
+ " NOT NULL" + ", SELECTOR " + stringIdDataType + ", LAST_ACKED_ID " + sequenceDataType
|
||||||
+ ", PRIMARY KEY ( CONTAINER, CLIENT_ID, SUB_NAME))",
|
+ ", PRIORITY " + sequenceDataType + ", PRIMARY KEY ( CONTAINER, CLIENT_ID, SUB_NAME))",
|
||||||
"CREATE TABLE " + getFullLockTableName()
|
"CREATE TABLE " + getFullLockTableName()
|
||||||
+ "( ID " + longDataType + " NOT NULL, TIME " + longDataType
|
+ "( ID " + longDataType + " NOT NULL, TIME " + longDataType
|
||||||
+ ", BROKER_NAME " + stringIdDataType + ", PRIMARY KEY (ID) )",
|
+ ", BROKER_NAME " + stringIdDataType + ", PRIMARY KEY (ID) )",
|
||||||
|
@ -130,7 +131,7 @@ public class Statements {
|
||||||
|
|
||||||
public String getFindMessageSequenceIdStatement() {
|
public String getFindMessageSequenceIdStatement() {
|
||||||
if (findMessageSequenceIdStatement == null) {
|
if (findMessageSequenceIdStatement == null) {
|
||||||
findMessageSequenceIdStatement = "SELECT ID FROM " + getFullMessageTableName()
|
findMessageSequenceIdStatement = "SELECT ID, PRIORITY FROM " + getFullMessageTableName()
|
||||||
+ " WHERE MSGID_PROD=? AND MSGID_SEQ=? AND CONTAINER=?";
|
+ " WHERE MSGID_PROD=? AND MSGID_SEQ=? AND CONTAINER=?";
|
||||||
}
|
}
|
||||||
return findMessageSequenceIdStatement;
|
return findMessageSequenceIdStatement;
|
||||||
|
@ -195,8 +196,8 @@ public class Statements {
|
||||||
if (createDurableSubStatement == null) {
|
if (createDurableSubStatement == null) {
|
||||||
createDurableSubStatement = "INSERT INTO "
|
createDurableSubStatement = "INSERT INTO "
|
||||||
+ getFullAckTableName()
|
+ getFullAckTableName()
|
||||||
+ "(CONTAINER, CLIENT_ID, SUB_NAME, SELECTOR, LAST_ACKED_ID, SUB_DEST) "
|
+ "(CONTAINER, CLIENT_ID, SUB_NAME, SELECTOR, LAST_ACKED_ID, SUB_DEST, PRIORITY) "
|
||||||
+ "VALUES (?, ?, ?, ?, ?, ?)";
|
+ "VALUES (?, ?, ?, ?, ?, ?, ?)";
|
||||||
}
|
}
|
||||||
return createDurableSubStatement;
|
return createDurableSubStatement;
|
||||||
}
|
}
|
||||||
|
@ -219,7 +220,7 @@ public class Statements {
|
||||||
|
|
||||||
public String getUpdateLastAckOfDurableSubStatement() {
|
public String getUpdateLastAckOfDurableSubStatement() {
|
||||||
if (updateLastAckOfDurableSubStatement == null) {
|
if (updateLastAckOfDurableSubStatement == null) {
|
||||||
updateLastAckOfDurableSubStatement = "UPDATE " + getFullAckTableName() + " SET LAST_ACKED_ID=?"
|
updateLastAckOfDurableSubStatement = "UPDATE " + getFullAckTableName() + " SET LAST_ACKED_ID=?, PRIORITY=?"
|
||||||
+ " WHERE CONTAINER=? AND CLIENT_ID=? AND SUB_NAME=?";
|
+ " WHERE CONTAINER=? AND CLIENT_ID=? AND SUB_NAME=?";
|
||||||
}
|
}
|
||||||
return updateLastAckOfDurableSubStatement;
|
return updateLastAckOfDurableSubStatement;
|
||||||
|
@ -255,6 +256,18 @@ public class Statements {
|
||||||
return findDurableSubMessagesStatement;
|
return findDurableSubMessagesStatement;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getFindDurableSubMessagesByPriorityStatement() {
|
||||||
|
if (findDurableSubMessagesByPriorityStatement == null) {
|
||||||
|
findDurableSubMessagesByPriorityStatement = "SELECT M.ID, M.MSG FROM " + getFullMessageTableName() + " M, "
|
||||||
|
+ getFullAckTableName() + " D "
|
||||||
|
+ " WHERE D.CONTAINER=? AND D.CLIENT_ID=? AND D.SUB_NAME=?"
|
||||||
|
+ " AND M.CONTAINER=D.CONTAINER AND "
|
||||||
|
+ "((M.ID > ? AND M.PRIORITY = ?) OR M.PRIORITY < ?)"
|
||||||
|
+ " ORDER BY M.PRIORITY DESC, M.ID";
|
||||||
|
}
|
||||||
|
return findDurableSubMessagesByPriorityStatement;
|
||||||
|
}
|
||||||
|
|
||||||
public String findAllDurableSubMessagesStatement() {
|
public String findAllDurableSubMessagesStatement() {
|
||||||
if (findAllDurableSubMessagesStatement == null) {
|
if (findAllDurableSubMessagesStatement == null) {
|
||||||
findAllDurableSubMessagesStatement = "SELECT M.ID, M.MSG FROM " + getFullMessageTableName()
|
findAllDurableSubMessagesStatement = "SELECT M.ID, M.MSG FROM " + getFullMessageTableName()
|
||||||
|
|
|
@ -17,8 +17,11 @@
|
||||||
package org.apache.activemq.store.jdbc.adapter;
|
package org.apache.activemq.store.jdbc.adapter;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.io.PrintStream;
|
||||||
|
import java.sql.Connection;
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.ResultSetMetaData;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.sql.Statement;
|
import java.sql.Statement;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -26,6 +29,8 @@ import java.util.HashSet;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import javax.jms.Message;
|
||||||
|
|
||||||
import org.apache.activemq.command.ActiveMQDestination;
|
import org.apache.activemq.command.ActiveMQDestination;
|
||||||
import org.apache.activemq.command.MessageId;
|
import org.apache.activemq.command.MessageId;
|
||||||
import org.apache.activemq.command.ProducerId;
|
import org.apache.activemq.command.ProducerId;
|
||||||
|
@ -249,7 +254,7 @@ public class DefaultJDBCAdapter implements JDBCAdapter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public long getStoreSequenceId(TransactionContext c, ActiveMQDestination destination, MessageId messageID) throws SQLException, IOException {
|
public long[] getStoreSequenceId(TransactionContext c, ActiveMQDestination destination, MessageId messageID) throws SQLException, IOException {
|
||||||
PreparedStatement s = null;
|
PreparedStatement s = null;
|
||||||
ResultSet rs = null;
|
ResultSet rs = null;
|
||||||
try {
|
try {
|
||||||
|
@ -259,9 +264,9 @@ public class DefaultJDBCAdapter implements JDBCAdapter {
|
||||||
s.setString(3, destination.getQualifiedName());
|
s.setString(3, destination.getQualifiedName());
|
||||||
rs = s.executeQuery();
|
rs = s.executeQuery();
|
||||||
if (!rs.next()) {
|
if (!rs.next()) {
|
||||||
return 0;
|
return new long[]{0,0};
|
||||||
}
|
}
|
||||||
return rs.getLong(1);
|
return new long[]{rs.getLong(1), rs.getLong(2)};
|
||||||
} finally {
|
} finally {
|
||||||
close(rs);
|
close(rs);
|
||||||
close(s);
|
close(s);
|
||||||
|
@ -378,7 +383,7 @@ public class DefaultJDBCAdapter implements JDBCAdapter {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void doSetLastAck(TransactionContext c, ActiveMQDestination destination, String clientId,
|
public void doSetLastAck(TransactionContext c, ActiveMQDestination destination, String clientId,
|
||||||
String subscriptionName, long seq) throws SQLException, IOException {
|
String subscriptionName, long seq, long prio) throws SQLException, IOException {
|
||||||
PreparedStatement s = c.getUpdateLastAckStatement();
|
PreparedStatement s = c.getUpdateLastAckStatement();
|
||||||
try {
|
try {
|
||||||
if (s == null) {
|
if (s == null) {
|
||||||
|
@ -388,9 +393,10 @@ public class DefaultJDBCAdapter implements JDBCAdapter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
s.setLong(1, seq);
|
s.setLong(1, seq);
|
||||||
s.setString(2, destination.getQualifiedName());
|
s.setLong(2, prio);
|
||||||
s.setString(3, clientId);
|
s.setString(3, destination.getQualifiedName());
|
||||||
s.setString(4, subscriptionName);
|
s.setString(4, clientId);
|
||||||
|
s.setString(5, subscriptionName);
|
||||||
if (this.batchStatments) {
|
if (this.batchStatments) {
|
||||||
s.addBatch();
|
s.addBatch();
|
||||||
} else if (s.executeUpdate() != 1) {
|
} else if (s.executeUpdate() != 1) {
|
||||||
|
@ -435,16 +441,25 @@ public class DefaultJDBCAdapter implements JDBCAdapter {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void doRecoverNextMessages(TransactionContext c, ActiveMQDestination destination, String clientId,
|
public void doRecoverNextMessages(TransactionContext c, ActiveMQDestination destination, String clientId,
|
||||||
String subscriptionName, long seq, int maxReturned, JDBCMessageRecoveryListener listener) throws Exception {
|
String subscriptionName, long seq, long priority, int maxReturned, JDBCMessageRecoveryListener listener) throws Exception {
|
||||||
|
|
||||||
PreparedStatement s = null;
|
PreparedStatement s = null;
|
||||||
ResultSet rs = null;
|
ResultSet rs = null;
|
||||||
try {
|
try {
|
||||||
|
if (isPrioritizedMessages()) {
|
||||||
|
s = c.getConnection().prepareStatement(this.statements.getFindDurableSubMessagesByPriorityStatement());
|
||||||
|
} else {
|
||||||
s = c.getConnection().prepareStatement(this.statements.getFindDurableSubMessagesStatement());
|
s = c.getConnection().prepareStatement(this.statements.getFindDurableSubMessagesStatement());
|
||||||
|
}
|
||||||
s.setMaxRows(maxReturned);
|
s.setMaxRows(maxReturned);
|
||||||
s.setString(1, destination.getQualifiedName());
|
s.setString(1, destination.getQualifiedName());
|
||||||
s.setString(2, clientId);
|
s.setString(2, clientId);
|
||||||
s.setString(3, subscriptionName);
|
s.setString(3, subscriptionName);
|
||||||
s.setLong(4, seq);
|
s.setLong(4, seq);
|
||||||
|
if (isPrioritizedMessages()) {
|
||||||
|
s.setLong(5, priority);
|
||||||
|
s.setLong(6, priority);
|
||||||
|
}
|
||||||
rs = s.executeQuery();
|
rs = s.executeQuery();
|
||||||
int count = 0;
|
int count = 0;
|
||||||
if (this.statements.isUseExternalMessageReferences()) {
|
if (this.statements.isUseExternalMessageReferences()) {
|
||||||
|
@ -507,6 +522,7 @@ public class DefaultJDBCAdapter implements JDBCAdapter {
|
||||||
PreparedStatement s = null;
|
PreparedStatement s = null;
|
||||||
try {
|
try {
|
||||||
long lastMessageId = -1;
|
long lastMessageId = -1;
|
||||||
|
long priority = Byte.MAX_VALUE - 1;
|
||||||
if (!retroactive) {
|
if (!retroactive) {
|
||||||
s = c.getConnection().prepareStatement(this.statements.getFindLastSequenceIdInMsgsStatement());
|
s = c.getConnection().prepareStatement(this.statements.getFindLastSequenceIdInMsgsStatement());
|
||||||
ResultSet rs = null;
|
ResultSet rs = null;
|
||||||
|
@ -527,6 +543,7 @@ public class DefaultJDBCAdapter implements JDBCAdapter {
|
||||||
s.setString(4, info.getSelector());
|
s.setString(4, info.getSelector());
|
||||||
s.setLong(5, lastMessageId);
|
s.setLong(5, lastMessageId);
|
||||||
s.setString(6, info.getSubscribedDestination().getQualifiedName());
|
s.setString(6, info.getSubscribedDestination().getQualifiedName());
|
||||||
|
s.setLong(7, priority);
|
||||||
if (s.executeUpdate() != 1) {
|
if (s.executeUpdate() != 1) {
|
||||||
throw new IOException("Could not create durable subscription for: " + info.getClientId());
|
throw new IOException("Could not create durable subscription for: " + info.getClientId());
|
||||||
}
|
}
|
||||||
|
@ -813,29 +830,61 @@ public class DefaultJDBCAdapter implements JDBCAdapter {
|
||||||
close(s);
|
close(s);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
* Useful for debugging. public void dumpTables(Connection c, String destinationName, String clientId, String
|
/* public void dumpTables(Connection c, String destinationName, String clientId, String
|
||||||
* subscriptionName) throws SQLException { printQuery(c, "Select * from ACTIVEMQ_MSGS", System.out); printQuery(c,
|
subscriptionName) throws SQLException {
|
||||||
* "Select * from ACTIVEMQ_ACKS", System.out); PreparedStatement s = c.prepareStatement("SELECT M.ID,
|
printQuery(c, "Select * from ACTIVEMQ_MSGS", System.out);
|
||||||
* D.LAST_ACKED_ID FROM " +"ACTIVEMQ_MSGS M, " +"ACTIVEMQ_ACKS D " +"WHERE D.CONTAINER=? AND D.CLIENT_ID=? AND
|
printQuery(c, "Select * from ACTIVEMQ_ACKS", System.out);
|
||||||
* D.SUB_NAME=?" +" AND M.CONTAINER=D.CONTAINER AND M.ID > D.LAST_ACKED_ID" +" ORDER BY M.ID");
|
PreparedStatement s = c.prepareStatement("SELECT M.ID, D.LAST_ACKED_ID FROM "
|
||||||
* s.setString(1,destinationName); s.setString(2,clientId); s.setString(3,subscriptionName);
|
+ "ACTIVEMQ_MSGS M, " +"ACTIVEMQ_ACKS D "
|
||||||
* printQuery(s,System.out); }
|
+ "WHERE D.CONTAINER=? AND D.CLIENT_ID=? AND D.SUB_NAME=?"
|
||||||
*
|
+ " AND M.CONTAINER=D.CONTAINER AND M.ID > D.LAST_ACKED_ID"
|
||||||
* public void dumpTables(Connection c) throws SQLException { printQuery(c, "Select * from ACTIVEMQ_MSGS",
|
+ " ORDER BY M.ID");
|
||||||
* System.out); printQuery(c, "Select * from ACTIVEMQ_ACKS", System.out); }
|
s.setString(1,destinationName); s.setString(2,clientId); s.setString(3,subscriptionName);
|
||||||
*
|
printQuery(s,System.out); }
|
||||||
* private void printQuery(Connection c, String query, PrintStream out) throws SQLException {
|
|
||||||
* printQuery(c.prepareStatement(query), out); }
|
public void dumpTables(Connection c) throws SQLException {
|
||||||
*
|
printQuery(c, "Select * from ACTIVEMQ_MSGS", System.out);
|
||||||
* private void printQuery(PreparedStatement s, PrintStream out) throws SQLException {
|
printQuery(c, "Select * from ACTIVEMQ_ACKS", System.out);
|
||||||
*
|
}
|
||||||
* ResultSet set=null; try { set = s.executeQuery(); ResultSetMetaData metaData = set.getMetaData(); for( int i=1; i<=
|
|
||||||
* metaData.getColumnCount(); i++ ) { if(i==1) out.print("||"); out.print(metaData.getColumnName(i)+"||"); }
|
private void printQuery(Connection c, String query, PrintStream out)
|
||||||
* out.println(); while(set.next()) { for( int i=1; i<= metaData.getColumnCount(); i++ ) { if(i==1) out.print("|");
|
throws SQLException {
|
||||||
* out.print(set.getString(i)+"|"); } out.println(); } } finally { try { set.close(); } catch (Throwable ignore) {}
|
printQuery(c.prepareStatement(query), out);
|
||||||
* try { s.close(); } catch (Throwable ignore) {} } }
|
}
|
||||||
*/
|
|
||||||
|
private void printQuery(PreparedStatement s, PrintStream out)
|
||||||
|
throws SQLException {
|
||||||
|
|
||||||
|
ResultSet set = null;
|
||||||
|
try {
|
||||||
|
set = s.executeQuery();
|
||||||
|
ResultSetMetaData metaData = set.getMetaData();
|
||||||
|
for (int i = 1; i <= metaData.getColumnCount(); i++) {
|
||||||
|
if (i == 1)
|
||||||
|
out.print("||");
|
||||||
|
out.print(metaData.getColumnName(i) + "||");
|
||||||
|
}
|
||||||
|
out.println();
|
||||||
|
while (set.next()) {
|
||||||
|
for (int i = 1; i <= metaData.getColumnCount(); i++) {
|
||||||
|
if (i == 1)
|
||||||
|
out.print("|");
|
||||||
|
out.print(set.getString(i) + "|");
|
||||||
|
}
|
||||||
|
out.println();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
set.close();
|
||||||
|
} catch (Throwable ignore) {
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
s.close();
|
||||||
|
} catch (Throwable ignore) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} */
|
||||||
|
|
||||||
public long doGetLastProducerSequenceId(TransactionContext c, ProducerId id)
|
public long doGetLastProducerSequenceId(TransactionContext c, ProducerId id)
|
||||||
throws SQLException, IOException {
|
throws SQLException, IOException {
|
||||||
|
|
|
@ -177,7 +177,7 @@ abstract public class MessagePriorityTest extends CombinationTestSupport {
|
||||||
sub = sess.createDurableSubscriber(topic, "priority");
|
sub = sess.createDurableSubscriber(topic, "priority");
|
||||||
for (int i = 0; i < MSG_NUM * 2; i++) {
|
for (int i = 0; i < MSG_NUM * 2; i++) {
|
||||||
Message msg = sub.receive(1000);
|
Message msg = sub.receive(1000);
|
||||||
assertNotNull(msg);
|
assertNotNull("Message " + i + " was null", msg);
|
||||||
assertEquals("Message " + i + " has wrong priority", i < MSG_NUM ? HIGH_PRI : LOW_PRI, msg.getJMSPriority());
|
assertEquals("Message " + i + " has wrong priority", i < MSG_NUM ? HIGH_PRI : LOW_PRI, msg.getJMSPriority());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue