-
Notifications
You must be signed in to change notification settings - Fork 30
/
routes.rs
76 lines (64 loc) · 2.4 KB
/
routes.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
use autometrics::{autometrics, objectives::*};
use autometrics_example_util::sleep_random_duration;
use axum::{extract::State, http::StatusCode, Json};
use rand::{thread_rng, Rng};
use serde::{Deserialize, Serialize};
use crate::database::Database;
use crate::error::ApiError;
/// This is a Service-Level Objective (SLO) we're defining for our API.
const API_SLO: Objective = Objective::new("api")
.success_rate(ObjectivePercentile::P99_9)
.latency(ObjectiveLatency::Ms500, ObjectivePercentile::P99);
// Starting simple, hover over the function name to see the Autometrics graph links in the Rust Docs!
/// This is a simple endpoint that never errors
#[autometrics]
pub async fn get_index() -> &'static str {
"Hello, World!"
}
/// This is a function that returns an error ~25% of the time
/// The call counter metric generated by autometrics will have a label
/// `result` = `ok` or `error`, depending on what the function returned
#[autometrics(objective = API_SLO)]
pub async fn get_random_error() -> Result<(), ApiError> {
let error = thread_rng().gen_range(0..4);
sleep_random_duration().await;
match error {
0 => Err(ApiError::NotFound),
1 => Err(ApiError::BadRequest),
2 => Err(ApiError::Internal),
_ => Ok(()),
}
}
// This handler calls another internal function that is also instrumented with autometrics.
//
// Unlike other instrumentation libraries, autometrics is designed to give you more
// granular metrics that allow you to dig into the internals of your application
// before even reaching for logs or traces.
//
// Try hovering over the function name to see the graph links and pay special attention
// to the links for the functions _called by this function_.
// You can also hover over the load_details_from_database function to see the graph links for that function.
#[autometrics(objective = API_SLO)]
pub async fn create_user(
State(database): State<Database>,
Json(payload): Json<CreateUser>,
) -> Result<Json<User>, ApiError> {
let user = User {
id: 1337,
username: payload.username,
};
database.load_details().await?;
sleep_random_duration().await;
Ok(Json(user))
}
// The input to our `create_user` handler
#[derive(Serialize, Deserialize)]
pub struct CreateUser {
pub username: String,
}
// The output to our `create_user` handler
#[derive(Serialize)]
pub struct User {
pub id: u64,
pub username: String,
}