mirror of
https://github.com/Cyrix126/gupaxx.git
synced 2025-01-06 22:19:22 +00:00
fix: green status p2pool when node offline
limit minimum log verbosity of P2Pool to 2 The user could always set log_level 1 or 0 in command args in advanced tab and break detection of errors.
This commit is contained in:
parent
fcee2c4944
commit
9092b5cd91
3 changed files with 36 additions and 4 deletions
|
@ -107,10 +107,10 @@ impl P2pool {
|
||||||
ui.add_space(SPACE);
|
ui.add_space(SPACE);
|
||||||
slider_state_field(
|
slider_state_field(
|
||||||
ui,
|
ui,
|
||||||
"Log level [ 0-6 ]:",
|
"Log level [ 2-6 ]:",
|
||||||
P2POOL_LOG,
|
P2POOL_LOG,
|
||||||
&mut self.log_level,
|
&mut self.log_level,
|
||||||
0..=6,
|
2..=6,
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|
|
@ -12,9 +12,11 @@ use crate::helper::signal_end;
|
||||||
use crate::helper::sleep_end_loop;
|
use crate::helper::sleep_end_loop;
|
||||||
use crate::regex::P2POOL_REGEX;
|
use crate::regex::P2POOL_REGEX;
|
||||||
use crate::regex::contains_end_status;
|
use crate::regex::contains_end_status;
|
||||||
|
use crate::regex::contains_newchain_tip;
|
||||||
use crate::regex::contains_statuscommand;
|
use crate::regex::contains_statuscommand;
|
||||||
use crate::regex::contains_yourhashrate;
|
use crate::regex::contains_yourhashrate;
|
||||||
use crate::regex::contains_yourshare;
|
use crate::regex::contains_yourshare;
|
||||||
|
use crate::regex::contains_zmq_failure;
|
||||||
use crate::regex::estimated_hr;
|
use crate::regex::estimated_hr;
|
||||||
use crate::regex::nb_current_shares;
|
use crate::regex::nb_current_shares;
|
||||||
use crate::{
|
use crate::{
|
||||||
|
@ -370,6 +372,12 @@ impl Helper {
|
||||||
} else {
|
} else {
|
||||||
&state.ip
|
&state.ip
|
||||||
};
|
};
|
||||||
|
// log level of p2pool must be minimum 2 so Gupaxx works correctly.
|
||||||
|
let log_level = if state.log_level < 2 {
|
||||||
|
2
|
||||||
|
} else {
|
||||||
|
state.log_level
|
||||||
|
};
|
||||||
args.push("--wallet".to_string());
|
args.push("--wallet".to_string());
|
||||||
args.push(state.address.clone()); // Wallet
|
args.push(state.address.clone()); // Wallet
|
||||||
args.push("--host".to_string());
|
args.push("--host".to_string());
|
||||||
|
@ -379,7 +387,7 @@ impl Helper {
|
||||||
args.push("--zmq-port".to_string());
|
args.push("--zmq-port".to_string());
|
||||||
args.push(state.zmq.to_string()); // ZMQ
|
args.push(state.zmq.to_string()); // ZMQ
|
||||||
args.push("--loglevel".to_string());
|
args.push("--loglevel".to_string());
|
||||||
args.push(state.log_level.to_string()); // Log Level
|
args.push(log_level.to_string()); // Log Level
|
||||||
args.push("--out-peers".to_string());
|
args.push("--out-peers".to_string());
|
||||||
args.push(state.out_peers.to_string()); // Out Peers
|
args.push(state.out_peers.to_string()); // Out Peers
|
||||||
args.push("--in-peers".to_string());
|
args.push("--in-peers".to_string());
|
||||||
|
@ -859,7 +867,7 @@ impl PubP2poolApi {
|
||||||
// 2. Parse the full STDOUT
|
// 2. Parse the full STDOUT
|
||||||
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);
|
||||||
// Check for "SYNCHRONIZED" only if we aren't already.
|
// Check for "SYNCHRONIZED" only if we aren't already. Works at level 0 and above.
|
||||||
if process.state == ProcessState::Syncing {
|
if process.state == ProcessState::Syncing {
|
||||||
// How many times the word was captured.
|
// How many times the word was captured.
|
||||||
let synchronized_captures = P2POOL_REGEX.synchronized.find_iter(&output_parse).count();
|
let synchronized_captures = P2POOL_REGEX.synchronized.find_iter(&output_parse).count();
|
||||||
|
@ -880,6 +888,15 @@ impl PubP2poolApi {
|
||||||
// just finding 1 instance of "SYNCHRONIZED".
|
// just finding 1 instance of "SYNCHRONIZED".
|
||||||
process.state = ProcessState::Alive;
|
process.state = ProcessState::Alive;
|
||||||
}
|
}
|
||||||
|
// if the p2pool node was synced but is not anymore due to faulty monero node and is synced again, the status must be alive again
|
||||||
|
// required log level 2 minimum
|
||||||
|
if contains_newchain_tip(&output_parse) {
|
||||||
|
process.state = ProcessState::Alive;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 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) {
|
||||||
|
process.state = ProcessState::Syncing;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 3. Throw away [output_parse]
|
// 3. Throw away [output_parse]
|
||||||
|
|
|
@ -277,6 +277,21 @@ pub fn contains_end_status(l: &str) -> bool {
|
||||||
static LINE_SHARE: Lazy<Regex> = Lazy::new(|| Regex::new(r"^Uptime ").unwrap());
|
static LINE_SHARE: Lazy<Regex> = Lazy::new(|| Regex::new(r"^Uptime ").unwrap());
|
||||||
LINE_SHARE.is_match(l)
|
LINE_SHARE.is_match(l)
|
||||||
}
|
}
|
||||||
|
// P2Pool
|
||||||
|
/// if the node is disconnected
|
||||||
|
/// this error will be present if log > 1 and Node is disconnected
|
||||||
|
pub fn contains_zmq_failure(l: &str) -> bool {
|
||||||
|
static LINE_SHARE: Lazy<Regex> = Lazy::new(|| {
|
||||||
|
Regex::new(r"(p2pool with offline node: failed: error Error (empty response)|ZMQReader failed to connect to|P2Pool Couldn't restart ZMQ reader: exception Operation cannot be accomplished in current state)").unwrap()
|
||||||
|
});
|
||||||
|
LINE_SHARE.is_match(l)
|
||||||
|
}
|
||||||
|
/// a way to detect that p2pool is alive
|
||||||
|
pub fn contains_newchain_tip(l: &str) -> bool {
|
||||||
|
static LINE_SHARE: Lazy<Regex> = Lazy::new(|| Regex::new(r"new chain tip").unwrap());
|
||||||
|
LINE_SHARE.is_match(l)
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------- TEST
|
//---------------------------------------------------------------------------------------------------- TEST
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod test {
|
mod test {
|
||||||
|
|
Loading…
Reference in a new issue