[Haskell-cafe] how to implement daemon start and stop directives?
Belka
lambda-belka at yandex.ru
Sat Jan 24 20:57:15 EST 2009
>If you want a normal daemon, you want to look at System.Posix.Process
>to create a proper daemon (forkProcess, createSession; don't forget to
>close stdOutput (and, errr, Haskell library types: stdin and stderr
>are where? not System.Posix.IO with stdOutput) and reopen them on /
>dev/null, at least if they're ttys as determined by
>System.Posix.Terminal.queryTerminal). You also want to write out a
>pidfile (/var/run/programname.pid) for use by startproc / killproc,
>and you want to install a handler for sigTERM
>(System.Posix.Signals.installHandler) which sets the exit flag (TVar,
>MVar, IORef, Chan, take your pick). Ideally you also catch sigHUP and
>reload your state.
Thanks for the guide, Brandon !!
By the way, I found a piece of code with function (daemonize :: IO () -> IO
()) (http://sneakymustard.com/2008/12/11/haskell-daemons), which is close to
the subject.
I guess now I'm ready to implement my own daemon!
Thanks for your help, everyboby!! =)
--
View this message in context: http://www.nabble.com/how-to-implement-daemon-start-and-stop-directives--tp21598690p21647723.html
Sent from the Haskell - Haskell-Cafe mailing list archive at Nabble.com.
More information about the Haskell-Cafe
mailing list