views:

219

answers:

4

Is there a simple way to do async in Perl? I have the following logic for an Apache app:

get request
process request
write to log
return

what I want to do is to have the "write to log" part to be async, so that I can do the "return" part asap.

+2  A: 

Unfortunately, this typically entails the POE framework, but there is also a growing alternative (which I would want to try first) called AnyEvent.

See this question for learning materials for more information about learning POE. POE is a framework and it tends to eat your whole application. It also doesn't look like Perl, and sticks out. I believe it is a big learning curve for your typical application.

AnyEvent is simple continuation based asyncronous tasking, you should be able to figure it out fairly well with just the CPAN docs.

For your specific question you would use AnyEvent's AIO or POE's Read Write wheel

Evan Carroll
thanks, was wondering if I missed anything obvious, but couldn't find any. As this is part of an Apache app, neither solution seems attractive. thanks tho
Timmy
you could use a simple non-blocking socket to send the data to a POE log writing daemon. And, as daotoad said, so long as you're limiting one writing process per file then you can probably just use a non-blocking handle
Evan Carroll
+2  A: 

you can use threads in perl. create a thread that handle the logs. this thread would have a buffer that the main thread can add messages to it

jojo
+3  A: 

Consider looking at Coro.

From its CPAN documentation:

Unlike the so-called "Perl threads" (which are not actually real threads but only the windows process emulation (see section of same name for more details) ported to unix, and as such act as processes), Coro provides a full shared address space, which makes communication between threads very easy. And Coro's threads are fast, too: disabling the Windows process emulation code in your perl and using Coro can easily result in a two to four times speed increase for your programs. A parallel matrix multiplication benchmark runs over 300 times faster on a single core than perl's pseudo-threads on a quad core using all four cores.

This includes Coro::AIO, a "truly asynchronous file and directory I/O", which might be what you're looking for.

Robert P
+4  A: 

Do you really need to write the logs before returning?

Assuming this is Apache mod_perl, it supports cleanup handlers that get triggered for the child process after the response is returned.

It seems what you REALLY want is for the logging not to stop the return, cleanup handlers would seem to do that without the need for async at all.

Adam Kennedy
You're probably right, but it's a bad design right now, and it needs it to take advantage of the fact that it has some of the data right now, not just a simple logging.
Timmy