updating fc to support more threads

This commit is contained in:
Daniel Larimer 2016-07-18 21:20:40 -04:00
parent c109dbecf3
commit e5ffc620ba
2 changed files with 39 additions and 28 deletions

View file

@ -93,14 +93,15 @@ namespace fc {
struct default_io_service_scope
{
boost::asio::io_service* io;
boost::thread* asio_thread;
std::vector<boost::thread*> asio_threads;
boost::asio::io_service::work* the_work;
default_io_service_scope()
{
io = new boost::asio::io_service();
the_work = new boost::asio::io_service::work(*io);
asio_thread = new boost::thread( [=]()
for( int i = 0; i < 8; ++i ) {
asio_threads.push_back( new boost::thread( [=]()
{
fc::thread::current().set_name("asio");
while (!io->stopped())
@ -122,17 +123,22 @@ namespace fc {
elog("Caught unhandled exception in asio service loop");
}
}
});
}) );
}
}
void cleanup()
{
delete the_work;
io->stop();
for( auto asio_thread : asio_threads ) {
asio_thread->join();
}
delete io;
for( auto asio_thread : asio_threads ) {
delete asio_thread;
}
}
~default_io_service_scope()
{}
@ -140,9 +146,9 @@ namespace fc {
/// If cleanup is true, do not use the return value; it is a null reference
boost::asio::io_service& default_io_service(bool cleanup) {
static default_io_service_scope fc_asio_service[4];
static default_io_service_scope fc_asio_service[1];
if (cleanup) {
for( int i = 0; i < 4; ++i )
for( int i = 0; i < 1; ++i )
fc_asio_service[i].cleanup();
}
return *fc_asio_service[0].io;

View file

@ -204,6 +204,11 @@ namespace fc { namespace http {
}).wait();
});
_server.set_socket_init_handler( [&](websocketpp::connection_hdl hdl, boost::asio::ip::tcp::socket& s ) {
boost::asio::ip::tcp::no_delay option(true);
s.lowest_layer().set_option(option);
} );
_server.set_http_handler( [&]( connection_hdl hdl ){
_server_thread.async( [&](){
auto current_con = std::make_shared<websocket_connection_impl<websocket_server_type::connection_ptr>>( _server.get_con_from_hdl(hdl) );