ARTEMIS-4041 Improve critical IO reporting
This commit is contained in:
parent
b604545a3c
commit
49d33470f9
|
@ -152,7 +152,7 @@ public class JDBCSequentialFileFactory implements SequentialFileFactory, ActiveM
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onIOError(Exception exception, String message, SequentialFile file) {
|
public void onIOError(Throwable exception, String message, String file) {
|
||||||
criticalErrorListener.onIOException(exception, message, file);
|
criticalErrorListener.onIOException(exception, message, file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -236,7 +236,7 @@ public class JDBCSequentialFileFactory implements SequentialFileFactory, ActiveM
|
||||||
try {
|
try {
|
||||||
file.sync();
|
file.sync();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
criticalErrorListener.onIOException(e, "Error during JDBC file sync.", file);
|
criticalErrorListener.onIOException(e, "Error during JDBC file sync.", file.getFileName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -99,7 +99,7 @@ public class JDBCSequentialFileFactoryTest {
|
||||||
String jdbcDatasourceClass = ActiveMQDefaultConfiguration.getDefaultDataSourceClassName();
|
String jdbcDatasourceClass = ActiveMQDefaultConfiguration.getDefaultDataSourceClassName();
|
||||||
factory = new JDBCSequentialFileFactory(new JDBCConnectionProvider(JDBCDataSourceUtils.getDataSource(jdbcDatasourceClass, dataSourceProperties)), JDBCUtils.getSQLProvider(dataSourceProperties, tableName, SQLProvider.DatabaseStoreType.PAGE), executor, new IOCriticalErrorListener() {
|
factory = new JDBCSequentialFileFactory(new JDBCConnectionProvider(JDBCDataSourceUtils.getDataSource(jdbcDatasourceClass, dataSourceProperties)), JDBCUtils.getSQLProvider(dataSourceProperties, tableName, SQLProvider.DatabaseStoreType.PAGE), executor, new IOCriticalErrorListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onIOException(Throwable code, String message, SequentialFile file) {
|
public void onIOException(Throwable code, String message, String file) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
factory.start();
|
factory.start();
|
||||||
|
|
|
@ -126,7 +126,7 @@ public abstract class AbstractSequentialFile implements SequentialFile {
|
||||||
} catch (ClosedChannelException e) {
|
} catch (ClosedChannelException e) {
|
||||||
throw e;
|
throw e;
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
factory.onIOError(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this);
|
factory.onIOError(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this.file.getName());
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -180,8 +180,13 @@ public abstract class AbstractSequentialFileFactory implements SequentialFileFac
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onIOError(Exception exception, String message, SequentialFile file) {
|
public void onIOError(Throwable exception, String message, String file) {
|
||||||
|
if (file != null) {
|
||||||
|
ActiveMQJournalLogger.LOGGER.criticalIOFile(message, file, exception);
|
||||||
|
} else {
|
||||||
ActiveMQJournalLogger.LOGGER.criticalIO(message, exception);
|
ActiveMQJournalLogger.LOGGER.criticalIO(message, exception);
|
||||||
|
}
|
||||||
|
|
||||||
if (critialErrorListener != null) {
|
if (critialErrorListener != null) {
|
||||||
critialErrorListener.onIOException(exception, message, file);
|
critialErrorListener.onIOException(exception, message, file);
|
||||||
}
|
}
|
||||||
|
@ -222,7 +227,7 @@ public abstract class AbstractSequentialFileFactory implements SequentialFileFac
|
||||||
boolean ok = journalDir.mkdirs();
|
boolean ok = journalDir.mkdirs();
|
||||||
if (!ok && !journalDir.exists()) {
|
if (!ok && !journalDir.exists()) {
|
||||||
IOException e = new IOException("Unable to create directory: " + journalDir);
|
IOException e = new IOException("Unable to create directory: " + journalDir);
|
||||||
onIOError(e, e.getMessage(), null);
|
onIOError(e, e.getMessage());
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,5 +21,5 @@ package org.apache.activemq.artemis.core.io;
|
||||||
*/
|
*/
|
||||||
public interface IOCriticalErrorListener {
|
public interface IOCriticalErrorListener {
|
||||||
|
|
||||||
void onIOException(Throwable code, String message, SequentialFile file);
|
void onIOException(Throwable code, String message, String file);
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,7 +55,15 @@ public interface SequentialFileFactory {
|
||||||
/**
|
/**
|
||||||
* The SequentialFile will call this method when a disk IO Error happens during the live phase.
|
* The SequentialFile will call this method when a disk IO Error happens during the live phase.
|
||||||
*/
|
*/
|
||||||
void onIOError(Exception exception, String message, SequentialFile file);
|
void onIOError(Throwable exception, String message, String file);
|
||||||
|
|
||||||
|
default void onIOError(Throwable exception, String message, SequentialFile file) {
|
||||||
|
onIOError(exception, message, file.getFileName());
|
||||||
|
}
|
||||||
|
|
||||||
|
default void onIOError(Throwable exception, String message) {
|
||||||
|
onIOError(exception, message, (String) null);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* used for cases where you need direct buffer outside of the journal context.
|
* used for cases where you need direct buffer outside of the journal context.
|
||||||
|
|
|
@ -418,7 +418,7 @@ public final class AIOSequentialFileFactory extends AbstractSequentialFileFactor
|
||||||
if (callback != null) {
|
if (callback != null) {
|
||||||
callback.onError(errorCode, errorMessage);
|
callback.onError(errorCode, errorMessage);
|
||||||
}
|
}
|
||||||
onIOError(new ActiveMQException(errorCode, errorMessage), errorMessage, null);
|
onIOError(new ActiveMQException(errorCode, errorMessage), errorMessage);
|
||||||
errorMessage = null;
|
errorMessage = null;
|
||||||
} else {
|
} else {
|
||||||
if (callback != null) {
|
if (callback != null) {
|
||||||
|
@ -447,7 +447,7 @@ public final class AIOSequentialFileFactory extends AbstractSequentialFileFactor
|
||||||
libaioContext.poll();
|
libaioContext.poll();
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
logger.warn(e.getMessage(), e);
|
logger.warn(e.getMessage(), e);
|
||||||
onIOError(new ActiveMQException("Error on libaio poll"), e.getMessage(), null);
|
onIOError(new ActiveMQException("Error on libaio poll"), e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -168,7 +168,7 @@ final class MappedSequentialFile implements SequentialFile {
|
||||||
callback.done();
|
callback.done();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
if (this.criticalErrorListener != null) {
|
if (this.criticalErrorListener != null) {
|
||||||
this.criticalErrorListener.onIOException(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this);
|
this.criticalErrorListener.onIOException(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this.getFileName());
|
||||||
}
|
}
|
||||||
callback.onError(ActiveMQExceptionType.IO_ERROR.getCode(), e.getMessage());
|
callback.onError(ActiveMQExceptionType.IO_ERROR.getCode(), e.getMessage());
|
||||||
throw e;
|
throw e;
|
||||||
|
@ -204,7 +204,7 @@ final class MappedSequentialFile implements SequentialFile {
|
||||||
callback.done();
|
callback.done();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
if (this.criticalErrorListener != null) {
|
if (this.criticalErrorListener != null) {
|
||||||
this.criticalErrorListener.onIOException(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this);
|
this.criticalErrorListener.onIOException(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this.getFileName());
|
||||||
}
|
}
|
||||||
callback.onError(ActiveMQExceptionType.IO_ERROR.getCode(), e.getMessage());
|
callback.onError(ActiveMQExceptionType.IO_ERROR.getCode(), e.getMessage());
|
||||||
throw e;
|
throw e;
|
||||||
|
@ -241,7 +241,7 @@ final class MappedSequentialFile implements SequentialFile {
|
||||||
callback.done();
|
callback.done();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
if (this.criticalErrorListener != null) {
|
if (this.criticalErrorListener != null) {
|
||||||
this.criticalErrorListener.onIOException(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this);
|
this.criticalErrorListener.onIOException(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this.getFileName());
|
||||||
}
|
}
|
||||||
callback.onError(ActiveMQExceptionType.IO_ERROR.getCode(), e.getMessage());
|
callback.onError(ActiveMQExceptionType.IO_ERROR.getCode(), e.getMessage());
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
|
@ -315,7 +315,7 @@ final class MappedSequentialFile implements SequentialFile {
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
if (this.criticalErrorListener != null) {
|
if (this.criticalErrorListener != null) {
|
||||||
this.criticalErrorListener.onIOException(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this);
|
this.criticalErrorListener.onIOException(new ActiveMQIOErrorException(e.getMessage(), e), e.getMessage(), this.getFileName());
|
||||||
}
|
}
|
||||||
callback.onError(ActiveMQExceptionType.IO_ERROR.getCode(), e.getMessage());
|
callback.onError(ActiveMQExceptionType.IO_ERROR.getCode(), e.getMessage());
|
||||||
throw e;
|
throw e;
|
||||||
|
|
|
@ -102,7 +102,7 @@ public class JournalFilesRepository {
|
||||||
pushOpenedFile();
|
pushOpenedFile();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
ActiveMQJournalLogger.LOGGER.errorPushingFile(e);
|
ActiveMQJournalLogger.LOGGER.errorPushingFile(e);
|
||||||
fileFactory.onIOError(e, "unable to open ", null);
|
fileFactory.onIOError(e, "unable to open ");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -495,7 +495,7 @@ public class JournalFilesRepository {
|
||||||
try {
|
try {
|
||||||
nextFile = takeFile(true, true, true, false);
|
nextFile = takeFile(true, true, true, false);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
fileFactory.onIOError(e, "unable to open ", null);
|
fileFactory.onIOError(e, "unable to open ");
|
||||||
// We need to reconnect the current file with the timed buffer as we were not able to roll the file forward
|
// We need to reconnect the current file with the timed buffer as we were not able to roll the file forward
|
||||||
// If you don't do this you will get a NPE in TimedBuffer::checkSize where it uses the bufferobserver
|
// If you don't do this you will get a NPE in TimedBuffer::checkSize where it uses the bufferobserver
|
||||||
fileFactory.activateBuffer(journal.getCurrentFile().getFile());
|
fileFactory.activateBuffer(journal.getCurrentFile().getFile());
|
||||||
|
|
|
@ -1888,11 +1888,7 @@ public class JournalImpl extends JournalBase implements TestableJournal, Journal
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
try {
|
fileFactory.onIOError(e, e.getMessage());
|
||||||
criticalIO(e);
|
|
||||||
} catch (Throwable ignored) {
|
|
||||||
logger.warn(ignored.getMessage(), ignored);
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
} finally {
|
} finally {
|
||||||
journalLock.writeLock().unlock();
|
journalLock.writeLock().unlock();
|
||||||
|
@ -1909,11 +1905,7 @@ public class JournalImpl extends JournalBase implements TestableJournal, Journal
|
||||||
logger.debug("Finished compacting on journal {}", this);
|
logger.debug("Finished compacting on journal {}", this);
|
||||||
|
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
try {
|
fileFactory.onIOError(e, e.getMessage());
|
||||||
criticalIO(e);
|
|
||||||
} catch (Throwable ignored) {
|
|
||||||
logger.warn(ignored.getMessage(), ignored);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
compactorLock.writeLock().unlock();
|
compactorLock.writeLock().unlock();
|
||||||
|
@ -2478,11 +2470,7 @@ public class JournalImpl extends JournalBase implements TestableJournal, Journal
|
||||||
try {
|
try {
|
||||||
Files.copy(copyFrom.toPath(), copyTo.toPath(), StandardCopyOption.REPLACE_EXISTING);
|
Files.copy(copyFrom.toPath(), copyTo.toPath(), StandardCopyOption.REPLACE_EXISTING);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.warn(e.getMessage(), e);
|
fileFactory.onIOError(e, e.getMessage(), copyFrom.getName());
|
||||||
try {
|
|
||||||
criticalIO(e);
|
|
||||||
} catch (Exception ignored) {
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
@ -2490,7 +2478,7 @@ public class JournalImpl extends JournalBase implements TestableJournal, Journal
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.warn(e.getMessage(), e);
|
logger.warn(e.getMessage(), e);
|
||||||
if (criticalErrorListener != null) {
|
if (criticalErrorListener != null) {
|
||||||
criticalErrorListener.onIOException(e, e.getMessage(), fileToCopy.getFile());
|
criticalErrorListener.onIOException(e, e.getMessage(), fileToCopy.getFile().getFileName());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3507,21 +3495,21 @@ public class JournalImpl extends JournalBase implements TestableJournal, Journal
|
||||||
|
|
||||||
// The same check needs to be done at the new file also
|
// The same check needs to be done at the new file also
|
||||||
if (!currentFile.getFile().fits(size)) {
|
if (!currentFile.getFile().fits(size)) {
|
||||||
// Sanity check, this should never happen
|
// The exception will be thrown by criticalIO
|
||||||
throw new IllegalStateException("Invalid logic on buffer allocation");
|
Exception reportingException = ActiveMQJournalBundle.BUNDLE.unexpectedFileSize(currentFile.getFile().getFileName(), size, currentFile.getFile().size());
|
||||||
|
fileFactory.onIOError(reportingException, reportingException.getMessage());
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return currentFile;
|
return currentFile;
|
||||||
} catch (Throwable e) {
|
} catch (Throwable e) {
|
||||||
criticalIO(e);
|
criticalIO(e, null);
|
||||||
return null; // this will never happen, the method will call throw
|
return null; // this will never happen, the method will call throw
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void criticalIO(Throwable e) throws Exception {
|
private void criticalIO(Throwable e, SequentialFile file) throws Exception {
|
||||||
if (criticalErrorListener != null) {
|
fileFactory.onIOError(e, e.getMessage(), file);
|
||||||
criticalErrorListener.onIOException(e, e.getMessage(), currentFile == null ? null : currentFile.getFile());
|
|
||||||
}
|
|
||||||
if (e instanceof Exception) {
|
if (e instanceof Exception) {
|
||||||
throw (Exception) e;
|
throw (Exception) e;
|
||||||
} else if (e instanceof IllegalStateException) {
|
} else if (e instanceof IllegalStateException) {
|
||||||
|
|
|
@ -46,4 +46,7 @@ public interface ActiveMQJournalBundle {
|
||||||
|
|
||||||
@Message(id = 149005, value = "Message of {} bytes is bigger than the max record size of {} bytes. You should try to move large application properties to the message body.")
|
@Message(id = 149005, value = "Message of {} bytes is bigger than the max record size of {} bytes. You should try to move large application properties to the message body.")
|
||||||
ActiveMQIOErrorException recordLargerThanStoreMax(long recordSize, long maxRecordSize);
|
ActiveMQIOErrorException recordLargerThanStoreMax(long recordSize, long maxRecordSize);
|
||||||
|
|
||||||
|
@Message(id = 149006, value = "The file system returned a file {} with unexpected file size. The broker requested a file sized as {} but the system returned a file sized as {}")
|
||||||
|
ActiveMQIOErrorException unexpectedFileSize(String fileName, long expectedSize, long returnedSize);
|
||||||
}
|
}
|
||||||
|
|
|
@ -198,6 +198,9 @@ public interface ActiveMQJournalLogger {
|
||||||
void cantOpenFileTimeout(long timeout);
|
void cantOpenFileTimeout(long timeout);
|
||||||
|
|
||||||
@LogMessage(id = 144010, value = "Critical IO Exception happened: {}", level = LogMessage.Level.WARN)
|
@LogMessage(id = 144010, value = "Critical IO Exception happened: {}", level = LogMessage.Level.WARN)
|
||||||
void criticalIO(String message, Exception error);
|
void criticalIO(String message, Throwable error);
|
||||||
|
|
||||||
|
// same as criticalIO but with the FileName associated (if there's a file available)
|
||||||
|
@LogMessage(id = 144011, value = "Critical IO Exception happened: {} on {}", level = LogMessage.Level.WARN)
|
||||||
|
void criticalIOFile(String message, String fileName, Throwable error);
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,7 +53,7 @@ public class FileIOUtilTest {
|
||||||
Assume.assumeTrue(LibaioContext.isLoaded());
|
Assume.assumeTrue(LibaioContext.isLoaded());
|
||||||
AtomicInteger errors = new AtomicInteger(0);
|
AtomicInteger errors = new AtomicInteger(0);
|
||||||
|
|
||||||
SequentialFileFactory factory = new AIOSequentialFileFactory(temporaryFolder.getRoot(), (Throwable error, String message, SequentialFile file) -> errors.incrementAndGet(), 4 * 1024);
|
SequentialFileFactory factory = new AIOSequentialFileFactory(temporaryFolder.getRoot(), (Throwable error, String message, String file) -> errors.incrementAndGet(), 4 * 1024);
|
||||||
factory.start();
|
factory.start();
|
||||||
|
|
||||||
SequentialFile file = factory.createSequentialFile("fileAIO.bin");
|
SequentialFile file = factory.createSequentialFile("fileAIO.bin");
|
||||||
|
|
|
@ -93,7 +93,7 @@ public class NullStorageManager implements StorageManager {
|
||||||
public NullStorageManager() {
|
public NullStorageManager() {
|
||||||
this(new IOCriticalErrorListener() {
|
this(new IOCriticalErrorListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onIOException(Throwable code, String message, SequentialFile file) {
|
public void onIOException(Throwable code, String message, String file) {
|
||||||
code.printStackTrace();
|
code.printStackTrace();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -78,7 +78,6 @@ import org.apache.activemq.artemis.core.deployers.impl.FileConfigurationParser;
|
||||||
import org.apache.activemq.artemis.core.filter.Filter;
|
import org.apache.activemq.artemis.core.filter.Filter;
|
||||||
import org.apache.activemq.artemis.core.filter.impl.FilterImpl;
|
import org.apache.activemq.artemis.core.filter.impl.FilterImpl;
|
||||||
import org.apache.activemq.artemis.core.io.IOCriticalErrorListener;
|
import org.apache.activemq.artemis.core.io.IOCriticalErrorListener;
|
||||||
import org.apache.activemq.artemis.core.io.SequentialFile;
|
|
||||||
import org.apache.activemq.artemis.core.io.aio.AIOSequentialFileFactory;
|
import org.apache.activemq.artemis.core.io.aio.AIOSequentialFileFactory;
|
||||||
import org.apache.activemq.artemis.core.journal.JournalLoadInformation;
|
import org.apache.activemq.artemis.core.journal.JournalLoadInformation;
|
||||||
import org.apache.activemq.artemis.core.management.impl.ActiveMQServerControlImpl;
|
import org.apache.activemq.artemis.core.management.impl.ActiveMQServerControlImpl;
|
||||||
|
@ -4230,7 +4229,7 @@ public class ActiveMQServerImpl implements ActiveMQServer {
|
||||||
private final AtomicBoolean failedAlready = new AtomicBoolean();
|
private final AtomicBoolean failedAlready = new AtomicBoolean();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized void onIOException(Throwable cause, String message, SequentialFile file) {
|
public synchronized void onIOException(Throwable cause, String message, String file) {
|
||||||
if (!failedAlready.compareAndSet(false, true)) {
|
if (!failedAlready.compareAndSet(false, true)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -4238,7 +4237,7 @@ public class ActiveMQServerImpl implements ActiveMQServer {
|
||||||
if (file == null) {
|
if (file == null) {
|
||||||
ActiveMQServerLogger.LOGGER.ioCriticalIOError(message, "NULL", cause);
|
ActiveMQServerLogger.LOGGER.ioCriticalIOError(message, "NULL", cause);
|
||||||
} else {
|
} else {
|
||||||
ActiveMQServerLogger.LOGGER.ioCriticalIOError(message, file.toString(), cause);
|
ActiveMQServerLogger.LOGGER.ioCriticalIOError(message, file, cause);
|
||||||
}
|
}
|
||||||
|
|
||||||
stopTheServer(true);
|
stopTheServer(true);
|
||||||
|
|
|
@ -31,7 +31,6 @@ import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import org.apache.activemq.artemis.core.config.storage.DatabaseStorageConfiguration;
|
import org.apache.activemq.artemis.core.config.storage.DatabaseStorageConfiguration;
|
||||||
import org.apache.activemq.artemis.core.io.IOCriticalErrorListener;
|
import org.apache.activemq.artemis.core.io.IOCriticalErrorListener;
|
||||||
import org.apache.activemq.artemis.core.io.SequentialFile;
|
|
||||||
import org.apache.activemq.artemis.core.journal.IOCompletion;
|
import org.apache.activemq.artemis.core.journal.IOCompletion;
|
||||||
import org.apache.activemq.artemis.core.journal.PreparedTransactionInfo;
|
import org.apache.activemq.artemis.core.journal.PreparedTransactionInfo;
|
||||||
import org.apache.activemq.artemis.core.journal.RecordInfo;
|
import org.apache.activemq.artemis.core.journal.RecordInfo;
|
||||||
|
@ -128,7 +127,7 @@ public class JDBCJournalTest extends ActiveMQTestBase {
|
||||||
executorService = Executors.newSingleThreadExecutor();
|
executorService = Executors.newSingleThreadExecutor();
|
||||||
journal = new JDBCJournalImpl(dbConf.getConnectionProvider(), sqlProvider, scheduledExecutorService, executorService, new IOCriticalErrorListener() {
|
journal = new JDBCJournalImpl(dbConf.getConnectionProvider(), sqlProvider, scheduledExecutorService, executorService, new IOCriticalErrorListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onIOException(Throwable code, String message, SequentialFile file) {
|
public void onIOException(Throwable code, String message, String file) {
|
||||||
|
|
||||||
}
|
}
|
||||||
}, 5);
|
}, 5);
|
||||||
|
|
|
@ -50,7 +50,7 @@ public class AsyncOpenCloseTest extends ActiveMQTestBase {
|
||||||
Assume.assumeTrue(LibaioContext.isLoaded());
|
Assume.assumeTrue(LibaioContext.isLoaded());
|
||||||
AtomicInteger errors = new AtomicInteger(0);
|
AtomicInteger errors = new AtomicInteger(0);
|
||||||
|
|
||||||
SequentialFileFactory factory = new AIOSequentialFileFactory(temporaryFolder.getRoot(), (Throwable error, String message, SequentialFile file) -> errors.incrementAndGet(), 4 * 1024);
|
SequentialFileFactory factory = new AIOSequentialFileFactory(temporaryFolder.getRoot(), (Throwable error, String message, String file) -> errors.incrementAndGet(), 4 * 1024);
|
||||||
factory.start();
|
factory.start();
|
||||||
|
|
||||||
SequentialFile file = factory.createSequentialFile("fileAIO.bin");
|
SequentialFile file = factory.createSequentialFile("fileAIO.bin");
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
package org.apache.activemq.artemis.tests.integration.journal;
|
package org.apache.activemq.artemis.tests.integration.journal;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
|
@ -29,9 +30,13 @@ import org.apache.activemq.artemis.core.journal.EncodingSupport;
|
||||||
import org.apache.activemq.artemis.tests.unit.core.journal.impl.SequentialFileFactoryTestBase;
|
import org.apache.activemq.artemis.tests.unit.core.journal.impl.SequentialFileFactoryTestBase;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
public class NIOSequentialFileFactoryTest extends SequentialFileFactoryTestBase {
|
public class NIOSequentialFileFactoryTest extends SequentialFileFactoryTestBase {
|
||||||
|
|
||||||
|
private static final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected SequentialFileFactory createFactory(String folder) {
|
protected SequentialFileFactory createFactory(String folder) {
|
||||||
return new NIOSequentialFileFactory(new File(folder), true, 1);
|
return new NIOSequentialFileFactory(new File(folder), true, 1);
|
||||||
|
@ -60,8 +65,8 @@ public class NIOSequentialFileFactoryTest extends SequentialFileFactoryTestBase
|
||||||
final AtomicInteger calls = new AtomicInteger(0);
|
final AtomicInteger calls = new AtomicInteger(0);
|
||||||
final NIOSequentialFileFactory factory = new NIOSequentialFileFactory(new File(getTestDir()), new IOCriticalErrorListener() {
|
final NIOSequentialFileFactory factory = new NIOSequentialFileFactory(new File(getTestDir()), new IOCriticalErrorListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onIOException(Throwable code, String message, SequentialFile file) {
|
public void onIOException(Throwable code, String message, String file) {
|
||||||
new Exception("shutdown").printStackTrace();
|
logger.debug("IOException happening", code);
|
||||||
calls.incrementAndGet();
|
calls.incrementAndGet();
|
||||||
}
|
}
|
||||||
}, 1);
|
}, 1);
|
||||||
|
|
|
@ -662,7 +662,7 @@ public class FakeSequentialFileFactory implements SequentialFileFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onIOError(Exception exception, String message, SequentialFile file) {
|
public void onIOError(Throwable exception, String message, String file) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue