Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type BlacklistLeaderPolicy ¶
type BlacklistLeaderPolicy struct { Membership map[t.NodeID]struct{} Suspected map[t.NodeID]t.EpochNr MinLeaders int }
func BlacklistLeaderPolicyFromBytes ¶
func BlacklistLeaderPolicyFromBytes(data []byte) (*BlacklistLeaderPolicy, error)
func NewBlackListLeaderPolicy ¶
func NewBlackListLeaderPolicy(members []t.NodeID, MinLeaders int) *BlacklistLeaderPolicy
func (*BlacklistLeaderPolicy) Bytes ¶
func (l *BlacklistLeaderPolicy) Bytes() ([]byte, error)
func (*BlacklistLeaderPolicy) Leaders ¶
func (l *BlacklistLeaderPolicy) Leaders() []t.NodeID
Leaders always returns the whole membership for the SimpleLeaderPolicy. All nodes are always leaders.
func (*BlacklistLeaderPolicy) Reconfigure ¶
func (l *BlacklistLeaderPolicy) Reconfigure(nodeIDs []t.NodeID) LeaderSelectionPolicy
Reconfigure informs the leader selection policy about a change in the membership.
type LeaderPolicyType ¶
type LeaderPolicyType uint64
const ( Simple LeaderPolicyType = iota Blacklist )
type LeaderSelectionPolicy ¶
type LeaderSelectionPolicy interface { // Leaders returns the (ordered) list of leaders based on the given epoch e and on the state of this policy object. Leaders() []t.NodeID // Suspect updates the state of the policy object by announcing it that node `node` has been suspected in epoch `e`. Suspect(e t.EpochNr, node t.NodeID) // Reconfigure returns a new LeaderSelectionPolicy based on the state of the current one, // but using a new configuration. // TODO: Use the whole configuration, not just the node IDs. Reconfigure(nodeIDs []t.NodeID) LeaderSelectionPolicy Bytes() ([]byte, error) }
A LeaderSelectionPolicy implements the algorithm for selecting a set of leaders in each ISS epoch. In a nutshell, it gathers information about suspected leaders in the past epochs and uses it to calculate the set of leaders for future epochs. Its state can be updated using Suspect() and the leader set for an epoch is queried using Leaders(). A leader set policy must be deterministic, i.e., calling Leaders() after the same sequence of Suspect() invocations always returns the same set of leaders at every Node.
func LeaderPolicyFromBytes ¶
func LeaderPolicyFromBytes(bytes []byte) (LeaderSelectionPolicy, error)
type SimpleLeaderPolicy ¶
The SimpleLeaderPolicy is a trivial leader selection policy. It must be initialized with a set of node IDs and always returns that full set as leaders, regardless of which nodes have been suspected. In other words, each node is leader each epoch with this policy.
func NewSimpleLeaderPolicy ¶
func NewSimpleLeaderPolicy(membership []t.NodeID) *SimpleLeaderPolicy
func SimpleLeaderPolicyFromBytes ¶
func SimpleLeaderPolicyFromBytes(data []byte) (*SimpleLeaderPolicy, error)
func (*SimpleLeaderPolicy) Bytes ¶
func (simple *SimpleLeaderPolicy) Bytes() ([]byte, error)
func (*SimpleLeaderPolicy) Leaders ¶
func (simple *SimpleLeaderPolicy) Leaders() []t.NodeID
Leaders always returns the whole membership for the SimpleLeaderPolicy. All nodes are always leaders.
func (*SimpleLeaderPolicy) Reconfigure ¶
func (simple *SimpleLeaderPolicy) Reconfigure(nodeIDs []t.NodeID) LeaderSelectionPolicy
Reconfigure informs the leader selection policy about a change in the membership.