pub struct EventJournal {
pub capacity: usize,
pub events: VecDeque<SupervisorEvent>,
pub dropped_count: u64,
pub last_sequence: Option<EventSequence>,
}Expand description
Fixed-capacity lifecycle event journal.
Fields§
§capacity: usizeMaximum number of events retained in memory.
events: VecDeque<SupervisorEvent>Recent events in oldest-to-newest order.
dropped_count: u64Number of events dropped because capacity was full.
last_sequence: Option<EventSequence>Last sequence written to the journal.
Implementations§
Source§impl EventJournal
impl EventJournal
Sourcepub fn new(capacity: usize) -> Self
pub fn new(capacity: usize) -> Self
Creates an event journal with fixed capacity.
§Arguments
capacity: Maximum number of events retained. Zero is allowed and drops every pushed event.
§Returns
Returns an empty EventJournal.
§Examples
let journal = rust_supervisor::journal::ring::EventJournal::new(2);
assert_eq!(journal.capacity, 2);Examples found in repository?
38fn main() {
39 // Build the child identifier.
40 let child_id = ChildId::new("market_feed");
41 // Build the child path.
42 let child_path = SupervisorPath::root().join("market_feed");
43 // Build a typed task failure.
44 let failure = TaskFailure::new(
45 // Set the failure kind.
46 TaskFailureKind::Timeout,
47 // Set the low-cardinality failure category.
48 "external_dependency",
49 // Set the diagnostic failure message.
50 "market feed heartbeat timed out",
51 // Finish the typed task failure.
52 );
53 // Build the restart policy decision.
54 let policy = PolicyDecision::new(
55 // Set the decision label.
56 "RestartAfter",
57 // Set the restart delay.
58 Some(500),
59 // Set the diagnostic decision reason.
60 Some("heartbeat timeout is restartable".to_owned()),
61 // Finish the policy decision.
62 );
63
64 // Create the fixed-capacity event journal.
65 let mut journal = EventJournal::new(8);
66 // Push the running event.
67 journal.push(event(
68 // Set the event sequence.
69 1,
70 // Clone the child identifier.
71 child_id.clone(),
72 // Set the child display name.
73 "Market Feed",
74 // Build the running event payload.
75 What::ChildRunning {
76 // Attach the state transition.
77 transition: Some(StateTransition::new("Starting", "Running")),
78 // Finish the running event payload.
79 },
80 // Attach no policy decision.
81 None,
82 // Finish the running event.
83 ));
84 // Push the failed event.
85 journal.push(event(
86 // Set the event sequence.
87 2,
88 // Clone the child identifier.
89 child_id.clone(),
90 // Set the child display name.
91 "Market Feed",
92 // Build the failed event payload.
93 What::ChildFailed {
94 // Attach the typed failure.
95 failure: failure.clone(),
96 // Finish the failed event payload.
97 },
98 // Attach the restart policy decision.
99 Some(policy.clone()),
100 // Finish the failed event.
101 ));
102 // Push the backoff event.
103 journal.push(event(
104 // Set the event sequence.
105 3,
106 // Clone the child identifier.
107 child_id.clone(),
108 // Set the child display name.
109 "Market Feed",
110 // Build the backoff payload.
111 What::BackoffScheduled { delay_ms: 500 },
112 // Attach the restart policy decision.
113 Some(policy.clone()),
114 // Finish the backoff event.
115 ));
116 // Push the restarted event.
117 journal.push(event(
118 // Set the event sequence.
119 4,
120 // Clone the child identifier.
121 child_id.clone(),
122 // Set the child display name.
123 "Market Feed",
124 // Build the restarted payload.
125 What::ChildRestarted { restart_count: 1 },
126 // Attach the restart policy decision.
127 Some(policy.clone()),
128 // Finish the restarted event.
129 ));
130
131 // Build the final child state.
132 let child = ChildState::declared(child_path, child_id, "Market Feed")
133 // Set the child lifecycle state.
134 .with_lifecycle_state(ChildLifecycleState::Running, EventSequence::new(1))
135 // Record the latest failure.
136 .record_failure(failure, EventSequence::new(2))
137 // Record the latest policy decision.
138 .with_policy_decision(policy, 1);
139 // Build the final supervisor state.
140 let final_state = SupervisorState::new(SupervisorPath::root(), EventSequence::new(4), 1)
141 // Add the child state.
142 .with_child(child)
143 // Mark shutdown as completed for the replay.
144 .with_shutdown_state(ShutdownState::Completed)
145 // Attach the last journal sequence.
146 .with_journal_sequence(EventSequence::new(4));
147 // Build the diagnostic run summary.
148 let summary = RunSummaryBuilder::new(8).build(
149 // Read recent events from the journal.
150 &journal,
151 // Attach the final current state.
152 final_state,
153 // Attach the shutdown cause.
154 Some("diagnostic replay complete".to_owned()),
155 // Finish the summary construction.
156 );
157 // Create the metrics facade.
158 let metrics = MetricsFacade::new();
159
160 // Print summary counters.
161 println!(
162 // Provide the output template.
163 "summary restart_count={} failure_count={} recent_events={}",
164 // Print the restart count.
165 summary.restart_count,
166 // Print the failure count.
167 summary.failure_count,
168 // Print the recent event count.
169 summary.recent_events.len(),
170 // Finish summary output.
171 );
172 // Iterate over recent journal events.
173 for event in journal.recent(8) {
174 // Print event names and derived metrics.
175 println!(
176 // Provide the output template.
177 "event={} metrics={:?}",
178 // Print the event name.
179 event.what.name(),
180 // Print metrics derived from the event.
181 metrics.samples_for_event(&event),
182 // Finish event output.
183 );
184 // Finish the journal replay loop.
185 }
186 // End the diagnostic replay example.
187}Sourcepub fn push(&mut self, event: SupervisorEvent) -> u64
pub fn push(&mut self, event: SupervisorEvent) -> u64
Pushes an event and drops the oldest event when full.
§Arguments
event: Event that should be retained when capacity permits.
§Returns
Returns the new dropped count.
Examples found in repository?
38fn main() {
39 // Build the child identifier.
40 let child_id = ChildId::new("market_feed");
41 // Build the child path.
42 let child_path = SupervisorPath::root().join("market_feed");
43 // Build a typed task failure.
44 let failure = TaskFailure::new(
45 // Set the failure kind.
46 TaskFailureKind::Timeout,
47 // Set the low-cardinality failure category.
48 "external_dependency",
49 // Set the diagnostic failure message.
50 "market feed heartbeat timed out",
51 // Finish the typed task failure.
52 );
53 // Build the restart policy decision.
54 let policy = PolicyDecision::new(
55 // Set the decision label.
56 "RestartAfter",
57 // Set the restart delay.
58 Some(500),
59 // Set the diagnostic decision reason.
60 Some("heartbeat timeout is restartable".to_owned()),
61 // Finish the policy decision.
62 );
63
64 // Create the fixed-capacity event journal.
65 let mut journal = EventJournal::new(8);
66 // Push the running event.
67 journal.push(event(
68 // Set the event sequence.
69 1,
70 // Clone the child identifier.
71 child_id.clone(),
72 // Set the child display name.
73 "Market Feed",
74 // Build the running event payload.
75 What::ChildRunning {
76 // Attach the state transition.
77 transition: Some(StateTransition::new("Starting", "Running")),
78 // Finish the running event payload.
79 },
80 // Attach no policy decision.
81 None,
82 // Finish the running event.
83 ));
84 // Push the failed event.
85 journal.push(event(
86 // Set the event sequence.
87 2,
88 // Clone the child identifier.
89 child_id.clone(),
90 // Set the child display name.
91 "Market Feed",
92 // Build the failed event payload.
93 What::ChildFailed {
94 // Attach the typed failure.
95 failure: failure.clone(),
96 // Finish the failed event payload.
97 },
98 // Attach the restart policy decision.
99 Some(policy.clone()),
100 // Finish the failed event.
101 ));
102 // Push the backoff event.
103 journal.push(event(
104 // Set the event sequence.
105 3,
106 // Clone the child identifier.
107 child_id.clone(),
108 // Set the child display name.
109 "Market Feed",
110 // Build the backoff payload.
111 What::BackoffScheduled { delay_ms: 500 },
112 // Attach the restart policy decision.
113 Some(policy.clone()),
114 // Finish the backoff event.
115 ));
116 // Push the restarted event.
117 journal.push(event(
118 // Set the event sequence.
119 4,
120 // Clone the child identifier.
121 child_id.clone(),
122 // Set the child display name.
123 "Market Feed",
124 // Build the restarted payload.
125 What::ChildRestarted { restart_count: 1 },
126 // Attach the restart policy decision.
127 Some(policy.clone()),
128 // Finish the restarted event.
129 ));
130
131 // Build the final child state.
132 let child = ChildState::declared(child_path, child_id, "Market Feed")
133 // Set the child lifecycle state.
134 .with_lifecycle_state(ChildLifecycleState::Running, EventSequence::new(1))
135 // Record the latest failure.
136 .record_failure(failure, EventSequence::new(2))
137 // Record the latest policy decision.
138 .with_policy_decision(policy, 1);
139 // Build the final supervisor state.
140 let final_state = SupervisorState::new(SupervisorPath::root(), EventSequence::new(4), 1)
141 // Add the child state.
142 .with_child(child)
143 // Mark shutdown as completed for the replay.
144 .with_shutdown_state(ShutdownState::Completed)
145 // Attach the last journal sequence.
146 .with_journal_sequence(EventSequence::new(4));
147 // Build the diagnostic run summary.
148 let summary = RunSummaryBuilder::new(8).build(
149 // Read recent events from the journal.
150 &journal,
151 // Attach the final current state.
152 final_state,
153 // Attach the shutdown cause.
154 Some("diagnostic replay complete".to_owned()),
155 // Finish the summary construction.
156 );
157 // Create the metrics facade.
158 let metrics = MetricsFacade::new();
159
160 // Print summary counters.
161 println!(
162 // Provide the output template.
163 "summary restart_count={} failure_count={} recent_events={}",
164 // Print the restart count.
165 summary.restart_count,
166 // Print the failure count.
167 summary.failure_count,
168 // Print the recent event count.
169 summary.recent_events.len(),
170 // Finish summary output.
171 );
172 // Iterate over recent journal events.
173 for event in journal.recent(8) {
174 // Print event names and derived metrics.
175 println!(
176 // Provide the output template.
177 "event={} metrics={:?}",
178 // Print the event name.
179 event.what.name(),
180 // Print metrics derived from the event.
181 metrics.samples_for_event(&event),
182 // Finish event output.
183 );
184 // Finish the journal replay loop.
185 }
186 // End the diagnostic replay example.
187}Sourcepub fn recent(&self, limit: usize) -> Vec<SupervisorEvent>
pub fn recent(&self, limit: usize) -> Vec<SupervisorEvent>
Returns recent events with newest events retained.
§Arguments
limit: Maximum number of events to return.
§Returns
Returns events in oldest-to-newest order.
§Examples
let journal = rust_supervisor::journal::ring::EventJournal::new(4);
assert!(journal.recent(2).is_empty());Examples found in repository?
38fn main() {
39 // Build the child identifier.
40 let child_id = ChildId::new("market_feed");
41 // Build the child path.
42 let child_path = SupervisorPath::root().join("market_feed");
43 // Build a typed task failure.
44 let failure = TaskFailure::new(
45 // Set the failure kind.
46 TaskFailureKind::Timeout,
47 // Set the low-cardinality failure category.
48 "external_dependency",
49 // Set the diagnostic failure message.
50 "market feed heartbeat timed out",
51 // Finish the typed task failure.
52 );
53 // Build the restart policy decision.
54 let policy = PolicyDecision::new(
55 // Set the decision label.
56 "RestartAfter",
57 // Set the restart delay.
58 Some(500),
59 // Set the diagnostic decision reason.
60 Some("heartbeat timeout is restartable".to_owned()),
61 // Finish the policy decision.
62 );
63
64 // Create the fixed-capacity event journal.
65 let mut journal = EventJournal::new(8);
66 // Push the running event.
67 journal.push(event(
68 // Set the event sequence.
69 1,
70 // Clone the child identifier.
71 child_id.clone(),
72 // Set the child display name.
73 "Market Feed",
74 // Build the running event payload.
75 What::ChildRunning {
76 // Attach the state transition.
77 transition: Some(StateTransition::new("Starting", "Running")),
78 // Finish the running event payload.
79 },
80 // Attach no policy decision.
81 None,
82 // Finish the running event.
83 ));
84 // Push the failed event.
85 journal.push(event(
86 // Set the event sequence.
87 2,
88 // Clone the child identifier.
89 child_id.clone(),
90 // Set the child display name.
91 "Market Feed",
92 // Build the failed event payload.
93 What::ChildFailed {
94 // Attach the typed failure.
95 failure: failure.clone(),
96 // Finish the failed event payload.
97 },
98 // Attach the restart policy decision.
99 Some(policy.clone()),
100 // Finish the failed event.
101 ));
102 // Push the backoff event.
103 journal.push(event(
104 // Set the event sequence.
105 3,
106 // Clone the child identifier.
107 child_id.clone(),
108 // Set the child display name.
109 "Market Feed",
110 // Build the backoff payload.
111 What::BackoffScheduled { delay_ms: 500 },
112 // Attach the restart policy decision.
113 Some(policy.clone()),
114 // Finish the backoff event.
115 ));
116 // Push the restarted event.
117 journal.push(event(
118 // Set the event sequence.
119 4,
120 // Clone the child identifier.
121 child_id.clone(),
122 // Set the child display name.
123 "Market Feed",
124 // Build the restarted payload.
125 What::ChildRestarted { restart_count: 1 },
126 // Attach the restart policy decision.
127 Some(policy.clone()),
128 // Finish the restarted event.
129 ));
130
131 // Build the final child state.
132 let child = ChildState::declared(child_path, child_id, "Market Feed")
133 // Set the child lifecycle state.
134 .with_lifecycle_state(ChildLifecycleState::Running, EventSequence::new(1))
135 // Record the latest failure.
136 .record_failure(failure, EventSequence::new(2))
137 // Record the latest policy decision.
138 .with_policy_decision(policy, 1);
139 // Build the final supervisor state.
140 let final_state = SupervisorState::new(SupervisorPath::root(), EventSequence::new(4), 1)
141 // Add the child state.
142 .with_child(child)
143 // Mark shutdown as completed for the replay.
144 .with_shutdown_state(ShutdownState::Completed)
145 // Attach the last journal sequence.
146 .with_journal_sequence(EventSequence::new(4));
147 // Build the diagnostic run summary.
148 let summary = RunSummaryBuilder::new(8).build(
149 // Read recent events from the journal.
150 &journal,
151 // Attach the final current state.
152 final_state,
153 // Attach the shutdown cause.
154 Some("diagnostic replay complete".to_owned()),
155 // Finish the summary construction.
156 );
157 // Create the metrics facade.
158 let metrics = MetricsFacade::new();
159
160 // Print summary counters.
161 println!(
162 // Provide the output template.
163 "summary restart_count={} failure_count={} recent_events={}",
164 // Print the restart count.
165 summary.restart_count,
166 // Print the failure count.
167 summary.failure_count,
168 // Print the recent event count.
169 summary.recent_events.len(),
170 // Finish summary output.
171 );
172 // Iterate over recent journal events.
173 for event in journal.recent(8) {
174 // Print event names and derived metrics.
175 println!(
176 // Provide the output template.
177 "event={} metrics={:?}",
178 // Print the event name.
179 event.what.name(),
180 // Print metrics derived from the event.
181 metrics.samples_for_event(&event),
182 // Finish event output.
183 );
184 // Finish the journal replay loop.
185 }
186 // End the diagnostic replay example.
187}Trait Implementations§
Source§impl Clone for EventJournal
impl Clone for EventJournal
Source§fn clone(&self) -> EventJournal
fn clone(&self) -> EventJournal
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for EventJournal
impl Debug for EventJournal
Source§impl<'de> Deserialize<'de> for EventJournal
impl<'de> Deserialize<'de> for EventJournal
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl PartialEq for EventJournal
impl PartialEq for EventJournal
Source§fn eq(&self, other: &EventJournal) -> bool
fn eq(&self, other: &EventJournal) -> bool
self and other values to be equal, and is used by ==.Source§impl Serialize for EventJournal
impl Serialize for EventJournal
impl Eq for EventJournal
impl StructuralPartialEq for EventJournal
Auto Trait Implementations§
impl Freeze for EventJournal
impl RefUnwindSafe for EventJournal
impl Send for EventJournal
impl Sync for EventJournal
impl Unpin for EventJournal
impl UnsafeUnpin for EventJournal
impl UnwindSafe for EventJournal
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
Source§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();Source§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
Source§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
Source§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
Source§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
Source§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
Source§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
Source§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
Source§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
Source§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();Source§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
Source§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
Source§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
Source§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
Source§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
Source§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
Source§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
Source§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
Source§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
Source§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
Source§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling Attribute value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();Source§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
Source§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi Quirk value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();Source§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
Source§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the Condition value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);