最近做ice服务器的压力测试,发现ICE在文件描述符用尽的情况下会崩溃,查看源码发现时connectionFactory中的一段代码:
//
// Now accept a new connection.
//
TransceiverPtr transceiver;
try
{
transceiver = _acceptor->accept();
}
catch(const SocketException& ex)
{
if(noMoreFds(ex.error))
{
{
Error out(_instance->initializationData().logger);
out << "fatal error: can't accept more connections:\n" << ex << '\n' << _acceptor->toString();
}
abort();
}
// Ignore socket exceptions.
return;
}
bool
IceInternal::noMoreFds(int error)
{
#ifdef _WIN32
return error == WSAEMFILE;
#else
return error == EMFILE || error == ENFILE;
#endif
}
EMFILE The per-process limit of open file descriptors has been reached.
ENFILE The system limit on the total number of open files has been reached.
返回EMFILE或者ENFILE通常是由于linux进程默认的单进程可以打开的最大描述符过小导致的。通过修改ulimit -n 可以修改当前用户的最大描述符数。 也可以通过修改/etc/security/limits.conf/ 来修改所有用户的最大描述符数。
ICE3.4.2中当检测单noMoreFd时服务器崩溃,因为会调用abort函数。其实这是没必要的,返回客户端连接异常就足够了。所以需要的话可以注释掉abort重新使用源码编译。
版权声明:本文为tbyzs原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。