feat: fast detection of offline Node
Some checks failed
Typo / typo (push) Waiting to run
Audit / audit (push) Has been cancelled
Lockbud / lockbud (push) Has been cancelled
Rust / fmt (push) Has been cancelled
Rust / test (push) Has been cancelled
Rust / clippy (macos-latest) (push) Has been cancelled
Rust / clippy (ubuntu-latest) (push) Has been cancelled
Rust / check (macos-latest) (push) Has been cancelled
Rust / check (ubuntu-latest) (push) Has been cancelled
Rust / doc (push) Has been cancelled

This commit is contained in:
Cyrix126 2025-01-03 20:50:54 +01:00
parent 3238cf8cc4
commit e9ab69cd20
3 changed files with 23 additions and 19 deletions

View file

@ -659,12 +659,21 @@ impl Helper {
debug!("P2Pool Watchdog | Starting [update_from_output()]"); debug!("P2Pool Watchdog | Starting [update_from_output()]");
let mut process_lock = process.lock().unwrap(); let mut process_lock = process.lock().unwrap();
let mut pub_api_lock = pub_api.lock().unwrap(); let mut pub_api_lock = pub_api.lock().unwrap();
// if zmq fails were detected, we should increment the timer
if let Some(timer) = &mut pub_api_lock.fails_zmq_since {
*timer += 1;
}
// after 5 seconds without being reset to 0, set to none.
if pub_api_lock.fails_zmq_since.is_some_and(|t| t == 5) {
info!("P2Pool Watchdog | 5 seconds since a ZMQ failure was seen");
pub_api_lock.fails_zmq_since = None;
}
PubP2poolApi::update_from_output( PubP2poolApi::update_from_output(
&mut pub_api_lock, &mut pub_api_lock,
&output_parse, &output_parse,
&output_pub, &output_pub,
start.elapsed(), start.elapsed(),
&mut process_lock,
); );
// Read [local] API // Read [local] API
@ -874,6 +883,7 @@ pub struct PubP2poolApi {
pub sidechain_shares: u32, pub sidechain_shares: u32,
pub sidechain_ehr: f32, pub sidechain_ehr: f32,
pub sidechain_height: u32, pub sidechain_height: u32,
pub fails_zmq_since: Option<u32>,
// from local/p2p // from local/p2p
pub p2p_connected: u32, pub p2p_connected: u32,
pub node_connected: bool, pub node_connected: bool,
@ -933,6 +943,7 @@ impl PubP2poolApi {
p2p_connected: 0, p2p_connected: 0,
node_connected: false, node_connected: false,
prefer_local_node: true, prefer_local_node: true,
fails_zmq_since: None,
} }
} }
@ -984,7 +995,6 @@ impl PubP2poolApi {
output_parse: &Arc<Mutex<String>>, output_parse: &Arc<Mutex<String>>,
output_pub: &Arc<Mutex<String>>, output_pub: &Arc<Mutex<String>>,
elapsed: std::time::Duration, elapsed: std::time::Duration,
process: &mut Process,
) { ) {
// 1. Take the process's current output buffer and combine it with Pub (if not empty) // 1. Take the process's current output buffer and combine it with Pub (if not empty)
let mut output_pub = output_pub.lock().unwrap(); let mut output_pub = output_pub.lock().unwrap();
@ -997,8 +1007,10 @@ impl PubP2poolApi {
let mut output_parse = output_parse.lock().unwrap(); let mut output_parse = output_parse.lock().unwrap();
let (payouts_new, xmr_new) = Self::calc_payouts_and_xmr(&output_parse); let (payouts_new, xmr_new) = Self::calc_payouts_and_xmr(&output_parse);
// if the node is offline, p2pool can not function properly. Requires at least p2pool log level 1 // if the node is offline, p2pool can not function properly. Requires at least p2pool log level 1
if process.state == ProcessState::Alive && contains_zmq_failure(&output_parse) { // if log level 0, it will take 2 minutes to detect that the node is offline.
process.state = ProcessState::Syncing; if contains_zmq_failure(&output_parse) {
warn!("P2Pool Watchdog | a ZMQ failure was seen, check connection to Node");
public.fails_zmq_since = Some(0);
} }
// 3. Throw away [output_parse] // 3. Throw away [output_parse]
@ -1166,11 +1178,15 @@ impl PubP2poolApi {
&& self.node_connected && self.node_connected
&& self.p2p_connected > 1 && self.p2p_connected > 1
&& self.sidechain_height > 1000 && self.sidechain_height > 1000
&& self.fails_zmq_since.is_none()
{ {
process.state = ProcessState::Alive; process.state = ProcessState::Alive;
} }
if process.state == ProcessState::Alive if process.state == ProcessState::Alive
&& (self.sidechain_height < 1000 || !self.node_connected || self.p2p_connected == 0) && (self.sidechain_height < 1000
|| !self.node_connected
|| self.p2p_connected == 0
|| self.fails_zmq_since.is_some())
{ {
process.state = ProcessState::Syncing; process.state = ProcessState::Syncing;
} }

View file

@ -131,19 +131,8 @@ Uptime = 0h 2m 4s
))); )));
let output_pub = Arc::new(Mutex::new(String::new())); let output_pub = Arc::new(Mutex::new(String::new()));
let elapsed = std::time::Duration::from_secs(60); let elapsed = std::time::Duration::from_secs(60);
let process = Arc::new(Mutex::new(Process::new(
ProcessName::P2pool,
"".to_string(),
PathBuf::new(),
)));
let mut public = public.lock().unwrap(); let mut public = public.lock().unwrap();
PubP2poolApi::update_from_output( PubP2poolApi::update_from_output(&mut public, &output_parse, &output_pub, elapsed);
&mut public,
&output_parse,
&output_pub,
elapsed,
&mut process.lock().unwrap(),
);
println!("{:#?}", public); println!("{:#?}", public);
assert_eq!(public.payouts, 3); assert_eq!(public.payouts, 3);
assert_eq!(public.payouts_hour, 180.0); assert_eq!(public.payouts_hour, 180.0);
@ -184,7 +173,6 @@ Uptime = 0h 2m 4s
&output_parse, &output_parse,
&output_pub, &output_pub,
elapsed, elapsed,
&mut process.lock().unwrap(),
); );
println!("{:#?}", process); println!("{:#?}", process);
assert!(process.lock().unwrap().state == ProcessState::Syncing); // still syncing assert!(process.lock().unwrap().state == ProcessState::Syncing); // still syncing

View file

@ -387,7 +387,7 @@ pub const P2POOL_MAIN: &str = "Use the P2Pool main-chain. This P2Pool finds bloc
pub const P2POOL_MINI: &str = "Use the P2Pool mini-chain. This P2Pool finds blocks slower, but has a lower difficulty. Suitable for miners with less than 50kH/s"; pub const P2POOL_MINI: &str = "Use the P2Pool mini-chain. This P2Pool finds blocks slower, but has a lower difficulty. Suitable for miners with less than 50kH/s";
pub const P2POOL_OUT: &str = "How many out-bound peers to connect to? (you connecting to others)"; pub const P2POOL_OUT: &str = "How many out-bound peers to connect to? (you connecting to others)";
pub const P2POOL_IN: &str = "How many in-bound peers to allow? (others connecting to you)"; pub const P2POOL_IN: &str = "How many in-bound peers to allow? (others connecting to you)";
pub const P2POOL_LOG: &str = "Verbosity of the console log"; pub const P2POOL_LOG: &str = "Verbosity of the console log.\nA verbosity level more than 0 is recommended to let the P2Pool process detect more rapidly errors with the Monero Node.\nIf the level is at 0, it can take up to 2 minutes to detect an error.";
pub const P2POOL_AUTO_NODE: &str = "Automatically ping the remote Monero nodes at Gupaxx startup"; pub const P2POOL_AUTO_NODE: &str = "Automatically ping the remote Monero nodes at Gupaxx startup";
pub const P2POOL_AUTO_SELECT: &str = pub const P2POOL_AUTO_SELECT: &str =
"Automatically select the fastest remote Monero node after pinging"; "Automatically select the fastest remote Monero node after pinging";