ARTEMIS-1287/ARTEMIS-1292 Complete Page on the Journal

fixing PagingTest.testDeletePhysicalPages
This commit is contained in:
Clebert Suconic 2017-07-14 15:04:43 -04:00
parent baeca47b44
commit f18b4ee0c9
7 changed files with 36 additions and 10 deletions

View File

@ -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 + "]";
} }
} }

View File

@ -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);

View File

@ -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

View File

@ -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();

View File

@ -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);

View File

@ -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));

View File

@ -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) {