oracular (3) Server::Starter.3pm.gz

Provided by: libserver-starter-perl_0.35-2_all bug

NAME

       Server::Starter - a superdaemon for hot-deploying server programs

SYNOPSIS

         # from command line
         % start_server --port=80 my_httpd

         # in my_httpd
         use Server::Starter qw(server_ports);

         my $listen_sock = IO::Socket::INET->new(
             Proto => 'tcp',
         );
         $listen_sock->fdopen((values %{server_ports()})[0], 'w')
             or die "failed to bind to listening socket:$!";

         while (1) {
             if (my $conn = $listen_sock->accept) {
                 ....
             }
         }

DESCRIPTION

       It is often a pain to write a server program that supports graceful restarts, with no resource leaks.
       Server::Starter solves the problem by splitting the task into two.  One is start_server, a script
       provided as a part of the module, which works as a superdaemon that binds to zero or more TCP ports or
       unix sockets, and repeatedly spawns the server program that actually handles the necessary tasks (for
       example, responding to incoming connections).  The spawned server programs under Server::Starter call
       accept(2) and handle the requests.

       To gracefully restart the server program, send SIGHUP to the superdaemon.  The superdaemon spawns a new
       server program, and if (and only if) it starts up successfully, sends SIGTERM to the old server program.

       By using Server::Starter it is much easier to write a hot-deployable server.  Following are the only
       requirements a server program to be run under Server::Starter should conform to:

       •   receive file descriptors to listen to through an environment variable

       •   perform a graceful shutdown when receiving SIGTERM

       A Net::Server personality that can be run under Server::Starter exists under the name
       Net::Server::SS::PreFork.

METHODS

       server_ports
           Returns zero or more file descriptors on which the server program should call accept(2) in a hashref.
           Each element of the hashref is: (host:port|port|path_of_unix_socket) => file_descriptor.

       start_server
           Starts the superdaemon.  Used by the "start_server" script.

AUTHOR

       Kazuho Oku

SEE ALSO

       Net::Server::SS::PreFork

LICENSE

       This library is free software; you can redistribute it and/or modify it under the same terms as Perl
       itself.