#[macro_use] extern crate log;
use k8s_openapi::api::core::v1::Node;
use kube::{
api::{ListParams, Meta, Resource},
client::APIClient,
config,
runtime::Reflector,
};
#[tokio::main]
async fn main() -> anyhow::Result<()> {
std::env::set_var("RUST_LOG", "info,kube=debug");
env_logger::init();
let config = config::load_kube_config().await?;
let client = APIClient::new(config);
let resource = Resource::all::<Node>();
let lp = ListParams::default()
.labels("beta.kubernetes.io/instance-type=m4.2xlarge") .timeout(10); let rf: Reflector<Node> = Reflector::new(client, lp, resource).init().await?;
rf.state().await?.into_iter().for_each(|o| {
let labels = Meta::meta(&o).labels.clone().unwrap();
info!(
"Found node {} ({:?}) running {:?} with labels: {:?}",
Meta::name(&o),
o.spec.unwrap().provider_id.unwrap(),
o.status.unwrap().conditions.unwrap(),
labels
);
});
let cloned = rf.clone();
tokio::spawn(async move {
loop {
if let Err(e) = cloned.poll().await {
warn!("Poll error: {:?}", e);
}
}
});
loop {
rf.poll().await?;
let deploys: Vec<_> = rf.state().await?.iter().map(Meta::name).collect();
info!("Current {} nodes: {:?}", deploys.len(), deploys);
}
}