Skip to content

Commit

Permalink
chore(starknet_http_server): add metrics for added txs
Browse files Browse the repository at this point in the history
commit-id:9bf71741
  • Loading branch information
Itay-Tsabary-Starkware committed Dec 23, 2024
1 parent 5879086 commit 7c18fd9
Show file tree
Hide file tree
Showing 5 changed files with 44 additions and 1 deletion.
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions crates/starknet_http_server/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ workspace = true
axum.workspace = true
hyper.workspace = true
infra_utils.workspace = true
metrics.workspace = true
papyrus_config.workspace = true
reqwest = { workspace = true, optional = true }
serde.workspace = true
Expand Down
8 changes: 7 additions & 1 deletion crates/starknet_http_server/src/http_server.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ use tracing::{error, info, instrument};

use crate::config::HttpServerConfig;
use crate::errors::HttpServerRunError;
use crate::metrics::{count_added_transaction, count_transaction_status, init_metrics};

#[cfg(test)]
#[path = "http_server_test.rs"]
Expand All @@ -36,6 +37,7 @@ pub struct AppState {
impl HttpServer {
pub fn new(config: HttpServerConfig, gateway_client: SharedGatewayClient) -> Self {
let app_state = AppState { gateway_client };
init_metrics();
HttpServer { config, app_state }
}

Expand All @@ -55,19 +57,23 @@ impl HttpServer {
}
}

// TODO(Tsabary): add a test for the module metrics.

// HttpServer handlers.

#[instrument(skip(app_state))]
async fn add_tx(
State(app_state): State<AppState>,
Json(tx): Json<RpcTransaction>,
) -> HttpServerResult<Json<TransactionHash>> {
let gateway_input: GatewayInput = GatewayInput { rpc_tx: tx.clone(), message_metadata: None };
count_added_transaction();
let gateway_input: GatewayInput = GatewayInput { rpc_tx: tx, message_metadata: None };

let add_tx_result = app_state.gateway_client.add_tx(gateway_input).await.map_err(|join_err| {
error!("Failed to process tx: {}", join_err);
GatewaySpecError::UnexpectedError { data: "Internal server error".to_owned() }
});
count_transaction_status(add_tx_result.is_ok());

add_tx_result_as_json(add_tx_result)
}
Expand Down
1 change: 1 addition & 0 deletions crates/starknet_http_server/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,6 @@ pub mod communication;
pub mod config;
pub mod errors;
pub mod http_server;
mod metrics;
#[cfg(feature = "testing")]
pub mod test_utils;
34 changes: 34 additions & 0 deletions crates/starknet_http_server/src/metrics.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
use metrics::{absolute_counter, describe_counter, register_counter};

const ADDED_TRANSACTIONS_TOTAL: (&str, &str, u64) =
("ADDED_TRANSACTIONS_TOTAL", "Total number of transactions added", 0);
const ADDED_TRANSACTIONS_SUCCESS: (&str, &str, u64) =
("ADDED_TRANSACTIONS_SUCCESS", "Number of successfully added transactions", 0);
const ADDED_TRANSACTIONS_FAILURE: (&str, &str, u64) =
("ADDED_TRANSACTIONS_FAILURE", "Number of faulty added transactions", 0);

pub(crate) fn init_metrics() {
register_counter!(ADDED_TRANSACTIONS_TOTAL.0);
describe_counter!(ADDED_TRANSACTIONS_TOTAL.0, ADDED_TRANSACTIONS_TOTAL.1);
absolute_counter!(ADDED_TRANSACTIONS_TOTAL.0, ADDED_TRANSACTIONS_TOTAL.2);

register_counter!(ADDED_TRANSACTIONS_SUCCESS.0);
describe_counter!(ADDED_TRANSACTIONS_SUCCESS.0, ADDED_TRANSACTIONS_SUCCESS.1);
absolute_counter!(ADDED_TRANSACTIONS_SUCCESS.0, ADDED_TRANSACTIONS_SUCCESS.2);

register_counter!(ADDED_TRANSACTIONS_FAILURE.0);
describe_counter!(ADDED_TRANSACTIONS_FAILURE.0, ADDED_TRANSACTIONS_FAILURE.1);
absolute_counter!(ADDED_TRANSACTIONS_FAILURE.0, ADDED_TRANSACTIONS_FAILURE.2);
}

pub(crate) fn count_added_transaction() {
metrics::increment_counter!(ADDED_TRANSACTIONS_TOTAL.0);
}

pub(crate) fn count_transaction_status(add_tx_success: bool) {
if add_tx_success {
metrics::increment_counter!(ADDED_TRANSACTIONS_SUCCESS.0);
} else {
metrics::increment_counter!(ADDED_TRANSACTIONS_FAILURE.0);
}
}

0 comments on commit 7c18fd9

Please sign in to comment.