Expand description
§Client for Fastly Real Time API
The library contains wapper for Fastly’s Real-time analytics and Real-time origin metrics
§Real-time analytics
Real-time analytics provides statistics of a service.
Related structures are service::ServiceResponse
, service::ServiceDataInSecond
, service::ServiceStats
To get statistic concecutively
use fastly_rt::service::ServiceClient;
use std::env;
use std::{thread, time};
#[tokio::main]
async fn main() {
let api_key = env::var("KEY").expect("env KEY not set");
let sid = env::var("SID").expect("env SID not set");
let mut rt = ServiceClient::new(&api_key, &sid).unwrap();
for _ in 0..5 {
let rt_data = rt.get_stats_consecutive().await.unwrap();
for data in rt_data.data {
println!("time {}, number of requests {}", data.recorded, data.aggregated.requests);
}
thread::sleep(time::Duration::from_secs(1));
}
}
To get statistic of last 120 seconds
use fastly_rt::service::ServiceClient;
use std::env;
#[tokio::main]
async fn main() {
let api_key = env::var("KEY").expect("env KEY not set");
let sid = env::var("SID").expect("env SID not set");
let mut rt = ServiceClient::new(&api_key, &sid).unwrap();
let rt_data = rt.get_stats_120s().await.unwrap();
for data in rt_data.data {
println!("time {}, number of requests {}", data.recorded, data.aggregated.requests);
}
}
To get statistic of last 10 seconds
use fastly_rt::service::ServiceClient;
use std::env;
#[tokio::main]
async fn main() {
let api_key = env::var("KEY").expect("env KEY not set");
let sid = env::var("SID").expect("env SID not set");
let mut rt = ServiceClient::new(&api_key, &sid).unwrap();
let rt_data = rt.get_stats_max(10).await.unwrap();
for data in rt_data.data {
println!("time {}, number of requests {}", data.recorded, data.aggregated.requests);
}
}
§Real-time origin metrics
Real-time origin metrics provides statistics of origins of a service.
Related structures are origin::OriginResponse
, origin::OriginDataInSecond
, origin::OriginStats
Examples are similar to that Real-time origin metrics