vector/internal_events/
aws_cloudwatch_logs.rs1use 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}