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

Modules