meta_srv/handler/
filter_inactive_region_stats.rsuse api::v1::meta::{HeartbeatRequest, Role};
use async_trait::async_trait;
use common_telemetry::warn;
use crate::error::Result;
use crate::handler::{HandleControl, HeartbeatAccumulator, HeartbeatHandler};
use crate::metasrv::Context;
pub const NAME: &str = "FilterInactiveRegionStatsHandler";
pub struct FilterInactiveRegionStatsHandler;
#[async_trait]
impl HeartbeatHandler for FilterInactiveRegionStatsHandler {
fn is_acceptable(&self, role: Role) -> bool {
role == Role::Datanode
}
async fn handle(
&self,
req: &HeartbeatRequest,
_ctx: &mut Context,
acc: &mut HeartbeatAccumulator,
) -> Result<HandleControl> {
if acc.inactive_region_ids.is_empty() {
return Ok(HandleControl::Continue);
}
warn!(
"The heartbeat of this node {:?} contains some inactive regions: {:?}",
req.peer, acc.inactive_region_ids
);
let Some(stat) = acc.stat.as_mut() else {
return Ok(HandleControl::Continue);
};
stat.retain_active_region_stats(&acc.inactive_region_ids);
Ok(HandleControl::Continue)
}
}