Skip to content

Commit

Permalink
Merge pull request #986 from drmingdrmer/33-faq-metrics
Browse files Browse the repository at this point in the history
Doc: faq: add how to get notified with RaftMetrics
  • Loading branch information
drmingdrmer authored Jan 10, 2024
2 parents 455422a + 659652d commit ab7f309
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 0 deletions.
2 changes: 2 additions & 0 deletions openraft/src/docs/faq/faq-toc.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
- [General](#general)
* [What are the differences between Openraft and standard Raft?](#what-are-the-differences-between-openraft-and-standard-raft)
- [Observation and Management](#observation-and-management)
* [How to get notified when the server state changes?](#how-to-get-notified-when-the-server-state-changes)
- [Data structure](#data-structure)
* [Why is log id a tuple of `(term, node_id, log_index)`?](#why-is-log-id-a-tuple-of-term-node_id-log_index)
- [Replication](#replication)
Expand Down
38 changes: 38 additions & 0 deletions openraft/src/docs/faq/faq.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,42 @@
- Does not support single step memebership change. Only joint is supported.


## Observation and Management


### How to get notified when the server state changes?

To monitor the state of a Raft node,
it's recommended to subscribe to updates in the [`RaftMetrics`][]
by calling [`Raft::metrics()`][].

The following code snippet provides an example of how to wait for changes in `RaftMetrics` until a leader is elected:

```ignore
let mut rx = self.raft.metrics();
loop {
if let Some(l) = rx.borrow().current_leader {
return Ok(Some(l));
}
rx.changed().await?;
}
```

The second example calls a function when the current node becomes the leader:

```ignore
let mut rx = self.raft.metrics();
loop {
if rx.borrow().state == ServerState::Leader {
app_init_leader();
}
rx.changed().await?;
}
```


## Data structure


Expand Down Expand Up @@ -155,3 +191,5 @@ pub(crate) fn following_handler(&mut self) -> FollowingHandler<C> {
[`NetworkError`]: `crate::error::NetworkError`


[`RaftMetrics`]: `crate::metrics::RaftMetrics`
[`Raft::metrics()`]: `crate::Raft::metrics`

0 comments on commit ab7f309

Please sign in to comment.