#[cfg(feature = "sources-prometheus-scrape")]
use std::borrow::Cow;
use metrics::counter;
use vector_lib::internal_event::InternalEvent;
use vector_lib::internal_event::{error_stage, error_type, ComponentEventsDropped, UNINTENTIONAL};
#[cfg(feature = "sources-prometheus-scrape")]
use vector_lib::prometheus::parser::ParserError;
#[cfg(feature = "sources-prometheus-scrape")]
#[derive(Debug)]
pub struct PrometheusParseError<'a> {
pub error: ParserError,
pub url: http::Uri,
pub body: Cow<'a, str>,
}
#[cfg(feature = "sources-prometheus-scrape")]
impl<'a> InternalEvent for PrometheusParseError<'a> {
fn emit(self) {
error!(
message = "Parsing error.",
url = %self.url,
error = ?self.error,
error_type = error_type::PARSER_FAILED,
stage = error_stage::PROCESSING,
internal_log_rate_limit = true,
);
debug!(
message = %format!("Failed to parse response:\n\n{}\n\n", self.body),
url = %self.url,
internal_log_rate_limit = true
);
counter!(
"component_errors_total",
"error_type" => error_type::PARSER_FAILED,
"stage" => error_stage::PROCESSING,
"url" => self.url.to_string(),
)
.increment(1);
}
}
#[derive(Debug)]
pub struct PrometheusRemoteWriteParseError {
pub error: prost::DecodeError,
}
impl InternalEvent for PrometheusRemoteWriteParseError {
fn emit(self) {
error!(
message = "Could not decode request body.",
error = ?self.error,
error_type = error_type::PARSER_FAILED,
stage = error_stage::PROCESSING,
internal_log_rate_limit = true,
);
counter!(
"component_errors_total",
"error_type" => error_type::PARSER_FAILED,
"stage" => error_stage::PROCESSING,
)
.increment(1);
}
}
#[derive(Debug)]
pub struct PrometheusNormalizationError;
impl InternalEvent for PrometheusNormalizationError {
fn emit(self) {
let normalization_reason = "Prometheus metric normalization failed.";
error!(
message = normalization_reason,
error_type = error_type::CONVERSION_FAILED,
stage = error_stage::PROCESSING,
internal_log_rate_limit = true,
);
counter!(
"component_errors_total",
"error_type" => error_type::CONVERSION_FAILED,
"stage" => error_stage::PROCESSING,
)
.increment(1);
emit!(ComponentEventsDropped::<UNINTENTIONAL> {
count: 1,
reason: normalization_reason
});
}
}