Commit 6c8d006
committed
Respect latency thresholds in node switching
Add configurable latency thresholds to monitoring and use them to avoid insignificant latency-based node switches. Changes include:
- config.yml: add latency_threshold and latency_threshold_percent.
- config/mod.rs: add optional latency fields and is_latency_improvement_significant() helper.
- monitoring/sync.rs: refactor selection logic (find_best_candidate, evaluate_switch), make select_best_node accept monitoring config and chain, and honor latency thresholds and in_sync rules when deciding switches; add many tests covering threshold behavior.
- monitoring/request_health.rs: expose test helpers via testkit::sync::url import.
- monitoring/mod.rs: make request_health module crate-visible.
- monitoring/service.rs & monitoring/worker.rs: expose/adopt RequestAdaptiveMonitor (add adaptive_monitor accessor in NodeService, wire adaptive_monitor through NodeMonitor, mark adaptive monitor on successful switches via try_switch).
- monitoring/telemetry.rs: normalize in_sync field serialization to "false" string and minor formatting.
- monitoring/switch_reason.rs: derive PartialEq for test assertions.
- testkit: add sync helpers (url, healthy_observation, not_in_sync_observation) and include them in mod; update test monitoring config defaults.
Overall goal: reduce noisy or insignificant latency-driven switches and integrate adaptive monitoring updates when switches occur. Tests added/updated to validate behavior.1 parent e1045b0 commit 6c8d006
13 files changed
Lines changed: 265 additions & 98 deletions
File tree
- apps/dynode
- src
- config
- monitoring
- testkit
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| 16 | + | |
| 17 | + | |
16 | 18 | | |
17 | 19 | | |
18 | 20 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
28 | 28 | | |
29 | 29 | | |
30 | 30 | | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
31 | 35 | | |
32 | 36 | | |
33 | 37 | | |
| |||
44 | 48 | | |
45 | 49 | | |
46 | 50 | | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
47 | 69 | | |
48 | 70 | | |
49 | 71 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
154 | 154 | | |
155 | 155 | | |
156 | 156 | | |
| 157 | + | |
157 | 158 | | |
158 | 159 | | |
159 | 160 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | | - | |
| 2 | + | |
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
263 | 263 | | |
264 | 264 | | |
265 | 265 | | |
| 266 | + | |
266 | 267 | | |
267 | 268 | | |
268 | 269 | | |
| |||
274 | 275 | | |
275 | 276 | | |
276 | 277 | | |
277 | | - | |
278 | | - | |
279 | | - | |
280 | | - | |
281 | | - | |
282 | | - | |
283 | | - | |
284 | 278 | | |
285 | 279 | | |
286 | 280 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
63 | 63 | | |
64 | 64 | | |
65 | 65 | | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
66 | 70 | | |
67 | 71 | | |
68 | 72 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
| 3 | + | |
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
21 | 20 | | |
22 | 21 | | |
23 | 22 | | |
| |||
0 commit comments