mirror of
https://github.com/sigp/lighthouse.git
synced 2026-03-03 00:31:50 +00:00
## Issue Addressed - Resolves #1883 ## Proposed Changes This follows on from @blacktemplar's work in #2018. - Allows the VC to connect to multiple BN for redundancy. - Update the simulator so some nodes always need to rely on their fallback. - Adds some extra deprecation warnings for `--eth1-endpoint` - Pass `SignatureBytes` as a reference instead of by value. ## Additional Info NA Co-authored-by: blacktemplar <blacktemplar@a1.net>
160 lines
5.8 KiB
Rust
160 lines
5.8 KiB
Rust
use super::Context;
|
|
use slot_clock::SlotClock;
|
|
use std::time::{SystemTime, UNIX_EPOCH};
|
|
use types::EthSpec;
|
|
|
|
pub const SUCCESS: &str = "success";
|
|
pub const SLASHABLE: &str = "slashable";
|
|
pub const SAME_DATA: &str = "same_data";
|
|
pub const UNREGISTERED: &str = "unregistered";
|
|
pub const FULL_UPDATE: &str = "full_update";
|
|
pub const BEACON_BLOCK: &str = "beacon_block";
|
|
pub const ATTESTATIONS: &str = "attestations";
|
|
pub const AGGREGATES: &str = "aggregates";
|
|
pub const CURRENT_EPOCH: &str = "current_epoch";
|
|
pub const NEXT_EPOCH: &str = "next_epoch";
|
|
|
|
pub use lighthouse_metrics::*;
|
|
|
|
lazy_static::lazy_static! {
|
|
pub static ref GENESIS_DISTANCE: Result<IntGauge> = try_create_int_gauge(
|
|
"vc_genesis_distance_seconds",
|
|
"Distance between now and genesis time"
|
|
);
|
|
pub static ref ENABLED_VALIDATORS_COUNT: Result<IntGauge> = try_create_int_gauge(
|
|
"vc_validators_enabled_count",
|
|
"Number of enabled validators"
|
|
);
|
|
pub static ref TOTAL_VALIDATORS_COUNT: Result<IntGauge> = try_create_int_gauge(
|
|
"vc_validators_total_count",
|
|
"Number of total validators (enabled and disabled)"
|
|
);
|
|
|
|
pub static ref SIGNED_BLOCKS_TOTAL: Result<IntCounterVec> = try_create_int_counter_vec(
|
|
"vc_signed_beacon_blocks_total",
|
|
"Total count of attempted block signings",
|
|
&["status"]
|
|
);
|
|
pub static ref SIGNED_ATTESTATIONS_TOTAL: Result<IntCounterVec> = try_create_int_counter_vec(
|
|
"vc_signed_attestations_total",
|
|
"Total count of attempted Attestation signings",
|
|
&["status"]
|
|
);
|
|
pub static ref SIGNED_AGGREGATES_TOTAL: Result<IntCounterVec> = try_create_int_counter_vec(
|
|
"vc_signed_aggregates_total",
|
|
"Total count of attempted SignedAggregateAndProof signings",
|
|
&["status"]
|
|
);
|
|
pub static ref SIGNED_SELECTION_PROOFS_TOTAL: Result<IntCounterVec> = try_create_int_counter_vec(
|
|
"vc_signed_selection_proofs_total",
|
|
"Total count of attempted SelectionProof signings",
|
|
&["status"]
|
|
);
|
|
pub static ref DUTIES_SERVICE_TIMES: Result<HistogramVec> = try_create_histogram_vec(
|
|
"vc_duties_service_task_times_seconds",
|
|
"Duration to perform duties service tasks",
|
|
&["task"]
|
|
);
|
|
pub static ref FORK_SERVICE_TIMES: Result<HistogramVec> = try_create_histogram_vec(
|
|
"vc_fork_service_task_times_seconds",
|
|
"Duration to perform fork service tasks",
|
|
&["task"]
|
|
);
|
|
pub static ref ATTESTATION_SERVICE_TIMES: Result<HistogramVec> = try_create_histogram_vec(
|
|
"vc_attestation_service_task_times_seconds",
|
|
"Duration to perform attestation service tasks",
|
|
&["task"]
|
|
);
|
|
pub static ref BLOCK_SERVICE_TIMES: Result<HistogramVec> = try_create_histogram_vec(
|
|
"vc_beacon_block_service_task_times_seconds",
|
|
"Duration to perform beacon block service tasks",
|
|
&["task"]
|
|
);
|
|
pub static ref PROPOSER_COUNT: Result<IntGaugeVec> = try_create_int_gauge_vec(
|
|
"vc_beacon_block_proposer_count",
|
|
"Number of beacon block proposers on this host",
|
|
&["task"]
|
|
);
|
|
pub static ref ATTESTER_COUNT: Result<IntGaugeVec> = try_create_int_gauge_vec(
|
|
"vc_beacon_attester_count",
|
|
"Number of attesters on this host",
|
|
&["task"]
|
|
);
|
|
/*
|
|
* Endpoint metrics
|
|
*/
|
|
pub static ref ENDPOINT_ERRORS: Result<IntCounterVec> = try_create_int_counter_vec(
|
|
"bn_endpoint_errors",
|
|
"The number of beacon node request errors for each endpoint",
|
|
&["endpoint"]
|
|
);
|
|
pub static ref ENDPOINT_REQUESTS: Result<IntCounterVec> = try_create_int_counter_vec(
|
|
"bn_endpoint_requests",
|
|
"The number of beacon node requests for each endpoint",
|
|
&["endpoint"]
|
|
);
|
|
}
|
|
|
|
pub fn gather_prometheus_metrics<T: EthSpec>(
|
|
ctx: &Context<T>,
|
|
) -> std::result::Result<String, String> {
|
|
let mut buffer = vec![];
|
|
let encoder = TextEncoder::new();
|
|
|
|
{
|
|
let shared = ctx.shared.read();
|
|
|
|
if let Some(genesis_time) = shared.genesis_time {
|
|
if let Ok(now) = SystemTime::now().duration_since(UNIX_EPOCH) {
|
|
let distance = now.as_secs() as i64 - genesis_time as i64;
|
|
set_gauge(&GENESIS_DISTANCE, distance);
|
|
}
|
|
}
|
|
|
|
if let Some(validator_store) = &shared.validator_store {
|
|
let initialized_validators_lock = validator_store.initialized_validators();
|
|
let initialized_validators = initialized_validators_lock.read();
|
|
|
|
set_gauge(
|
|
&ENABLED_VALIDATORS_COUNT,
|
|
initialized_validators.num_enabled() as i64,
|
|
);
|
|
set_gauge(
|
|
&TOTAL_VALIDATORS_COUNT,
|
|
initialized_validators.num_total() as i64,
|
|
);
|
|
}
|
|
|
|
if let Some(duties_service) = &shared.duties_service {
|
|
if let Some(slot) = duties_service.slot_clock.now() {
|
|
let current_epoch = slot.epoch(T::slots_per_epoch());
|
|
let next_epoch = current_epoch + 1;
|
|
|
|
set_int_gauge(
|
|
&PROPOSER_COUNT,
|
|
&[CURRENT_EPOCH],
|
|
duties_service.proposer_count(current_epoch) as i64,
|
|
);
|
|
set_int_gauge(
|
|
&ATTESTER_COUNT,
|
|
&[CURRENT_EPOCH],
|
|
duties_service.attester_count(current_epoch) as i64,
|
|
);
|
|
set_int_gauge(
|
|
&ATTESTER_COUNT,
|
|
&[NEXT_EPOCH],
|
|
duties_service.attester_count(next_epoch) as i64,
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
warp_utils::metrics::scrape_health_metrics();
|
|
|
|
encoder
|
|
.encode(&lighthouse_metrics::gather(), &mut buffer)
|
|
.unwrap();
|
|
|
|
String::from_utf8(buffer).map_err(|e| format!("Failed to encode prometheus info: {:?}", e))
|
|
}
|