ICE 超过最大连接数崩溃的问题

  • Post author:
  • Post category:其他


最近做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 版权协议,转载请附上原文出处链接和本声明。