# NAME

Twiggy::Prefork - Preforking AnyEvent HTTP server for PSGI

# SYNOPSIS

    $ plackup -s Twiggy::Prefork -a app.psgi
    

# DESCRIPTION

Twiggy::Prefork is Preforking AnyEvent HTTP server for PSGI based on Twiggy. This server supports,

- Min/Max Request Per Child

    supports Min/Max Request Per Child feature. 

- Superdaemon aware

    Supports [Server::Starter](http://search.cpan.org/perldoc?Server::Starter) for hot deploy and
    graceful restarts.

    To use it, instead of the usual:

        plackup --server Twiggy::Prefork --port 8111 app.psgi

    install [Server::Starter](http://search.cpan.org/perldoc?Server::Starter) and use:

        start_server --port 8111 plackup --server Twiggy::Prefork app.psgi

# OPTIONS

- max\_workers

    number of worker processes (default: 10)

- max\_reqs\_per\_child

    max. number of requests to be handled before a worker process exits. If passed 0, child process is not existed by number of requests (default: 100).

- min\_reqs\_per\_child

    if set, randomizes the number of requests handled by a single worker process between the value and that supplied by --max-reqs-per-child (default: none)

# PSGI extensions

- psgix.exit\_guard

    AnyEvent::CondVar object. You can make graceful stop mechanism with this variable.

        use Coro;
        use AnyEvent;

        my $channel = Coro::Channel->new(100);

        async {
          while(1){
            my $q = $channel->get;
            # works..
            $q[0]->end;
          }
        };

        #psgi app
        sub {
          my $env = shift;
          my $cv = AE::cv;
          async {
            $env->{psgix.exit_guard}->begin; 
            $channel->put([$env->{psgix.exit_guard}]);
            $cv->send;
          };
          return sub {
            my $start_response = shift;
            $cv->cb(sub {
              $start_response->([200,['Content-Type'=>'text/plain'],['OK']]);
            });
          }
        }

    Block Twiggy::Prefork worker process exiting until your jobs done.

# AUTHOR

Masahiro Nagano <kazeburo {at} gmail.com>

Shigeki Morimoto

# SEE ALSO

[Twiggy](http://search.cpan.org/perldoc?Twiggy), [Parallel::Prefork](http://search.cpan.org/perldoc?Parallel::Prefork)

# LICENSE

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