mirror of
https://github.com/SChernykh/p2pool.git
synced 2025-01-20 17:34:31 +00:00
P2PServer: use BLOCK_NOTIFY to speed up syncing
This commit is contained in:
parent
d72f0ce40c
commit
fe2ff95f19
3 changed files with 29 additions and 7 deletions
|
@ -2012,12 +2012,23 @@ bool P2PServer::P2PClient::on_block_request(const uint8_t* buf)
|
||||||
P2PServer* server = static_cast<P2PServer*>(m_owner);
|
P2PServer* server = static_cast<P2PServer*>(m_owner);
|
||||||
|
|
||||||
std::vector<uint8_t> blob;
|
std::vector<uint8_t> blob;
|
||||||
if (!server->m_pool->side_chain().get_block_blob(id, blob) && !id.empty()) {
|
const PoolBlock* block = server->m_pool->side_chain().get_block_blob(id, blob);
|
||||||
|
|
||||||
|
if (!block && !id.empty()) {
|
||||||
LOGWARN(5, "got a request for block with id " << id << " but couldn't find it");
|
LOGWARN(5, "got a request for block with id " << id << " but couldn't find it");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Notifications about parent and uncle blocks to speed up syncing
|
||||||
|
std::vector<hash> notify_blocks;
|
||||||
|
|
||||||
|
if (block && (m_protocolVersion >= PROTOCOL_VERSION_1_2)) {
|
||||||
|
notify_blocks.reserve(block->m_uncles.size() + 1);
|
||||||
|
notify_blocks.push_back(block->m_parent);
|
||||||
|
notify_blocks.insert(notify_blocks.end(), block->m_uncles.begin(), block->m_uncles.end());
|
||||||
|
}
|
||||||
|
|
||||||
return server->send(this,
|
return server->send(this,
|
||||||
[this, &blob](uint8_t* buf, size_t buf_size) -> size_t
|
[this, &blob, ¬ify_blocks](uint8_t* buf, size_t buf_size) -> size_t
|
||||||
{
|
{
|
||||||
LOGINFO(5, "sending BLOCK_RESPONSE to " << static_cast<char*>(m_addrString));
|
LOGINFO(5, "sending BLOCK_RESPONSE to " << static_cast<char*>(m_addrString));
|
||||||
|
|
||||||
|
@ -2029,6 +2040,17 @@ bool P2PServer::P2PClient::on_block_request(const uint8_t* buf)
|
||||||
|
|
||||||
uint8_t* p = buf;
|
uint8_t* p = buf;
|
||||||
|
|
||||||
|
if (buf_size >= 1 + sizeof(uint32_t) + len + notify_blocks.size() * (1 + HASH_SIZE)) {
|
||||||
|
for (const hash& id : notify_blocks) {
|
||||||
|
LOGINFO(5, "sending BLOCK_NOTIFY for " << id << " to " << static_cast<char*>(m_addrString));
|
||||||
|
|
||||||
|
*(p++) = static_cast<uint8_t>(MessageId::BLOCK_NOTIFY);
|
||||||
|
|
||||||
|
memcpy(p, id.h, HASH_SIZE);
|
||||||
|
p += HASH_SIZE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
*(p++) = static_cast<uint8_t>(MessageId::BLOCK_RESPONSE);
|
*(p++) = static_cast<uint8_t>(MessageId::BLOCK_RESPONSE);
|
||||||
|
|
||||||
memcpy(p, &len, sizeof(uint32_t));
|
memcpy(p, &len, sizeof(uint32_t));
|
||||||
|
|
|
@ -739,7 +739,7 @@ void SideChain::watch_mainchain_block(const ChainMain& data, const hash& possibl
|
||||||
m_watchBlockSidechainId = possible_id;
|
m_watchBlockSidechainId = possible_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SideChain::get_block_blob(const hash& id, std::vector<uint8_t>& blob) const
|
const PoolBlock* SideChain::get_block_blob(const hash& id, std::vector<uint8_t>& blob) const
|
||||||
{
|
{
|
||||||
ReadLock lock(m_sidechainLock);
|
ReadLock lock(m_sidechainLock);
|
||||||
|
|
||||||
|
@ -751,7 +751,7 @@ bool SideChain::get_block_blob(const hash& id, std::vector<uint8_t>& blob) const
|
||||||
|
|
||||||
// Don't return stale chain tip
|
// Don't return stale chain tip
|
||||||
if (block && (block->m_txinGenHeight + 2 < m_pool->miner_data().height)) {
|
if (block && (block->m_txinGenHeight + 2 < m_pool->miner_data().height)) {
|
||||||
return false;
|
return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -762,14 +762,14 @@ bool SideChain::get_block_blob(const hash& id, std::vector<uint8_t>& blob) const
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!block) {
|
if (!block) {
|
||||||
return false;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
blob = block->serialize_mainchain_data();
|
blob = block->serialize_mainchain_data();
|
||||||
const std::vector<uint8_t> sidechain_data = block->serialize_sidechain_data();
|
const std::vector<uint8_t> sidechain_data = block->serialize_sidechain_data();
|
||||||
blob.insert(blob.end(), sidechain_data.begin(), sidechain_data.end());
|
blob.insert(blob.end(), sidechain_data.begin(), sidechain_data.end());
|
||||||
|
|
||||||
return true;
|
return block;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SideChain::get_outputs_blob(PoolBlock* block, uint64_t total_reward, std::vector<uint8_t>& blob, uv_loop_t* loop) const
|
bool SideChain::get_outputs_blob(PoolBlock* block, uint64_t total_reward, std::vector<uint8_t>& blob, uv_loop_t* loop) const
|
||||||
|
|
|
@ -57,7 +57,7 @@ public:
|
||||||
PoolBlock* find_block(const hash& id) const;
|
PoolBlock* find_block(const hash& id) const;
|
||||||
void watch_mainchain_block(const ChainMain& data, const hash& possible_id);
|
void watch_mainchain_block(const ChainMain& data, const hash& possible_id);
|
||||||
|
|
||||||
bool get_block_blob(const hash& id, std::vector<uint8_t>& blob) const;
|
const PoolBlock* get_block_blob(const hash& id, std::vector<uint8_t>& blob) const;
|
||||||
bool get_outputs_blob(PoolBlock* block, uint64_t total_reward, std::vector<uint8_t>& blob, uv_loop_t* loop) const;
|
bool get_outputs_blob(PoolBlock* block, uint64_t total_reward, std::vector<uint8_t>& blob, uv_loop_t* loop) const;
|
||||||
|
|
||||||
void print_status(bool obtain_sidechain_lock = true) const;
|
void print_status(bool obtain_sidechain_lock = true) const;
|
||||||
|
|
Loading…
Reference in a new issue