All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.neo4j.kernel.impl.transaction.log.TransactionCommitment Maven / Gradle / Ivy

Go to download

Neo4j kernel is a lightweight, embedded Java database designed to store data structured as graphs rather than tables. For more information, see http://neo4j.org.

There is a newer version: 5.26.0
Show newest version
/*
 * Copyright (c) "Neo4j"
 * Neo4j Sweden AB [https://neo4j.com]
 *
 * This file is part of Neo4j.
 *
 * Neo4j is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
package org.neo4j.kernel.impl.transaction.log;

import static org.neo4j.storageengine.AppendIndexProvider.UNKNOWN_APPEND_INDEX;

import org.neo4j.kernel.KernelVersion;
import org.neo4j.storageengine.api.Commitment;
import org.neo4j.storageengine.api.TransactionIdStore;

public class TransactionCommitment implements Commitment {

    private final TransactionIdStore transactionIdStore;
    private boolean committed;
    private boolean firstBatch;
    private boolean lastBatch;
    private long transactionId;
    private int checksum;
    private long consensusIndex;
    private KernelVersion kernelVersion;
    private LogPosition logPositionBeforeCommit;
    private LogPosition logPositionAfterCommit;
    private long transactionCommitTimestamp;

    private long firstAppendIndex;
    private long currentBatchAppendIndex = UNKNOWN_APPEND_INDEX;
    private long lastClosedAppendIndex = UNKNOWN_APPEND_INDEX;

    TransactionCommitment(TransactionIdStore transactionIdStore) {
        this.transactionIdStore = transactionIdStore;
    }

    @Override
    public void commit(
            long transactionId,
            long appendIndex,
            boolean firstBatch,
            boolean lastBatch,
            KernelVersion kernelVersion,
            LogPosition logPositionBeforeCommit,
            LogPosition logPositionAfterCommit,
            int checksum,
            long consensusIndex) {
        this.transactionId = transactionId;
        this.kernelVersion = kernelVersion;
        this.logPositionBeforeCommit = logPositionBeforeCommit;
        this.logPositionAfterCommit = logPositionAfterCommit;
        this.checksum = checksum;
        this.consensusIndex = consensusIndex;
        this.firstBatch = firstBatch;
        this.lastBatch = lastBatch;
        this.currentBatchAppendIndex = appendIndex;
    }

    @Override
    public void publishAsCommitted(long transactionCommitTimestamp, long firstAppendIndex) {
        this.committed = true;
        this.firstAppendIndex = firstAppendIndex;
        this.transactionCommitTimestamp = transactionCommitTimestamp;
        transactionIdStore.transactionCommitted(
                transactionId, firstAppendIndex, kernelVersion, checksum, transactionCommitTimestamp, consensusIndex);
    }

    @Override
    public void publishAsCommitedLastBatch() {
        transactionIdStore.appendBatch(
                transactionId,
                currentBatchAppendIndex,
                firstBatch,
                lastBatch,
                logPositionBeforeCommit,
                logPositionAfterCommit);
    }

    @Override
    public void publishAsClosed() {
        if (lastClosedAppendIndex != currentBatchAppendIndex) {
            transactionIdStore.batchClosed(
                    transactionId,
                    currentBatchAppendIndex,
                    firstBatch,
                    lastBatch,
                    kernelVersion,
                    logPositionAfterCommit);
            lastClosedAppendIndex = currentBatchAppendIndex;
        }
        if (committed) {
            transactionIdStore.transactionClosed(
                    transactionId,
                    firstAppendIndex,
                    kernelVersion,
                    logPositionAfterCommit.getLogVersion(),
                    logPositionAfterCommit.getByteOffset(),
                    checksum,
                    transactionCommitTimestamp,
                    consensusIndex);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy