From afa7e2a02d77256645ebd386059681cfa550f5cd Mon Sep 17 00:00:00 2001 From: dkos Date: Sun, 30 Aug 2020 13:32:08 +0200 Subject: [PATCH] prometheus integration --- Cargo.toml | 1 - src/main.rs | 40 ++++++---------------------------------- 2 files changed, 6 insertions(+), 35 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 5639eca..10d27be 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -13,7 +13,6 @@ structopt = "0.3" actix-web = "2.0" actix-rt = "1.0" actix-web-prom = "0.2" -prometheus = "0.8" serde = { version = "1.0", features = ["derive"] } diff --git a/src/main.rs b/src/main.rs index aef6212..b059249 100644 --- a/src/main.rs +++ b/src/main.rs @@ -5,11 +5,11 @@ use std::fs::File; use actix_web::body::{Body, ResponseBody}; use actix_web::http::header::ContentType; - use actix_web::middleware::errhandlers::{ErrorHandlerResponse, ErrorHandlers}; use actix_web::web::Bytes; use actix_web::{delete, dev, get, http, post, put, HttpRequest, HttpResponse, ResponseError}; use actix_web::{web, App, HttpServer}; +use actix_web_prom::PrometheusMetrics; use log::LevelFilter; use serde::Deserialize; use simplelog::{ConfigBuilder, TermLogger, TerminalMode, ThreadLogMode, WriteLogger}; @@ -20,10 +20,6 @@ use crate::conversion::{convert, current_ms, Conversion}; use crate::db::DbManager; use crate::errors::{ApiError, DbError}; -use actix_web_prom::PrometheusMetrics; -use prometheus::core::{AtomicI64, GenericCounterVec}; -use prometheus::{opts, IntCounterVec}; - mod errors; mod config; @@ -112,20 +108,6 @@ async fn open(db_name: web::Path, db_man: web::Data) -> Respo Ok(HttpResponse::Ok().finish()) } -#[get("/{db_name}")] -async fn db_size( - db_name: web::Path, - c: web::Data>, -) -> HttpResponse { - let r = c - .get_metric_with_label_values(&[&db_name]) - .map_or(0, |gc| gc.get()); - - HttpResponse::Ok() - .set(ContentType::plaintext()) - .body(r.to_string()) -} - #[delete("/{db_name}")] async fn close(db_name: web::Path, db_man: web::Data) -> Response { db_man.close(db_name.into_inner()).await?; @@ -198,32 +180,18 @@ async fn main() -> std::io::Result<()> { db_manager.init(); let db_manager = web::Data::new(db_manager); - let prometheus = PrometheusMetrics::new("api", Some("/metrics"), None); - - let counter_opts = opts!("db_size_counter", "Database size").namespace("db"); - let counter = IntCounterVec::new(counter_opts, &["db_name"]).unwrap(); - prometheus - .registry - .register(Box::new(counter.clone())) - .unwrap(); - - counter.with_label_values(&["baza1"]).inc(); - - let c = web::Data::new(counter); - + let prometheus = init_prometheus(); HttpServer::new(move || { App::new() .wrap(ErrorHandlers::new().handler(http::StatusCode::NOT_FOUND, not_found)) .wrap(prometheus.clone()) .app_data(db_manager.clone()) - .app_data(c.clone()) .service(open) .service(close) .service(store) .service(read) .service(remove) .service(health) - .service(db_size) }) .bind(service_cfg.bind_address())? .workers(service_cfg.workers()) @@ -232,6 +200,10 @@ async fn main() -> std::io::Result<()> { .await } +fn init_prometheus() -> PrometheusMetrics { + PrometheusMetrics::new("api", Some("/metrics"), None) +} + fn init_logger(log_path: &str, dev_mode: bool) { let cfg = ConfigBuilder::new() .set_thread_mode(ThreadLogMode::Both)