Re: enif_send from a thread after NIF returns
Rapsey <rapsey <at> gmail.com>
2010-10-26 13:37:46 GMT
On Tue, Oct 26, 2010 at 3:29 PM, Joel Reymont <joelr1 <at> gmail.com> wrote:
> On Oct 26, 2010, at 2:22 PM, Rapsey wrote:
> > Does unload/reload/upgrade get called? I have printf in those so that I
> know what's going on.
> I'm sure it does, although I'm not using it. Thanks for the tip, though. I
> now understand that the unload "callback" corresponds to driver unload and
> that's where threads must be joined.
> I'm trying to implement asynchronous fsync, though, so I spawn a thread for
> each fsync. Joining all those threads on unload in a long-running server
> would require me to keep a -
huge- stack of thread ids, one per fsync call. I
> realize that it's probably a bad idea to launch a thread for each fsync but
> I'm just experimenting.
> How do you work around this in your network server? Do you use a thread
I don't use fsync anywhere :)
I have only one accept thread and sockets are non-blocking.