-
Notifications
You must be signed in to change notification settings - Fork 220
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: add merge mining proxy support for p2pool #6474
feat: add merge mining proxy support for p2pool #6474
Conversation
Test Results (Integration tests)36 tests 36 ✅ 16m 3s ⏱️ Results for commit 650f6dc. ♻️ This comment has been updated with latest results. |
Test Results (CI) 2 files 86 suites 24m 11s ⏱️ For more details on these failures, see this check. Results for commit 650f6dc. ♻️ This comment has been updated with latest results. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good
applications/minotari_merge_mining_proxy/src/block_template_protocol.rs
Outdated
Show resolved
Hide resolved
applications/minotari_merge_mining_proxy/src/block_template_protocol.rs
Outdated
Show resolved
Hide resolved
applications/minotari_merge_mining_proxy/src/block_template_protocol.rs
Outdated
Show resolved
Hide resolved
…ri into st-randomx-merge-mining
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just 2 nits
applications/minotari_merge_mining_proxy/src/block_template_protocol.rs
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi there, I am a bit concerned that this PR is doing too much. My proposal would be to only add support for pool mining and then do condensing/refactoring in a next PR.
}, | ||
); | ||
b | ||
}, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We are missing handing this error
}, | |
}, | |
Err(MmProxyError::FailedPreconditionBlockLostRetry) => { | |
debug!( | |
target: LOG_TARGET, | |
"Chain tip has progressed past template height {}. Fetching a new block template (try {}).", | |
height, loop_count | |
); | |
continue; | |
}, |
None => { | ||
let new_template = match self.get_new_block_template().await { | ||
Ok(val) => val, | ||
let (_new_template, block_template_with_coinbase, height) = self |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
let (_new_template, block_template_with_coinbase, height) = self | |
let (new_template, block_template_with_coinbase, height) = self |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this field is not used, but I have removed it now
.cloned() | ||
.ok_or_else(|| MmProxyError::GrpcResponseMissingField("miner_data"))?; | ||
|
||
(add_monero_data(block, monero_mining_data.clone(), miner_data)?, height) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should new_template
as calculated earlier not be used for non-pools? I am not sure if miner data pulled form the block will be the same. In fn add_monero_data(
parameter template_data: NewBlockTemplateData
is fed in and not pulled from tari_block_result: grpc::GetNewBlockResult
. With the suggestion below we know the code will behave the same.
(add_monero_data(block, monero_mining_data.clone(), miner_data)?, height) | |
match self.p2pool_client.as_mut() { | |
Some(p2pool_client) => { | |
(add_monero_data(block, monero_mining_data.clone(), miner_data)?, height) | |
}, | |
None => { | |
(add_monero_data(block, monero_mining_data.clone(), new_template)?, height) | |
}, | |
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure I understand what you mean here. I think the mmproxy caching can be simplified even for non pools, but I unfortunately don't have the time to do this now
// TODO: I don't know why this is so complicated, but I've extracted it into it's own method to hide the ugliness | ||
async fn get_block_template_in_unnecessarily_complicated_manner( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
// TODO: I don't know why this is so complicated, but I've extracted it into it's own method to hide the ugliness | |
async fn get_block_template_in_unnecessarily_complicated_manner( | |
async fn get_block_template_from_cache_or_new( |
let new_template = match self.get_new_block_template().await { | ||
Ok(val) => val, | ||
let (_new_template, block_template_with_coinbase, height) = self | ||
.get_block_template_in_unnecessarily_complicated_manner( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
.get_block_template_in_unnecessarily_complicated_manner( | |
.get_block_template_from_cache_or_new( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
updated
let block_result = client.get_new_block(GetNewBlockRequest::default()).await?.into_inner(); | ||
block_result | ||
.block | ||
.ok_or_else(|| MmProxyError::FailedToGetBlockTemplate("block result".to_string()))? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think pool mining could also benefit using the cached templates
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
pool mining has a new template every second, so I don't think that is true
b.get(merge_mining_hash.as_ref()).map(|item| { | ||
trace!( | ||
target: LOG_TARGET, | ||
"Retrieving block template at height #{} with merge mining hash: {:?}", | ||
item.data.clone().template.new_block_template.header.unwrap_or_default().height, | ||
hex::encode(merge_mining_hash.as_ref()) | ||
); | ||
item.data.clone() | ||
}) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would leave in the the trace log please
@@ -325,7 +307,6 @@ impl BlockTemplateDataBuilder { | |||
tari_difficulty, | |||
tari_merge_mining_hash, | |||
aux_chain_hashes: self.aux_chain_hashes, | |||
new_block_template, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would leave refactoring this (removing new_block_template
and using tari_block
instead) for a next PR when we can do ample tests to verify that the change is good. We had very-hard-to-find sync issues between when the template is requested from the base node and when the block is finally populated by the base node, of state changing midway.
Co-authored-by: SW van Heerden <[email protected]>
…otocol.rs Co-authored-by: SW van Heerden <[email protected]>
Description --- Sha-P2Pool must be integrated into universe to help users earn more by mining in a pool. P2pool should be able to enable/disable from the app. Motivation and Context --- How Has This Been Tested? --- https://github.com/user-attachments/assets/7fa09375-d5e3-4e3f-b990-497dc38612c0 What process can a PR reviewer use to test or verify this change? --- See tests Breaking Changes --- - [x] None - [ ] Requires data directory on base node to be deleted - [ ] Requires hard fork - [ ] Other - Please specify **NOTE:** This PR must wait for the following changes to be merged: - tari-project/sha-p2pool#31 - tari-project/tari#6474 - tari-project/sha-p2pool#32 --------- Co-authored-by: stringhandler <[email protected]> Co-authored-by: C.Lee Taylor <[email protected]> Co-authored-by: shan <[email protected]> Co-authored-by: Marcin Papież <[email protected]> Co-authored-by: Misieq01 <[email protected]> Co-authored-by: Erika <[email protected]> Co-authored-by: stringhandler <[email protected]> Co-authored-by: Bertok Richard <[email protected]>
Adds merge mining support for p2pool