mirror of
https://github.com/Cyrix126/gupaxx.git
synced 2025-01-07 22:49:32 +00:00
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
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:
parent
3238cf8cc4
commit
e9ab69cd20
3 changed files with 23 additions and 19 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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";
|
||||||
|
|
Loading…
Reference in a new issue