From e796f37821919be9e20a4cc32109bee29e5eeb8e Mon Sep 17 00:00:00 2001 From: Kevin Heifner Date: Mon, 16 Sep 2019 11:17:15 -0400 Subject: [PATCH 1/2] Fix problem with keepalive timer sometimes causing a crash on exit because plugin_shutdown not called. Moved the creation of keepalive timer to after acceptor bind which can easily fail if port already in use. Changed fc_elog to elog for port already in use so that it is always logged regardless of net_plugin_impl logger setting. Also move the setup of logger to start of plugin_startup since logging is used within the method. --- plugins/net_plugin/net_plugin.cpp | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/plugins/net_plugin/net_plugin.cpp b/plugins/net_plugin/net_plugin.cpp index b35b38a0da8..b563a36294a 100644 --- a/plugins/net_plugin/net_plugin.cpp +++ b/plugins/net_plugin/net_plugin.cpp @@ -3022,6 +3022,8 @@ namespace eosio { } void net_plugin::plugin_startup() { + handle_sighup(); + try { my->producer_plug = app().find_plugin(); // currently thread_pool only used for server_ioc @@ -3056,17 +3058,13 @@ namespace eosio { } } - my->keepalive_timer.reset( new boost::asio::steady_timer( my->thread_pool->get_executor() ) ); - my->ticker(); - if( my->acceptor ) { my->acceptor->open(my->listen_endpoint.protocol()); my->acceptor->set_option(tcp::acceptor::reuse_address(true)); try { my->acceptor->bind(my->listen_endpoint); } catch (const std::exception& e) { - fc_elog( logger, "net_plugin::plugin_startup failed to bind to port ${port}", - ("port", my->listen_endpoint.port())); + elog( "net_plugin::plugin_startup failed to bind to port ${port}", ("port", my->listen_endpoint.port())); throw e; } my->acceptor->listen(); @@ -3078,6 +3076,9 @@ namespace eosio { cc.accepted_block.connect( boost::bind(&net_plugin_impl::accepted_block, my.get(), _1)); } + my->keepalive_timer.reset( new boost::asio::steady_timer( my->thread_pool->get_executor() ) ); + my->ticker(); + my->incoming_transaction_ack_subscription = app().get_channel().subscribe(boost::bind(&net_plugin_impl::transaction_ack, my.get(), _1)); if( cc.get_read_mode() == chain::db_read_mode::READ_ONLY ) { @@ -3090,7 +3091,12 @@ namespace eosio { for( auto seed_node : my->supplied_peers ) { connect( seed_node ); } - handle_sighup(); + + } catch (...) { + // always want plugin_shutdown even on exception + plugin_shutdown(); + throw; + } } void net_plugin::handle_sighup() { From e122844e64d6f2a3e275095ffbeeb4b7b1ac489d Mon Sep 17 00:00:00 2001 From: Kevin Heifner Date: Mon, 16 Sep 2019 11:17:53 -0400 Subject: [PATCH 2/2] Make sure plugin_shutdown is called in case of exception in plugin_startup to ensure proper shutdown on exception --- plugins/producer_plugin/producer_plugin.cpp | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/plugins/producer_plugin/producer_plugin.cpp b/plugins/producer_plugin/producer_plugin.cpp index 4291dffaeb6..a9cfab68cb4 100644 --- a/plugins/producer_plugin/producer_plugin.cpp +++ b/plugins/producer_plugin/producer_plugin.cpp @@ -804,6 +804,7 @@ void producer_plugin::plugin_startup() { try { handle_sighup(); // Sets loggers + try { ilog("producer plugin: plugin_startup() begin"); chain::controller& chain = my->chain_plug->chain(); @@ -840,6 +841,11 @@ void producer_plugin::plugin_startup() my->schedule_production_loop(); ilog("producer plugin: plugin_startup() end"); + } catch( ... ) { + // always call plugin_shutdown, even on exception + plugin_shutdown(); + throw; + } } FC_CAPTURE_AND_RETHROW() } void producer_plugin::plugin_shutdown() {