ARTEMIS-1287/ARTEMIS-1292 Complete Page on the Journal
fixing PagingTest.testDeletePhysicalPages
This commit is contained in:
parent
baeca47b44
commit
f18b4ee0c9
|
@ -1079,10 +1079,13 @@ public class CoreMessage extends RefCountMessage implements ICoreMessage {
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
try {
|
try {
|
||||||
|
checkProperties();
|
||||||
return "CoreMessage[messageID=" + messageID + ",durable=" + isDurable() + ",userID=" + getUserID() + ",priority=" + this.getPriority() +
|
return "CoreMessage[messageID=" + messageID + ",durable=" + isDurable() + ",userID=" + getUserID() + ",priority=" + this.getPriority() +
|
||||||
", timestamp=" + toDate(getTimestamp()) + ",expiration=" + toDate(getExpiration()) +
|
", timestamp=" + toDate(getTimestamp()) + ",expiration=" + toDate(getExpiration()) +
|
||||||
", durable=" + durable + ", address=" + getAddress() + ",properties=" + properties.toString() + "]@" + System.identityHashCode(this);
|
", durable=" + durable + ", address=" + getAddress() + ",properties=" + properties + "]@" + System.identityHashCode(this);
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
System.exit(-1);
|
||||||
return "ServerMessage[messageID=" + messageID + "]";
|
return "ServerMessage[messageID=" + messageID + "]";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -96,7 +96,7 @@ public interface PageSubscription {
|
||||||
*/
|
*/
|
||||||
void reloadACK(PagePosition position);
|
void reloadACK(PagePosition position);
|
||||||
|
|
||||||
void reloadPageCompletion(PagePosition position) throws Exception;
|
boolean reloadPageCompletion(PagePosition position) throws Exception;
|
||||||
|
|
||||||
void reloadPageInfo(long pageNr);
|
void reloadPageInfo(long pageNr);
|
||||||
|
|
||||||
|
|
|
@ -190,7 +190,10 @@ final class PageSubscriptionImpl implements PageSubscription {
|
||||||
* cursor/subscription.
|
* cursor/subscription.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void reloadPageCompletion(PagePosition position) throws Exception {
|
public boolean reloadPageCompletion(PagePosition position) throws Exception {
|
||||||
|
if (!pageStore.checkPageFileExists((int)position.getPageNr())) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
// if the current page is complete, we must move it out of the way
|
// if the current page is complete, we must move it out of the way
|
||||||
if (pageStore != null && pageStore.getCurrentPage() != null &&
|
if (pageStore != null && pageStore.getCurrentPage() != null &&
|
||||||
pageStore.getCurrentPage().getPageId() == position.getPageNr()) {
|
pageStore.getCurrentPage().getPageId() == position.getPageNr()) {
|
||||||
|
@ -201,6 +204,8 @@ final class PageSubscriptionImpl implements PageSubscription {
|
||||||
synchronized (consumedPages) {
|
synchronized (consumedPages) {
|
||||||
consumedPages.put(Long.valueOf(position.getPageNr()), info);
|
consumedPages.put(Long.valueOf(position.getPageNr()), info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -520,6 +520,12 @@ public class PagingStoreImpl implements PagingStore {
|
||||||
@Override
|
@Override
|
||||||
public boolean checkPageFileExists(final int pageNumber) {
|
public boolean checkPageFileExists(final int pageNumber) {
|
||||||
String fileName = createFileName(pageNumber);
|
String fileName = createFileName(pageNumber);
|
||||||
|
|
||||||
|
try {
|
||||||
|
checkFileFactory();
|
||||||
|
} catch (Exception ignored) {
|
||||||
|
}
|
||||||
|
|
||||||
SequentialFile file = fileFactory.createSequentialFile(fileName);
|
SequentialFile file = fileFactory.createSequentialFile(fileName);
|
||||||
return file.exists();
|
return file.exists();
|
||||||
}
|
}
|
||||||
|
@ -528,9 +534,7 @@ public class PagingStoreImpl implements PagingStore {
|
||||||
public Page createPage(final int pageNumber) throws Exception {
|
public Page createPage(final int pageNumber) throws Exception {
|
||||||
String fileName = createFileName(pageNumber);
|
String fileName = createFileName(pageNumber);
|
||||||
|
|
||||||
if (fileFactory == null) {
|
checkFileFactory();
|
||||||
fileFactory = storeFactory.newFileFactory(getStoreName());
|
|
||||||
}
|
|
||||||
|
|
||||||
SequentialFile file = fileFactory.createSequentialFile(fileName);
|
SequentialFile file = fileFactory.createSequentialFile(fileName);
|
||||||
|
|
||||||
|
@ -546,6 +550,12 @@ public class PagingStoreImpl implements PagingStore {
|
||||||
return page;
|
return page;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void checkFileFactory() throws Exception {
|
||||||
|
if (fileFactory == null) {
|
||||||
|
fileFactory = storeFactory.newFileFactory(getStoreName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void forceAnotherPage() throws Exception {
|
public void forceAnotherPage() throws Exception {
|
||||||
openNewPage();
|
openNewPage();
|
||||||
|
|
|
@ -1085,7 +1085,12 @@ public abstract class AbstractJournalStorageManager implements StorageManager {
|
||||||
PageSubscription sub = locateSubscription(encoding.queueID, pageSubscriptions, queueInfos, pagingManager);
|
PageSubscription sub = locateSubscription(encoding.queueID, pageSubscriptions, queueInfos, pagingManager);
|
||||||
|
|
||||||
if (sub != null) {
|
if (sub != null) {
|
||||||
sub.reloadPageCompletion(encoding.position);
|
if (!sub.reloadPageCompletion(encoding.position)) {
|
||||||
|
if (logger.isDebugEnabled()) {
|
||||||
|
logger.debug("Complete page " + encoding.position.getPageNr() + " doesn't exist on page manager " + sub.getPagingStore().getAddress());
|
||||||
|
}
|
||||||
|
messageJournal.appendDeleteRecord(record.id, false);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
ActiveMQServerLogger.LOGGER.cantFindQueueOnPageComplete(encoding.queueID);
|
ActiveMQServerLogger.LOGGER.cantFindQueueOnPageComplete(encoding.queueID);
|
||||||
messageJournal.appendDeleteRecord(record.id, false);
|
messageJournal.appendDeleteRecord(record.id, false);
|
||||||
|
|
|
@ -71,6 +71,7 @@ import org.apache.activemq.artemis.spi.core.security.ActiveMQJAASSecurityManager
|
||||||
import org.apache.activemq.artemis.spi.core.security.ActiveMQSecurityManager;
|
import org.apache.activemq.artemis.spi.core.security.ActiveMQSecurityManager;
|
||||||
import org.apache.activemq.artemis.spi.core.security.jaas.InVMLoginModule;
|
import org.apache.activemq.artemis.spi.core.security.jaas.InVMLoginModule;
|
||||||
import org.apache.activemq.artemis.tests.util.ActiveMQTestBase;
|
import org.apache.activemq.artemis.tests.util.ActiveMQTestBase;
|
||||||
|
import org.apache.activemq.artemis.tests.util.Wait;
|
||||||
import org.apache.activemq.artemis.utils.ExecutorFactory;
|
import org.apache.activemq.artemis.utils.ExecutorFactory;
|
||||||
import org.apache.activemq.artemis.utils.ReusableLatch;
|
import org.apache.activemq.artemis.utils.ReusableLatch;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
|
@ -151,6 +152,7 @@ public class HangConsumerTest extends ActiveMQTestBase {
|
||||||
|
|
||||||
// a flush to guarantee any pending task is finished on flushing out delivery and pending msgs
|
// a flush to guarantee any pending task is finished on flushing out delivery and pending msgs
|
||||||
queue.flushExecutor();
|
queue.flushExecutor();
|
||||||
|
Wait.waitFor(() -> getMessageCount(queue) == 2);
|
||||||
Assert.assertEquals(2, getMessageCount(queue));
|
Assert.assertEquals(2, getMessageCount(queue));
|
||||||
Assert.assertEquals(2, getMessagesAdded(queue));
|
Assert.assertEquals(2, getMessagesAdded(queue));
|
||||||
|
|
||||||
|
|
|
@ -1430,14 +1430,14 @@ public class PagingTest extends ActiveMQTestBase {
|
||||||
|
|
||||||
producer = session.createProducer(PagingTest.ADDRESS);
|
producer = session.createProducer(PagingTest.ADDRESS);
|
||||||
|
|
||||||
for (int i = 0; i < numberOfMessages; i++) {
|
for (int i = 0; i < numberOfMessages * 2; i++) {
|
||||||
message = session.createMessage(true);
|
message = session.createMessage(true);
|
||||||
|
|
||||||
ActiveMQBuffer bodyLocal = message.getBodyBuffer();
|
ActiveMQBuffer bodyLocal = message.getBodyBuffer();
|
||||||
|
|
||||||
bodyLocal.writeBytes(body);
|
bodyLocal.writeBytes(body);
|
||||||
|
|
||||||
message.putIntProperty(new SimpleString("id"), i);
|
message.putIntProperty(new SimpleString("theid"), i);
|
||||||
|
|
||||||
producer.send(message);
|
producer.send(message);
|
||||||
if (i % 1000 == 0) {
|
if (i % 1000 == 0) {
|
||||||
|
@ -1466,12 +1466,13 @@ public class PagingTest extends ActiveMQTestBase {
|
||||||
for (int msgCount = 0; msgCount < numberOfMessages; msgCount++) {
|
for (int msgCount = 0; msgCount < numberOfMessages; msgCount++) {
|
||||||
log.info("Received " + msgCount);
|
log.info("Received " + msgCount);
|
||||||
msgReceived++;
|
msgReceived++;
|
||||||
ClientMessage msg = consumer.receiveImmediate();
|
ClientMessage msg = consumer.receive(5000);
|
||||||
if (msg == null) {
|
if (msg == null) {
|
||||||
log.info("It's null. leaving now");
|
log.info("It's null. leaving now");
|
||||||
sessionConsumer.commit();
|
sessionConsumer.commit();
|
||||||
fail("Didn't receive a message");
|
fail("Didn't receive a message");
|
||||||
}
|
}
|
||||||
|
System.out.println("Message " + msg.getIntProperty(SimpleString.toSimpleString("theid")));
|
||||||
msg.acknowledge();
|
msg.acknowledge();
|
||||||
|
|
||||||
if (msgCount % 5 == 0) {
|
if (msgCount % 5 == 0) {
|
||||||
|
|
Loading…
Reference in New Issue