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

org.jgroups.protocols.raft.Log Maven / Gradle / Ivy

package org.jgroups.protocols.raft;

import org.jgroups.Address;

import java.util.Map;
import java.util.function.ObjIntConsumer;

/**
 * The interface for a persistent log. See doc/design/Log.txt for details.
 * @author Bela Ban
 * @since  0.1
 */
public interface Log {

    /** Called after the instance has been created
     * @param log_name The name of the log. Implementations can create a DB or file named after this, e.g.
     *                 /tmp/.log
     * @param args A hashmap of configuration information (impl-dependent) to configure itself. May be null
     */
    void init(String log_name, Map args) throws Exception;

    /** Called when the instance is closed. Should release resource, ie. close a DB connection */
    void close();

    /** Remove the persistent store, e.g. DB table, or file */
    void delete();

    /** Returns the current term */
    int currentTerm();

    /** Sets the current term */
    Log currentTerm(int new_term);

    /** Returns the address of the candidate that this node voted for in the current term */
    Address votedFor();

    /** Sets the address of the member this node voted for in the current term. Only invoked once per term */
    Log votedFor(Address member);

    /** Returns the current commit index. (May get removed as the RAFT paper has this as in-memory attribute) */
    int commitIndex();

    /**
     * Sets commitIndex to a new value
     * @param new_index The new index to set commitIndex to. May throw an exception if new_index > lastApplied()
     * @return the log
     */
    Log commitIndex(int new_index);

    /** Returns the index of the firstApplied entry */
    int firstApplied();

    /** Returns the index of the last applied append operation (May get removed as this should be in-memory)

* This value is set by {@link #append(int,boolean,LogEntry...)} */ int lastApplied(); /** * Append the entries starting at index. Advance last_applied by the number of entries appended.

* This is used by the leader when appending entries before sending AppendEntries requests to cluster members. * Contrary to {@link #append(int,boolean,LogEntry...)}, no consistency check needs to be performed. * @param index The index at which to append the entries. Should be the same as lastApplied. LastApplied needs * to be incremented by the number of entries appended * @param overwrite If there is an existing entry and overwrite is true, overwrite it. Else throw an exception * @param entries The entries to append */ void append(int index, boolean overwrite, LogEntry... entries); /** * Delete all entries starting from start_index. * Updates current_term and last_applied accordingly * * @param index The index * @return The LogEntry, or null if none's present at index. */ LogEntry get(int index); /** * Truncates the log up to (and excluding) index. All entries < index are removed. First = index. * @param index If greater than commit_index, commit_index will be used instead */ void truncate(int index); /** * Delete all entries starting from start_index (including the entry at start_index). * Updates current_term and last_applied accordingly * * @param start_index */ void deleteAllEntriesStartingFrom(int start_index); /** * Applies function to all elements of the log in range [max(start_index,first_applied) .. min(last_applied,end_index)]. * @param function The function to be applied * @param start_index The start index. If smaller than first_applied, first_applied will be used * @param end_index The end index. If greater than last_applied, last_applied will be used */ void forEach(ObjIntConsumer function, int start_index, int end_index); /** Applies a function to all elements in range [first_applied .. last_applied] */ void forEach(ObjIntConsumer function); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy