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

org.jgroups.raft.RaftHandle Maven / Gradle / Ivy

There is a newer version: 1.0.14.Final
Show newest version
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