mirror of
https://github.com/Cuprate/cuprate.git
synced 2025-01-08 20:09:44 +00:00
add more data to status
This commit is contained in:
parent
864380b15c
commit
5c10d35581
4 changed files with 30 additions and 14 deletions
|
@ -20,17 +20,17 @@ use cuprate_p2p_core::{ClearNet, ClearNetServerCfg};
|
||||||
mod args;
|
mod args;
|
||||||
mod fs;
|
mod fs;
|
||||||
mod p2p;
|
mod p2p;
|
||||||
|
mod rayon;
|
||||||
mod storage;
|
mod storage;
|
||||||
mod tokio;
|
mod tokio;
|
||||||
mod tracing_config;
|
mod tracing_config;
|
||||||
mod rayon;
|
|
||||||
|
|
||||||
use crate::config::fs::FileSystemConfig;
|
use crate::config::fs::FileSystemConfig;
|
||||||
|
use crate::config::rayon::RayonConfig;
|
||||||
use crate::config::tokio::TokioConfig;
|
use crate::config::tokio::TokioConfig;
|
||||||
use p2p::P2PConfig;
|
use p2p::P2PConfig;
|
||||||
use storage::StorageConfig;
|
use storage::StorageConfig;
|
||||||
use tracing_config::TracingConfig;
|
use tracing_config::TracingConfig;
|
||||||
use crate::config::rayon::RayonConfig;
|
|
||||||
|
|
||||||
/// Reads the args & config file, returning a [`Config`].
|
/// Reads the args & config file, returning a [`Config`].
|
||||||
pub fn read_config_and_args() -> Config {
|
pub fn read_config_and_args() -> Config {
|
||||||
|
|
|
@ -13,5 +13,3 @@ impl Default for RayonConfig {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -18,8 +18,13 @@
|
||||||
|
|
||||||
use crate::commands::Command;
|
use crate::commands::Command;
|
||||||
use crate::config::Config;
|
use crate::config::Config;
|
||||||
|
use crate::constants::PANIC_CRITICAL_SERVICE_ERROR;
|
||||||
|
use cuprate_consensus_context::{
|
||||||
|
BlockChainContextRequest, BlockChainContextResponse, BlockChainContextService,
|
||||||
|
};
|
||||||
use cuprate_helper::time::secs_to_hms;
|
use cuprate_helper::time::secs_to_hms;
|
||||||
use tokio::sync::mpsc;
|
use tokio::sync::mpsc;
|
||||||
|
use tower::{Service, ServiceExt};
|
||||||
use tracing::level_filters::LevelFilter;
|
use tracing::level_filters::LevelFilter;
|
||||||
use tracing_subscriber::layer::SubscriberExt;
|
use tracing_subscriber::layer::SubscriberExt;
|
||||||
use tracing_subscriber::reload::Handle;
|
use tracing_subscriber::reload::Handle;
|
||||||
|
@ -100,7 +105,7 @@ fn main() {
|
||||||
blockchain_write_handle,
|
blockchain_write_handle,
|
||||||
blockchain_read_handle,
|
blockchain_read_handle,
|
||||||
txpool_write_handle,
|
txpool_write_handle,
|
||||||
context_svc,
|
context_svc.clone(),
|
||||||
block_verifier,
|
block_verifier,
|
||||||
config.block_downloader_config(),
|
config.block_downloader_config(),
|
||||||
)
|
)
|
||||||
|
@ -109,7 +114,7 @@ fn main() {
|
||||||
let (command_tx, command_rx) = mpsc::channel(1);
|
let (command_tx, command_rx) = mpsc::channel(1);
|
||||||
std::thread::spawn(|| commands::command_listener(command_tx));
|
std::thread::spawn(|| commands::command_listener(command_tx));
|
||||||
|
|
||||||
io_loop(command_rx).await;
|
io_loop(command_rx, context_svc).await;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,7 +133,10 @@ fn init_global_rayon_pool(config: &Config) {
|
||||||
.unwrap()
|
.unwrap()
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn io_loop(mut incoming_commands: mpsc::Receiver<Command>) -> ! {
|
async fn io_loop(
|
||||||
|
mut incoming_commands: mpsc::Receiver<Command>,
|
||||||
|
mut context_service: BlockChainContextService,
|
||||||
|
) -> ! {
|
||||||
while let Some(command) = incoming_commands.recv().await {
|
while let Some(command) = incoming_commands.recv().await {
|
||||||
match command {
|
match command {
|
||||||
Command::SetLog { level } => {
|
Command::SetLog { level } => {
|
||||||
|
@ -137,10 +145,22 @@ async fn io_loop(mut incoming_commands: mpsc::Receiver<Command>) -> ! {
|
||||||
println!("LOG LEVEL CHANGED: {level}");
|
println!("LOG LEVEL CHANGED: {level}");
|
||||||
}
|
}
|
||||||
Command::Status => {
|
Command::Status => {
|
||||||
|
let BlockChainContextResponse::Context(blockchain_context) = context_service
|
||||||
|
.ready()
|
||||||
|
.await
|
||||||
|
.expect(PANIC_CRITICAL_SERVICE_ERROR)
|
||||||
|
.call(BlockChainContextRequest::Context)
|
||||||
|
.await
|
||||||
|
.expect(PANIC_CRITICAL_SERVICE_ERROR)
|
||||||
|
else {
|
||||||
|
unreachable!();
|
||||||
|
};
|
||||||
|
let context = blockchain_context.unchecked_blockchain_context();
|
||||||
|
|
||||||
let uptime = statics::START_INSTANT.elapsed().unwrap_or_default();
|
let uptime = statics::START_INSTANT.elapsed().unwrap_or_default();
|
||||||
let (hours, minutes, second) = secs_to_hms(uptime.as_secs());
|
let (hours, minutes, second) = secs_to_hms(uptime.as_secs());
|
||||||
|
|
||||||
println!("STATUS:\n uptime: {hours}h {minutes}m {second}s");
|
println!("STATUS:\n uptime: {hours}h {minutes}m {second}s,\n height: {},\n top_hash: {}", context.chain_height, hex::encode(context.top_hash));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,15 +39,13 @@ pub(crate) fn save_peers_to_disk<Z: BorshNetworkZone>(
|
||||||
})
|
})
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
let dir = cfg
|
let dir = cfg.peer_store_directory.clone();
|
||||||
.peer_store_directory.clone();
|
let file = dir.join(format!("{}_p2p_state", Z::NAME));
|
||||||
let file = dir
|
|
||||||
.join(format!("{}_p2p_state", Z::NAME));
|
|
||||||
|
|
||||||
spawn_blocking(move || {
|
spawn_blocking(move || {
|
||||||
fs::create_dir_all(dir)?;
|
fs::create_dir_all(dir)?;
|
||||||
fs::write(&file, &data) }
|
fs::write(&file, &data)
|
||||||
)
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) async fn read_peers_from_disk<Z: BorshNetworkZone>(
|
pub(crate) async fn read_peers_from_disk<Z: BorshNetworkZone>(
|
||||||
|
|
Loading…
Reference in a new issue