vector/internal_events/
batch.rs

1use metrics::counter;
2use vector_lib::NamedInternalEvent;
3use vector_lib::internal_event::{
4    ComponentEventsDropped, InternalEvent, UNINTENTIONAL, error_stage, error_type,
5};
6
7#[derive(Debug, NamedInternalEvent)]
8pub struct LargeEventDroppedError {
9    pub(crate) length: usize,
10    pub max_length: usize,
11}
12
13impl InternalEvent for LargeEventDroppedError {
14    fn emit(self) {
15        let reason = "Event larger than batch max_bytes.";
16        error!(
17            message = reason,
18            batch_max_bytes = %self.max_length,
19            length = %self.length,
20            error_type = error_type::CONDITION_FAILED,
21            stage = error_stage::SENDING,
22        );
23        counter!(
24            "component_errors_total",
25            "error_code" => "oversized",
26            "error_type" => error_type::CONDITION_FAILED,
27            "stage" => error_stage::SENDING,
28        )
29        .increment(1);
30        emit!(ComponentEventsDropped::<UNINTENTIONAL> { count: 1, reason });
31    }
32}