kubernetes: github.com/bboreham/kubernetes/pkg/client/leaderelection Index | Files

package leaderelection

import "github.com/bboreham/kubernetes/pkg/client/leaderelection"

Package leaderelection implements leader election of a set of endpoints. It uses an annotation in the endpoints object to store the record of the election state.

This implementation does not guarantee that only one client is acting as a leader (a.k.a. fencing). A client observes timestamps captured locally to infer the state of the leader election. Thus the implementation is tolerant to arbitrary clock skew, but is not tolerant to arbitrary clock skew rate.

However the level of tolerance to skew rate can be configured by setting RenewDeadline and LeaseDuration appropriately. The tolerance expressed as a maximum tolerated ratio of time passed on the fastest node to time passed on the slowest node can be approximately achieved with a configuration that sets the same ratio of LeaseDuration to RenewDeadline. For example if a user wanted to tolerate some nodes progressing forward in time twice as fast as other nodes, the user could set LeaseDuration to 60 seconds and RenewDeadline to 30 seconds.

While not required, some method of clock synchronization between nodes in the cluster is highly recommended. It's important to keep in mind when configuring this client that the tolerance to skew rate varies inversely to master availability.

Larger clusters often have a more lenient SLA for API latency. This should be taken into account when configuring the client. The rate of leader transistions should be monitored and RetryPeriod and LeaseDuration should be increased until the rate is stable and acceptably low. It's important to keep in mind when configuring this client that the tolerance to API latency varies inversely to master availability.

DISCLAIMER: this is an alpha API. This library will likely change significantly or even be removed entirely in subsequent releases. Depend on this API at your own risk.

Index

Package Files

leaderelection.go

Constants

const (
    JitterFactor = 1.2

    LeaderElectionRecordAnnotationKey = "control-plane.alpha.kubernetes.io/leader"
)

type LeaderCallbacks Uses

type LeaderCallbacks struct {
    // OnStartedLeading is called when a LeaderElector client starts leading
    OnStartedLeading func(stop <-chan struct{})
    // OnStoppedLeading is called when a LeaderElector client stops leading
    OnStoppedLeading func()
}

LeaderCallbacks are callbacks that are triggered during certain lifecycle events of the LeaderElector. These are invoked asynchronously.

possible future callbacks:

* OnChallenge()
* OnNewLeader()

type LeaderElectionConfig Uses

type LeaderElectionConfig struct {
    // EndpointsMeta should contain a Name and a Namespace of an
    // Endpoints object that the LeaderElector will attempt to lead.
    EndpointsMeta api.ObjectMeta
    // Identity is a unique identifier of the leader elector.
    Identity string

    Client        client.Interface
    EventRecorder record.EventRecorder

    // LeaseDuration is the duration that non-leader candidates will
    // wait to force acquire leadership. This is measured against time of
    // last observed ack.
    LeaseDuration time.Duration
    // RenewDeadline is the duration that the acting master will retry
    // refreshing leadership before giving up.
    RenewDeadline time.Duration
    // RetryPeriod is the duration the LeaderElector clients should wait
    // between tries of actions.
    RetryPeriod time.Duration

    // Callbacks are callbacks that are triggered during certain lifecycle
    // events of the LeaderElector
    Callbacks LeaderCallbacks
}

type LeaderElectionRecord Uses

type LeaderElectionRecord struct {
    HolderIdentity       string           `json:"holderIdentity"`
    LeaseDurationSeconds int              `json:"leaseDurationSeconds"`
    AcquireTime          unversioned.Time `json:"acquireTime"`
    RenewTime            unversioned.Time `json:"renewTime"`
    LeaderTransitions    int              `json:"leaderTransitions"`
}

LeaderElectionRecord is the record that is stored in the leader election annotation. This information should be used for observational purposes only and could be replaced with a random string (e.g. UUID) with only slight modification of this code. TODO(mikedanese): this should potentially be versioned

type LeaderElector Uses

type LeaderElector struct {
    // contains filtered or unexported fields
}

LeaderElector is a leader election client.

possible future methods:

* (le *LeaderElector) IsLeader()
* (le *LeaderElector) GetLeader()

func NewLeaderElector Uses

func NewLeaderElector(lec LeaderElectionConfig) (*LeaderElector, error)

NewLeadereElector creates a LeaderElector from a LeaderElecitionConfig

func (*LeaderElector) Run Uses

func (le *LeaderElector) Run()

Run starts the leader election loop

Package leaderelection imports 12 packages (graph). Updated 2017-07-25. Refresh now. Tools for package owners. This is a quick bug-fix fork (has fewer than three commits, and only during the week it was created).