vector/internal_events/
aws_cloudwatch_logs.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 AwsCloudwatchLogsMessageSizeError {
9    pub size: usize,
10    pub max_size: usize,
11}
12
13impl InternalEvent for AwsCloudwatchLogsMessageSizeError {
14    fn emit(self) {
15        let reason = "Encoded event is too long.";
16        error!(
17            message = reason,
18            size = self.size as u64,
19            max_size = self.max_size as u64,
20            error_code = "message_too_long",
21            error_type = error_type::ENCODER_FAILED,
22            stage = error_stage::PROCESSING,
23        );
24        counter!(
25            "component_errors_total",
26            "error_code" => "message_too_long",
27            "error_type" => error_type::ENCODER_FAILED,
28            "stage" => error_stage::PROCESSING,
29        )
30        .increment(1);
31        emit!(ComponentEventsDropped::<UNINTENTIONAL> { count: 1, reason });
32    }
33}