Documentation ¶
Index ¶
- Constants
- func CurrentTime() int64
- type Beacon
- type MetricsRequest
- type Propose
- type RPCMessage
- type RPCPair
- type Replica
- func (r *Replica) BeTheLeader(args *genericsmrproto.BeTheLeaderArgs, reply *genericsmrproto.BeTheLeaderReply) error
- func (r *Replica) ConnectToPeers()
- func (r *Replica) Ping(args *genericsmrproto.PingArgs, reply *genericsmrproto.PingReply) error
- func (r *Replica) RegisterRPC(msgObj fastrpc.Serializable, notify chan *RPCMessage) uint8
- func (r *Replica) ReplyBeacon(beacon *Beacon)
- func (r *Replica) ReplyPropose(reply *genericsmrproto.ProposeReply, w *bufio.Writer)
- func (r *Replica) SendBeacon(peerId int32)
- func (r *Replica) SendMsg(peerId int32, code uint8, msg fastrpc.Serializable)
- func (r *Replica) UpdatePreferredPeerOrder(quorum []int32)
- func (r *Replica) WaitForClientConnections()
Constants ¶
View Source
const CHAN_BUFFER_SIZE = 200000
Variables ¶
This section is empty.
Functions ¶
Types ¶
type MetricsRequest ¶
type MetricsRequest struct { *genericsmrproto.MetricsRequest Reply *bufio.Writer }
type RPCMessage ¶
type RPCMessage struct { Message fastrpc.Serializable ReceivedAt int64 // Unix Nano UTC timestamp From int64 // The rid of the replica who sent this message }
type RPCPair ¶
type RPCPair struct { Obj fastrpc.Serializable Chan chan *RPCMessage }
type Replica ¶
type Replica struct { N int // total number of replicas Id int32 // the ID of the current replica PeerAddrList []string // array with the IP:port address of every replica Peers []net.Conn // cache of connections to all other replicas PeerReaders []*bufio.Reader PeerWriters []*bufio.Writer Alive []bool // connection status Listener net.Listener State *state.State ProposeChan chan *Propose // channel for client proposals BeaconChan chan *Beacon // channel for beacons from peer replicas MetricsChan chan *MetricsRequest // channel to send metrics to experiment code Shutdown bool Thrifty bool // send only as many messages as strictly required? Beacon bool // send beacons to detect how fast are the other replicas? Durable bool // log to a stable store? StableStore *os.File // file support for the persistent log PreferredPeerOrder []int32 // replicas in the preferred order of communication Ewma []float64 OnClientConnect chan bool // contains filtered or unexported fields }
func (*Replica) BeTheLeader ¶
func (r *Replica) BeTheLeader(args *genericsmrproto.BeTheLeaderArgs, reply *genericsmrproto.BeTheLeaderReply) error
func (*Replica) ConnectToPeers ¶
func (r *Replica) ConnectToPeers()
func (*Replica) Ping ¶
func (r *Replica) Ping(args *genericsmrproto.PingArgs, reply *genericsmrproto.PingReply) error
func (*Replica) RegisterRPC ¶
func (r *Replica) RegisterRPC(msgObj fastrpc.Serializable, notify chan *RPCMessage) uint8
func (*Replica) ReplyBeacon ¶
func (*Replica) ReplyPropose ¶
func (r *Replica) ReplyPropose(reply *genericsmrproto.ProposeReply, w *bufio.Writer)
func (*Replica) SendBeacon ¶
func (*Replica) SendMsg ¶
func (r *Replica) SendMsg(peerId int32, code uint8, msg fastrpc.Serializable)
func (*Replica) UpdatePreferredPeerOrder ¶
updates the preferred order in which to communicate with peers according to a preferred quorum
func (*Replica) WaitForClientConnections ¶
func (r *Replica) WaitForClientConnections()
Client connections dispatcher
Click to show internal directories.
Click to hide internal directories.