use of org.neo4j.kernel.impl.transaction.log.TransactionLogWriter in project neo4j by neo4j.
the class TransactionLogFile method start.
@Override
public void start() throws IOException {
long currentLogVersion = logVersionRepository.getCurrentLogVersion();
channel = createLogChannelForVersion(currentLogVersion, context::getLastCommittedTransactionId);
context.getMonitors().newMonitor(LogRotationMonitor.class).started(channel.getPath(), currentLogVersion);
// try to set position
seekChannelPosition(currentLogVersion);
writer = new PositionAwarePhysicalFlushableChecksumChannel(channel, new NativeScopedBuffer(calculateLogBufferSize(), memoryTracker));
transactionLogWriter = new TransactionLogWriter(writer, new DbmsLogEntryWriterFactory(context.getKernelVersionProvider()));
}
use of org.neo4j.kernel.impl.transaction.log.TransactionLogWriter in project neo4j by neo4j.
the class AbstractLogTailScannerTest method logFile.
LogCreator logFile(Entry... entries) {
return (logVersion, positions) -> {
try {
AtomicLong lastTxId = new AtomicLong();
logVersionRepository.setCurrentLogVersion(logVersion, NULL);
logVersionRepository.setCheckpointLogVersion(logVersion, NULL);
LifeSupport logFileLife = new LifeSupport();
logFileLife.start();
logFileLife.add(logFiles);
LogFile logFile = logFiles.getLogFile();
var checkpointFile = logFiles.getCheckpointFile();
int previousChecksum = BASE_TX_CHECKSUM;
try {
TransactionLogWriter logWriter = logFile.getTransactionLogWriter();
LogEntryWriter writer = logWriter.getWriter();
for (Entry entry : entries) {
LogPosition currentPosition = logWriter.getCurrentPosition();
positions.put(entry, currentPosition);
if (entry instanceof StartEntry) {
writer.writeStartEntry(0, 0, previousChecksum, new byte[0]);
} else if (entry instanceof CommitEntry) {
CommitEntry commitEntry = (CommitEntry) entry;
previousChecksum = writer.writeCommitEntry(commitEntry.txId, 0);
lastTxId.set(commitEntry.txId);
} else if (entry instanceof CheckPointEntry) {
CheckPointEntry checkPointEntry = (CheckPointEntry) entry;
Entry target = checkPointEntry.withPositionOfEntry;
LogPosition logPosition = target != null ? positions.get(target) : currentPosition;
assert logPosition != null : "No registered log position for " + target;
writeCheckpoint(writer, checkpointFile, logPosition);
} else if (entry instanceof PositionEntry) {
// Don't write anything, this entry is just for registering a position so that
// another CheckPointEntry can refer to it
} else {
throw new IllegalArgumentException("Unknown entry " + entry);
}
}
} finally {
logFileLife.shutdown();
}
} catch (IOException e) {
throw new UncheckedIOException(e);
}
};
}
Aggregations