use of org.neo4j.kernel.impl.transaction.log.entry.LogEntryCommit in project neo4j by neo4j.
the class IndexCreationTest method verifyThatIndexCreationTransactionIsTheFirstOne.
private void verifyThatIndexCreationTransactionIsTheFirstOne() throws Exception {
PhysicalLogFile pLogFile = db.getDependencyResolver().resolveDependency(PhysicalLogFile.class);
long version = db.getDependencyResolver().resolveDependency(LogVersionRepository.class).getCurrentLogVersion();
db.getDependencyResolver().resolveDependency(LogRotation.class).rotateLogFile();
db.getDependencyResolver().resolveDependency(CheckPointer.class).forceCheckPoint(new SimpleTriggerInfo("test"));
ReadableLogChannel logChannel = pLogFile.getReader(LogPosition.start(version));
final AtomicBoolean success = new AtomicBoolean(false);
try (IOCursor<LogEntry> cursor = new LogEntryCursor(new VersionAwareLogEntryReader<>(), logChannel)) {
List<StorageCommand> commandsInFirstEntry = new ArrayList<>();
boolean startFound = false;
while (cursor.next()) {
LogEntry entry = cursor.get();
if (entry instanceof LogEntryStart) {
if (startFound) {
throw new IllegalArgumentException("More than one start entry");
}
startFound = true;
}
if (startFound && entry instanceof LogEntryCommand) {
commandsInFirstEntry.add(entry.<LogEntryCommand>as().getXaCommand());
}
if (entry instanceof LogEntryCommit) {
// The first COMMIT
assertTrue(startFound);
assertFalse("Index creation transaction wasn't the first one", commandsInFirstEntry.isEmpty());
List<StorageCommand> createCommands = Iterators.asList(new FilteringIterator<>(commandsInFirstEntry.iterator(), item -> item instanceof IndexDefineCommand));
assertEquals(1, createCommands.size());
success.set(true);
break;
}
}
}
assertTrue("Didn't find any commit record in log " + version, success.get());
}
use of org.neo4j.kernel.impl.transaction.log.entry.LogEntryCommit in project neo4j by neo4j.
the class BatchingTxApplierTest method createTxWithId.
private CommittedTransactionRepresentation createTxWithId(long txId) {
CommittedTransactionRepresentation tx = mock(CommittedTransactionRepresentation.class);
LogEntryCommit commitEntry = mock(LogEntryCommit.class);
when(commitEntry.getTxId()).thenReturn(txId);
TransactionRepresentation txRep = mock(TransactionRepresentation.class);
when(tx.getTransactionRepresentation()).thenReturn(txRep);
when(tx.getCommitEntry()).thenReturn(commitEntry);
return tx;
}
use of org.neo4j.kernel.impl.transaction.log.entry.LogEntryCommit in project neo4j by neo4j.
the class CommittedTransactionSerializer method visit.
@Override
public boolean visit(CommittedTransactionRepresentation tx) throws IOException {
LogEntryStart startEntry = tx.getStartEntry();
writer.writeStartEntry(startEntry.getMasterId(), startEntry.getLocalId(), startEntry.getTimeWritten(), startEntry.getLastCommittedTxWhenTransactionStarted(), startEntry.getAdditionalHeader());
writer.serialize(tx.getTransactionRepresentation());
LogEntryCommit commitEntry = tx.getCommitEntry();
writer.writeCommitEntry(commitEntry.getTxId(), commitEntry.getTimeWritten());
return false;
}
use of org.neo4j.kernel.impl.transaction.log.entry.LogEntryCommit in project neo4j by neo4j.
the class CheckTxLogs method scan.
private <C extends Command, R extends AbstractBaseRecord> boolean scan(PhysicalLogFiles logFiles, InconsistenciesHandler handler, CheckType<C, R> check, boolean checkTxIds) throws IOException {
out.println("Checking logs for " + check.name() + " inconsistencies");
CommittedRecords<R> state = new CommittedRecords<>(check);
List<CommandAndLogVersion> txCommands = new ArrayList<>();
boolean validLogs = true;
long commandsRead = 0;
long lastSeenTxId = BASE_TX_ID;
try (LogEntryCursor logEntryCursor = LogTestUtils.openLogs(fs, logFiles)) {
while (logEntryCursor.next()) {
LogEntry entry = logEntryCursor.get();
if (entry instanceof LogEntryCommand) {
StorageCommand command = ((LogEntryCommand) entry).getXaCommand();
if (check.commandClass().isInstance(command)) {
long logVersion = logEntryCursor.getCurrentLogVersion();
txCommands.add(new CommandAndLogVersion(command, logVersion));
}
} else if (entry instanceof LogEntryCommit) {
long txId = ((LogEntryCommit) entry).getTxId();
if (checkTxIds) {
validLogs &= checkNoDuplicatedTxsInTheLog(lastSeenTxId, txId, handler);
lastSeenTxId = txId;
}
for (CommandAndLogVersion txCommand : txCommands) {
validLogs &= checkAndHandleInconsistencies(txCommand, check, state, txId, handler);
}
txCommands.clear();
}
commandsRead++;
}
}
out.println("Processed " + commandsRead + " commands");
out.println(state);
if (!txCommands.isEmpty()) {
out.println("Found " + txCommands.size() + " uncommitted commands at the end.");
for (CommandAndLogVersion txCommand : txCommands) {
validLogs &= checkAndHandleInconsistencies(txCommand, check, state, -1, handler);
}
txCommands.clear();
}
return validLogs;
}
use of org.neo4j.kernel.impl.transaction.log.entry.LogEntryCommit in project neo4j by neo4j.
the class LegacyLogs method getTransactionInformation.
public Optional<TransactionId> getTransactionInformation(File storeDir, long transactionId) throws IOException {
List<File> logFiles = Arrays.asList(fs.listFiles(storeDir, versionedLegacyLogFilesFilter));
logFiles.sort(NEWEST_FIRST);
for (File file : logFiles) {
Pair<LogHeader, IOCursor<LogEntry>> pair = reader.openReadableChannel(file);
boolean hadAnyTransactions = false;
try (IOCursor<LogEntry> cursor = pair.other()) {
// The log entries will come sorted from this cursor, so no need to keep track of identifiers and such.
LogEntryStart startEntry = null;
while (cursor.next()) {
LogEntry logEntry = cursor.get();
if (logEntry instanceof LogEntryStart) {
startEntry = (LogEntryStart) logEntry;
} else if (logEntry instanceof LogEntryCommit) {
hadAnyTransactions = true;
LogEntryCommit commitEntry = logEntry.as();
if (commitEntry.getTxId() == transactionId) {
return Optional.of(new TransactionId(transactionId, startEntry.checksum(), commitEntry.getTimeWritten()));
}
}
}
}
if (hadAnyTransactions) {
// No need to go further back than this. We're looking for the last transaction
break;
}
}
return Optional.empty();
}
Aggregations