buildFdSets: file descriptor out of range
Simon Marlow
marlowsd at gmail.com
Wed Jul 15 08:55:25 EDT 2009
On 15/07/2009 05:16, Brandon S. Allbery KF8NH wrote:
> On Jul 14, 2009, at 21:48 , Kazu Yamamoto (山本和彦) wrote:
>> running well at the beginning. But after several hours, it receives an
>> error, "buildFdSets: file descriptor out of range".
>
> I believe the runtime uses select(), which has a hard limit (enforced by
> the kernel) that the maximum file descriptor id be 1023. (select() uses
> bitmasks and there is a limit on the size of a bitmask; see FD_SETSIZE.)
Strictly speaking it's the IO library, not the runtime, that calls
select() when you're using -threaded. But otherwise that's all correct.
>> - pushes the limit of file descriptors to 65536 with setResourceLimit.
>
>
> Reduce this to 1024, otherwise the runtime will eventually find itself
> dealing with file descriptors beyond the select() limit mentioned above.
> Someone with more knowledge of the Haskell runtime will have to advise
> as to possible ways around it if you really need more than 1024 file
> descriptors.
There's no easy workaround. We could have the IO library switch to
using blocking read() calls for the out-of-range FDs to avoid the error
from the IO manager, but that is likely to lead to a different problem:
too many OS threads.
The right fix is to move to using epoll() instead. I understand it is
being worked on, but I don't know the current status (Johan?).
Cheers,
Simon
More information about the Glasgow-haskell-users
mailing list