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

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

package org.jgroups.protocols.raft;

import java.io.DataInput;
import java.io.DataOutput;

/**
 * Interface of a state machine which stores data in memory. Committed log entries are applied to the state machine.
 * @author Bela Ban
 * @since  0.1
 */
public interface StateMachine {
    /**
     * Applies a command to the state machine. The contents of the byte[] buffer are interpreted by the state machine.
     * The command could for example be a set(), remove() or clear() command.
     * @param data The byte[] buffer
     * @param offset The offset at which the data starts
     * @param length The length of the data
     * @return A serialized response value, or null (e.g. if the method returned void)
     * @throws Exception Thrown on deserialization or other failure
     */
    byte[]     apply(byte[] data, int offset, int length) throws Exception;  // tbd: should we use NIO ByteBuffers ?

    /**
     * Reads the contents of the state machine from an input stream. This can be the case when an InstallSnapshot RPC
     * is used to bootstrap a new node, or a node that's lagging far behind.

* The parsing depends on the concrete state machine implementation, but the idea is that the stream is a sequence * of commands, each of which can be passed to {@link #apply(byte[],int,int)}.

* The state machine may need to block modifications until the contents have been set (unless e.g. copy-on-write * is used)

* The state machine implementation may need to remove all contents before populating itself from the stream. * @param in The input stream */ void readContentFrom(DataInput in) throws Exception; /** * Writes the contents of the state machine to an output stream. This is typically called on the leader to * provide state to a new node, or a node that's lagging far behind.

* Updates to the state machine may need to be put on hold while the state is written to the output stream. * @param out The output stream */ void writeContentTo(DataOutput out) throws Exception; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy