NAME
Daemon - Start an Application as a Daemon
SYNOPSIS
use HTTP::Server::Daemon qw(check_pid become_daemon);
my $child_num = 0; my $quit = 1; become_daemon(__FILE__); my $pidfile = check_pid(__FILE__); $SIG{CHLD} = sub { while(waitpid(-1,WNOHANG)>0){ $child_num--; } }; $SIG{TERM} = $SIG{INT} = sub { unlink $pidfile; $quit--; }; while ($quit){ #do your things; }
DESCRIPTION
Help running an application as a daemon.
METHODS
server_perfork_dynamic($child_func, $port, $min_children, $max_children)
Prefork a net server listen on the given port.
perfork_child_pipe($server_sock, $pipe_write, $child_func_ref, $dead_after_requests_num)
Fork a child listen the port. (Internal methods).
become_netserver($port)
Let the proccess listen on given port using protocol 'TCP'.
send_msg($sock)
Send msg to sock using protocol 'PON'(Perl Object Notation).
get_msg($sock)
Receive msg from sock using protocol 'PON'(Perl Object Notation).
peer_info($sock)
Return ($peer_port, $peer_ip).
net_filter($sock)
Enable white list net filter. Allow only ip list in 'conf/allowip.conf' access, return 0. Others return 'deny'.
check_pid($invoker_name)
Deal with pid file things. Can be used independently.
become_daemon($invoker_name)
Let the proccess become a daemon. Can be used independently.
AUTHOR
Written by ChenGang, yikuyiku.com@gmail.com
COPYRIGHT
Copyright (c) 2011 ChenGang. This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.