Skip to content

Commit

Permalink
enhancement: batch events out metric in Pipeline (#8383)
Browse files Browse the repository at this point in the history
* enhancement: batch events out metric in Pipeline

Signed-off-by: Toby Lawrence <[email protected]>
  • Loading branch information
tobz authored Jul 21, 2021
1 parent adf9990 commit 5a00f06
Showing 1 changed file with 13 additions and 1 deletion.
14 changes: 13 additions & 1 deletion src/pipeline.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,13 +28,23 @@ pub struct Pipeline {
#[derivative(Debug = "ignore")]
inlines: Vec<Box<dyn FunctionTransform>>,
enqueued: VecDeque<Event>,
events_outstanding: usize,
}

impl Pipeline {
fn try_flush(
&mut self,
cx: &mut Context<'_>,
) -> Poll<Result<(), <Self as Sink<Event>>::Error>> {
// We batch the updates to "events out" for efficiency, and do it here because
// it gives us a chance to allow the natural batching of `Pipeline` to kick in.
if self.events_outstanding > 0 {
emit!(EventOut {
count: self.events_outstanding
});
self.events_outstanding = 0;
}

while let Some(event) = self.enqueued.pop_front() {
match self.inner.poll_ready(cx) {
Poll::Pending => {
Expand Down Expand Up @@ -79,7 +89,8 @@ impl Sink<Event> for Pipeline {
}

fn start_send(mut self: Pin<&mut Self>, item: Event) -> Result<(), Self::Error> {
emit!(EventOut { count: 1 });
self.events_outstanding += 1;

// Note how this gets **swapped** with `new_working_set` in the loop.
// At the end of the loop, it will only contain finalized events.
let mut working_set = vec![item];
Expand Down Expand Up @@ -142,6 +153,7 @@ impl Pipeline {
// We ensure the buffer is sufficient that it is unlikely to require reallocations.
// There is a possibility a component might blow this queue size.
enqueued: VecDeque::with_capacity(10),
events_outstanding: 0,
}
}
}
Expand Down

0 comments on commit 5a00f06

Please sign in to comment.