Skip to content

Commit

Permalink
Readme: reword a paragraph so it's not misleading
Browse files Browse the repository at this point in the history
The description of OnElected, OnOusting, and LeaderChanged are a bit
misleading because of an interstitial clause. Rewrite that paragraph and
break it up into two.
  • Loading branch information
dfinkel committed Mar 25, 2022
1 parent 74d2e6f commit 452f327
Showing 1 changed file with 9 additions and 4 deletions.
13 changes: 9 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,15 @@ Currently, this implementation only has two implementations:
The [`Config`] struct contains callbacks and tunables for the leader election
"campaign".

Each process that would like to acquire leadership must register callbacks for
all three of `OnElected`, `OnOusting` and `LeaderChanged`, as well as specify
unique `LeaderID` and `HostPort`s (the latter two are used for communication, so
some use-cases may be able to ignore them)
Each "candidate" contending for leadership must register an `OnElected` callback
and a `LeaderID` (which is often a random string). Additionally, it is
recommended to specify `HostPort`, which makes it possible to leverage the
`legrpc` and have other clients using the `WatchConfig{}.Watch()` method connect
to the current leader. (it can also be useful for debugging)

Optionally, one can specify `LeaderChanged` and `OnOusting` callbacks which are
called when a the current leader changes and an instance has lost its election,
respectively.

The `TermLength` is the length of time that a leader acquires leadership for,
and the length of any extension. This duration should be long enough to get
Expand Down

0 comments on commit 452f327

Please sign in to comment.