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

最近做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重新使用源码编译。

你可能感兴趣的:(ICE 超过最大连接数崩溃的问题)