X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fsocket_server.cpp;fp=src%2Fsocket_server.cpp;h=1fc99d83e0e1e612c8a5e6fcc1a8d1f48db4736a;hp=0eff67623fdb5d9463f40ebd8f2af96db4175b28;hb=c7857475c8b0f02cac3ce29a617a4d542fa59f37;hpb=1450c0649dc1f1414fd8e051b8d452f4adcb4b24 diff --git a/src/socket_server.cpp b/src/socket_server.cpp index 0eff676..1fc99d8 100644 --- a/src/socket_server.cpp +++ b/src/socket_server.cpp @@ -152,14 +152,17 @@ void socket_server::new_connection() int newsock = accept (sock,(struct sockaddr *) &clientname,&size); if (newsock < 0) { - if (errno == EAGAIN) + // return on non-fatal errors (list taken from man-page) + if (errno == EAGAIN || errno == EWOULDBLOCK || errno == ECONNABORTED || errno == EINTR || + errno == EMFILE || errno == ENFILE || errno == ENOBUFS || errno == ENOMEM || + errno == EPROTO || errno == EPERM || errno == ETIMEDOUT) { - LOGSTREAM(error,"accept error (EAGAIN): no connection waiting"); + LOGSTREAM(error,"non-fatal accept error: " << strerror(errno)); return; } - /* default: break */ - EXCEPTIONSTREAM(error,t2n_server_error,"error accepting connection: " << strerror(errno)); + /* fatal error: will usually kill or restart the server */ + EXCEPTIONSTREAM(error,t2n_server_error,"fatal error accepting connection: " << strerror(errno)); } FD_SET (newsock, &connection_set); @@ -242,8 +245,18 @@ bool socket_server::fill_connection_buffers() std::map::iterator ie=connections.end(); for(std::map::iterator i=connections.begin(); i != ie; i++) if (!i->second->server_connection::is_closed()) - if (i->second->fill_buffer(0)) - data_found=true; + { + // shutdown all connections which throw exceptions to protect the server + try + { + if (i->second->fill_buffer(0)) + data_found=true; + } + catch (t2n_transfer_error &e) + { i->second->close(); } + catch(...) + { throw; } + } return data_found; }