vector/internal_events/
aws_cloudwatch_logs.rs1use metrics::counter;
2use vector_lib::internal_event::{
3 ComponentEventsDropped, InternalEvent, UNINTENTIONAL, error_stage, error_type,
4};
5
6#[derive(Debug)]
7pub struct AwsCloudwatchLogsMessageSizeError {
8 pub size: usize,
9 pub max_size: usize,
10}
11
12impl InternalEvent for AwsCloudwatchLogsMessageSizeError {
13 fn emit(self) {
14 let reason = "Encoded event is too long.";
15 error!(
16 message = reason,
17 size = self.size as u64,
18 max_size = self.max_size as u64,
19 error_code = "message_too_long",
20 error_type = error_type::ENCODER_FAILED,
21 stage = error_stage::PROCESSING,
22 internal_log_rate_limit = true,
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}