Skip to content

Commit

Permalink
Fix worker retain
Browse files Browse the repository at this point in the history
  • Loading branch information
Mark-Simulacrum committed Nov 10, 2023
1 parent 8491684 commit 5bac763
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 2 deletions.
2 changes: 1 addition & 1 deletion src/server/agents.rs
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ impl Agents {
let mut guard = self.current_workers.lock().unwrap();
guard.retain(|_, (_, timestamp)| {
// It's been 10 minutes since we heard from this worker, drop it from our active list.
timestamp.elapsed() > std::time::Duration::from_secs(60 * 10)
timestamp.elapsed() < std::time::Duration::from_secs(60 * 10)
});
guard.len()
}
Expand Down
9 changes: 8 additions & 1 deletion src/server/metrics.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ use crate::experiments::{Assignee, Experiment};
use crate::prelude::*;
use crate::server::agents::Agent;
use chrono::{DateTime, Utc};
use prometheus::{HistogramVec, IntCounter, IntCounterVec, IntGauge, IntGaugeVec};
use prometheus::{Histogram, HistogramVec, IntCounter, IntCounterVec, IntGauge, IntGaugeVec};

const JOBS_METRIC: &str = "crater_completed_jobs_total";
const AGENT_WORK_METRIC: &str = "crater_agent_supposed_to_work";
Expand All @@ -21,6 +21,7 @@ pub struct Metrics {
crater_last_crates_update: IntGauge,
pub crater_endpoint_time: HistogramVec,
crater_worker_count: IntGauge,
pub result_log_size: Histogram,
}

impl Metrics {
Expand All @@ -47,6 +48,11 @@ impl Metrics {
.buckets(prometheus::exponential_buckets(0.05, 1.2, 25).unwrap()),
&["endpoint"]
)?;
let result_log_size = prometheus::register_histogram!(
"crater_log_length",
"payload size in bytes",
prometheus::exponential_buckets(4096.0, 1.28, 30)?
)?;

let crater_worker_count = prometheus::opts!(WORKER_COUNT, "number of active workers");
let crater_worker_count = prometheus::register_int_gauge!(crater_worker_count)?;
Expand All @@ -59,6 +65,7 @@ impl Metrics {
crater_last_crates_update,
crater_endpoint_time,
crater_worker_count,
result_log_size,
})
}

Expand Down
2 changes: 2 additions & 0 deletions src/server/routes/agent.rs
Original file line number Diff line number Diff line change
Expand Up @@ -303,6 +303,8 @@ fn endpoint_record_progress(
) -> Fallible<Response<Body>> {
let start = Instant::now();

data.metrics.result_log_size.observe(result.data.result.log.len() as f64);

let ret = match data.record_progress_worker.queue.try_send(result) {
Ok(()) => Ok(ApiResponse::Success { result: true }.into_response()?),
Err(crossbeam_channel::TrySendError::Full(_)) => {
Expand Down

0 comments on commit 5bac763

Please sign in to comment.