org.jgroups.raft.RaftHandle Maven / Gradle / Ivy
package org.jgroups.raft;
import org.jgroups.Address;
import org.jgroups.JChannel;
import org.jgroups.protocols.raft.*;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.TimeUnit;
import java.util.function.ObjIntConsumer;
/**
* Main interaction point for applications with jgroups-raft. Provides methods to make changes, register a state machine,
* get commit-index and last-applied, register {@link org.jgroups.protocols.raft.RAFT.RoleChange} listeners etc
* Sample use:
*
* JChannel ch=createChannel();
* RaftHandle handle=new RaftHandle(ch, new StateMachineImpl()); // implements StateMachine
* handle.addRoleListener(this);
* handle.setAsync(buf, 0, buf.length).whenComplete((buf,ex) -> ...);
*
* @author Bela Ban
* @since 0.2
*/
public class RaftHandle implements Settable {
protected JChannel ch;
protected RAFT raft;
protected Settable settable; // usually REDIRECT (at the top of the stack)
/**
* Creates a RaftHandle instance.
* @param ch The channel over which to create the RaftHandle. Must be non-null, but doesn't yet need to be connected
* @param sm An implementation of {@link StateMachine}.
* Can be null, ie. if it is set later via {@link #stateMachine(StateMachine)}.
*/
public RaftHandle(JChannel ch, StateMachine sm) {
if((this.ch=ch) == null)
throw new IllegalStateException("channel must not be null");
if((raft=RAFT.findProtocol(RAFT.class, ch.getProtocolStack().getTopProtocol(),true)) == null)
throw new IllegalStateException("RAFT protocol was not found");
if((settable=RAFT.findProtocol(Settable.class, ch.getProtocolStack().getTopProtocol(),true)) == null)
throw new IllegalStateException("did not find a protocol implementing Settable (e.g. REDIRECT or RAFT)");
stateMachine(sm);
}
public JChannel channel() {return ch;}
public RAFT raft() {return raft;}
public String raftId() {return raft.raftId();}
public RaftHandle raftId(String id) {raft.raftId(id); return this;}
public Address leader() {return raft.leader();}
public boolean isLeader() {return raft.isLeader();}
public StateMachine stateMachine() {return raft.stateMachine();}
public RaftHandle stateMachine(StateMachine sm) {raft.stateMachine(sm); return this;}
public RaftHandle addRoleListener(RAFT.RoleChange listener) {raft.addRoleListener(listener); return this;}
public RaftHandle removeRoleListener(RAFT.RoleChange listener) {raft.remRoleListener(listener); return this;}
public int currentTerm() {return raft.currentTerm();}
public int lastApplied() {return raft.lastAppended();}
public int commitIndex() {return raft.commitIndex();}
public void snapshot() throws Exception {raft.snapshot();}
public Log log() {return raft.log();}
public int logSize() {return raft.logSize();}
public int logSizeInBytes() {return raft.logSizeInBytes();}
public void logEntries(ObjIntConsumer func) {
raft.logEntries(func);
}
@Override
public byte[] set(byte[] buf, int offset, int length) throws Exception {
return settable.set(buf, offset, length);
}
@Override
public byte[] set(byte[] buf, int offset, int length, long timeout, TimeUnit unit) throws Exception {
return settable.set(buf, offset, length, timeout, unit);
}
@Override
public CompletableFuture setAsync(byte[] buf, int offset, int length) {
return settable.setAsync(buf, offset, length);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy