Skip to content

Commit

Permalink
#1649 Leak query counter name to improve QueryCounter performance (#1669
Browse files Browse the repository at this point in the history
)
  • Loading branch information
justinweng-instaclustr authored Jun 18, 2024
1 parent b540be8 commit 911e8a0
Showing 1 changed file with 10 additions and 7 deletions.
17 changes: 10 additions & 7 deletions shotover/src/transforms/query_counter.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ use super::UpChainProtocol;

#[derive(Clone)]
pub struct QueryCounter {
counter_name: String,
counter_name: &'static str,
}

#[derive(Serialize, Deserialize, Debug)]
Expand All @@ -28,7 +28,10 @@ impl QueryCounter {
pub fn new(counter_name: String) -> Self {
counter!("shotover_query_count", "name" => counter_name.clone());

QueryCounter { counter_name }
QueryCounter {
// Leaking here is fine since the builder is created only once during shotover startup.
counter_name: counter_name.leak(),
}
}
}

Expand All @@ -54,20 +57,20 @@ impl Transform for QueryCounter {
#[cfg(feature = "cassandra")]
Some(Frame::Cassandra(frame)) => {
for statement in frame.operation.queries() {
counter!("shotover_query_count", "name" => self.counter_name.clone(), "query" => statement.short_name(), "type" => "cassandra").increment(1);
counter!("shotover_query_count", "name" => self.counter_name, "query" => statement.short_name(), "type" => "cassandra").increment(1);
}
}
#[cfg(feature = "redis")]
Some(Frame::Redis(frame)) => {
if let Some(query_type) = crate::frame::redis::redis_query_name(frame) {
counter!("shotover_query_count", "name" => self.counter_name.clone(), "query" => query_type, "type" => "redis").increment(1);
counter!("shotover_query_count", "name" => self.counter_name, "query" => query_type, "type" => "redis").increment(1);
} else {
counter!("shotover_query_count", "name" => self.counter_name.clone(), "query" => "unknown", "type" => "redis").increment(1);
counter!("shotover_query_count", "name" => self.counter_name, "query" => "unknown", "type" => "redis").increment(1);
}
}
#[cfg(feature = "kafka")]
Some(Frame::Kafka(_)) => {
counter!("shotover_query_count", "name" => self.counter_name.clone(), "query" => "unknown", "type" => "kafka").increment(1);
counter!("shotover_query_count", "name" => self.counter_name, "query" => "unknown", "type" => "kafka").increment(1);
}
Some(Frame::Dummy) => {
// Dummy does not count as a message
Expand All @@ -77,7 +80,7 @@ impl Transform for QueryCounter {
todo!();
}
None => {
counter!("shotover_query_count", "name" => self.counter_name.clone(), "query" => "unknown", "type" => "none").increment(1)
counter!("shotover_query_count", "name" => self.counter_name, "query" => "unknown", "type" => "none").increment(1)
}
}
}
Expand Down

0 comments on commit 911e8a0

Please sign in to comment.