Skip to content
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

Feature/dpos pbft bos upgrade: fix snapshot compatibility; add pbft_api plugin; fix bugs #98

Closed
wants to merge 26 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
a28493e
fix potential crash when calculating integrity hash
VincentOCL May 14, 2019
8dad318
fix snapshot's container reading in different os.
VincentOCL May 14, 2019
37beebe
reformat snapshot sections; reformat getting block state in pbft_db.
VincentOCL May 15, 2019
ec893e6
Merge branch 'develop' into feature/dpos-pbft-bos-upgrade
oldcold May 15, 2019
1cc5e17
re-struct pbft message; compress pbft new view
May 17, 2019
902177a
add new view primary check; add debug info during prepare (commit) in…
May 18, 2019
cf75956
optimise cal in `should_recv_pbft_msg` and `should_send_pbft_msg`; do…
May 21, 2019
3c45326
generate pbft watermark from forkdb.
May 22, 2019
303c12d
generate pbft watermark from forkdb.
May 22, 2019
0f63be7
Merge remote-tracking branch 'origin/feature/dpos-pbft-bos-upgrade' i…
VincentOCL May 28, 2019
f475fa6
add pbft_api_plugin
May 29, 2019
8a1c39c
increase pbft message deadline
May 30, 2019
56110e0
increase new view message deadline; add prepared & my_prepare in pbft…
May 30, 2019
7b241d5
re-struct pbft message; compress pbft new view
May 17, 2019
3b7068b
fix bug in new view decompression.
May 31, 2019
601c8c6
Merge remote-tracking branch 'origin/feature/dpos-pbft-bos-upgrade-sl…
VincentOCL May 31, 2019
fd444d2
optimise scp sync; move upo creation into `update_pbft_status`;
Jun 2, 2019
a63265f
fix bug in loading old version snapshots.
Jun 3, 2019
45ad108
add message_type in pbft messages; refactor code.
Jun 4, 2019
dde4c39
Merge branch 'feature/dpos-pbft-bos-upgrade-slim' into feature/dpos-p…
VincentOCL Jun 6, 2019
7c9404e
remove pbft controller config; fix net layer bugs.
Jun 6, 2019
74bde5c
bug fix: view change certs generation;
Jun 6, 2019
2ffcf15
retry sending all pending checkpoints;
Jun 7, 2019
299f82f
check all prepares (commits) fall on the same fork during generating …
Jun 8, 2019
01775ea
add pre_prepares in prepared_cert, requesting missing blocks upon vie…
Jun 11, 2019
a3d05a0
bug fix: reset view change state cache properly.
Jun 12, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
increase new view message deadline; add prepared & my_prepare in pbft…
…_api_plugin
oldcold authored and VincentOCL committed May 30, 2019
commit 56110e076aa864a9b02b16f674e96152248d1969
11 changes: 2 additions & 9 deletions libraries/chain/pbft_database.cpp
Original file line number Diff line number Diff line change
@@ -122,8 +122,6 @@ namespace eosio {
psp->prepares.emplace_back(p);
std::sort(psp->prepares.begin(), psp->prepares.end(), less<>());
});
} else {
dlog( "prepare already exists: ${p}", ("p", p));
}
}
curr_itr = by_block_id_index.find(current->id);
@@ -148,8 +146,7 @@ namespace eosio {
for (auto const &e: prepare_count) {
if (e.second >= as.size() * 2 / 3 + 1) {
by_block_id_index.modify(curr_itr,
[&](const pbft_state_ptr &psp) { psp->should_prepared = true; });
dlog( "block id ${id} is now prepared at view ${v}", ("id", current->id)("v", e.first));
[&](const pbft_state_ptr &psp) { psp->should_prepared = true; });
}
}
}
@@ -279,8 +276,6 @@ namespace eosio {
psp->commits.emplace_back(c);
std::sort(psp->commits.begin(), psp->commits.end(), less<>());
});
} else {
dlog( "commit already exists: ${c}", ("c", c));
}
}

@@ -309,8 +304,7 @@ namespace eosio {
for (auto const &e: commit_count) {
if (e.second >= current->active_schedule.producers.size() * 2 / 3 + 1) {
by_block_id_index.modify(curr_itr,
[&](const pbft_state_ptr &psp) { psp->should_committed = true; });
dlog( "block id ${id} is now committed at view ${v}", ("id", current->id)("v", e.first));
[&](const pbft_state_ptr &psp) { psp->should_committed = true; });
}
}
}
@@ -417,7 +411,6 @@ namespace eosio {
pbft_state_ptr psp = *itr;

ctrl.pbft_commit_local(psp->block_id);
dlog( "block id ${id} is committed local", ("id", psp->block_id));
}

bool pbft_database::pending_pbft_lib() {
36 changes: 18 additions & 18 deletions plugins/net_plugin/net_plugin.cpp
Original file line number Diff line number Diff line change
@@ -247,9 +247,9 @@ namespace eosio {
template<typename M>
bool is_pbft_msg_valid(M const & msg);

void bcast_pbft_msg(const net_message &msg);
void bcast_pbft_msg(const net_message &msg, int ttl);

void forward_pbft_msg(connection_ptr c, const net_message &msg);
void forward_pbft_msg(connection_ptr c, const net_message &msg, int ttl);

void pbft_outgoing_prepare(const pbft_prepare &prepare);
void pbft_outgoing_commit(const pbft_commit &commit);
@@ -2912,15 +2912,15 @@ namespace eosio {
template<typename M>
bool net_plugin_impl::is_pbft_msg_valid(M const & msg) {
// Do some basic validations of an incoming pbft msg, bad msgs should be quickly discarded without affecting state.
return chain_id == msg.chain_id
return chain_id == msg.chain_id
&& !is_pbft_msg_outdated(msg)
&& !sync_master->is_syncing();
}

void net_plugin_impl::bcast_pbft_msg(const net_message &msg) {
void net_plugin_impl::bcast_pbft_msg(const net_message &msg, int ttl) {
if (sync_master->is_syncing()) return;

auto deadline = time_point_sec(time_point::now()) + pbft_message_TTL;
auto deadline = time_point_sec(time_point::now()) + ttl;

for (auto &conn: connections) {
if (conn->pbft_ready()) {
@@ -2929,8 +2929,8 @@ namespace eosio {
}
}

void net_plugin_impl::forward_pbft_msg(connection_ptr c, const net_message &msg) {
auto deadline = time_point_sec(time_point::now()) + pbft_message_TTL;
void net_plugin_impl::forward_pbft_msg(connection_ptr c, const net_message &msg, int ttl) {
auto deadline = time_point_sec(time_point::now()) + ttl;

for (auto &conn: connections) {
if (conn != c && conn->pbft_ready()) {
@@ -2946,7 +2946,7 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_prepare(msg)) return;

bcast_pbft_msg(msg);
bcast_pbft_msg(msg, pbft_message_TTL);
fc_ilog( logger, "sent prepare at height: ${n}, view: ${v}, from ${k}, ", ("n", msg.block_num)("v", msg.view)("k", msg.public_key));
}

@@ -2957,7 +2957,7 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_commit(msg)) return;

bcast_pbft_msg(msg);
bcast_pbft_msg(msg, pbft_message_TTL);
fc_ilog( logger, "sent commit at height: ${n}, view: ${v}, from ${k}, ", ("n", msg.block_num)("v", msg.view)("k", msg.public_key));
}

@@ -2968,7 +2968,7 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_view_change(msg)) return;

bcast_pbft_msg(msg);
bcast_pbft_msg(msg, pbft_message_TTL);
fc_ilog( logger, "sent view change {cv: ${cv}, tv: ${tv}} from ${v}", ("cv", msg.current_view)("tv", msg.target_view)("v", msg.public_key));
}

@@ -2979,7 +2979,7 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_new_view(msg)) return;

bcast_pbft_msg(msg);
bcast_pbft_msg(msg, INT_MAX);
fc_ilog( logger, "sent new view at view: ${v}, from ${k}, ", ("v", msg.view)("k", msg.public_key));
}

@@ -2990,7 +2990,7 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_checkpoint(msg)) return;

bcast_pbft_msg(msg);
bcast_pbft_msg(msg, pbft_message_TTL);
fc_ilog( logger, "sent checkpoint at height: ${n}, from ${k}, ", ("n", msg.block_num)("k", msg.public_key));
}

@@ -3026,7 +3026,7 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_prepare(msg)) return;

forward_pbft_msg(c, msg);
forward_pbft_msg(c, msg, pbft_message_TTL);
fc_ilog( logger, "received prepare at height: ${n}, view: ${v}, from ${k}, ", ("n", msg.block_num)("v", msg.view)("k", msg.public_key));

pbft_incoming_prepare_channel.publish(msg);
@@ -3043,7 +3043,7 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_commit(msg)) return;

forward_pbft_msg(c, msg);
forward_pbft_msg(c, msg, pbft_message_TTL);
fc_ilog( logger, "received commit at height: ${n}, view: ${v}, from ${k}, ", ("n", msg.block_num)("v", msg.view)("k", msg.public_key));

pbft_incoming_commit_channel.publish(msg);
@@ -3059,23 +3059,23 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_view_change(msg)) return;

forward_pbft_msg(c, msg);
forward_pbft_msg(c, msg, pbft_message_TTL);
fc_ilog( logger, "received view change {cv: ${cv}, tv: ${tv}} from ${v}", ("cv", msg.current_view)("tv", msg.target_view)("v", msg.public_key));

pbft_incoming_view_change_channel.publish(msg);
}

void net_plugin_impl::handle_message( connection_ptr c, const pbft_new_view &msg) {

if (!is_pbft_msg_valid(msg)) return;
if (chain_id != msg.chain_id) return;

auto added = maybe_add_pbft_cache(msg.uuid);
if (!added) return;

pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!(msg.public_key == pcc.pbft_db.get_new_view_primary_key(msg.view) && msg.is_signature_valid())) return;

forward_pbft_msg(c, msg);
forward_pbft_msg(c, msg, INT_MAX);
fc_ilog( logger, "received new view: ${n}, from ${v}", ("n", msg)("v", msg.public_key));

pbft_incoming_new_view_channel.publish(msg);
@@ -3091,7 +3091,7 @@ namespace eosio {
pbft_controller &pcc = my_impl->chain_plug->pbft_ctrl();
if (!pcc.pbft_db.is_valid_checkpoint(msg)) return;

forward_pbft_msg(c, msg);
forward_pbft_msg(c, msg, pbft_message_TTL);
fc_ilog( logger, "received checkpoint at ${n}, from ${v}", ("n", msg.block_num)("v", msg.public_key));

pbft_incoming_checkpoint_channel.publish(msg);
2 changes: 2 additions & 0 deletions plugins/pbft_api_plugin/pbft_api_plugin.cpp
Original file line number Diff line number Diff line change
@@ -57,6 +57,8 @@ void pbft_api_plugin::plugin_startup() {
CALL(pbft, pbft, get_pbft_checkpoints_record, INVOKE_R_P(pbft, get_pbft_checkpoints_record, block_num_type), 200),
CALL(pbft, pbft, get_view_change_record, INVOKE_R_P(pbft, get_view_change_record, pbft_view_type), 200),
CALL(pbft, pbft, get_pbft_status, INVOKE_R(pbft, get_pbft_status), 200),
CALL(pbft, pbft, get_pbft_prepared_id, INVOKE_R(pbft, get_pbft_prepared_id), 200),
CALL(pbft, pbft, get_pbft_my_prepare_id, INVOKE_R(pbft, get_pbft_my_prepare_id), 200),
CALL(pbft, pbft, set_pbft_current_view, INVOKE_W_P(pbft, set_pbft_current_view, pbft_view_type), 201),
});
}
Original file line number Diff line number Diff line change
@@ -31,7 +31,7 @@ class pbft_plugin : public appbase::plugin<pbft_plugin> {
vector<block_num_type> get_watermarks()const;
flat_map<public_key_type, uint32_t> get_fork_schedules()const;
const char* get_pbft_status()const;
block_id_type get_pbft_prepared_block_id()const;
block_id_type get_pbft_prepared_id()const;
block_id_type get_pbft_my_prepare_id()const;

void set_pbft_current_view(pbft_view_type view);
2 changes: 1 addition & 1 deletion plugins/pbft_plugin/pbft_plugin.cpp
Original file line number Diff line number Diff line change
@@ -95,7 +95,7 @@ namespace eosio {
return pbft_ctrl.state_machine.get_current()->get_name();
}

block_id_type pbft_plugin::get_pbft_prepared_block_id() const {
block_id_type pbft_plugin::get_pbft_prepared_id() const {
auto& ctrl = app().get_plugin<chain_plugin>().chain();
return ctrl.get_pbft_prepared();
}