# NAME

POE::Component::WheelRun::Pool - POE::Wheel::Run worker pool

# VERSION

version 0.003

# SYNOPSIS

Provides a pool wrapper around POE::Wheel::Run to allow for large worker pools that are automatically replenished.
POE::Component::WheelRun::Pool uses STDIN, STDOUT, and STDERR for communication between the parent session and the worker children.

    my $worker_pool_id = POE::Component::WheelRun::Pool->spawn(
        Alias            => 'pool',             # Default
        Program          => \&run_analysis,     # Required
        PoolSize         => 4,                  # Default
        MaxTasksPerChild => 1000,               # Default '0' = unlimited
        MaxTimePerChild  => 3600,               # Default '0' = unlimited
        Splay            => 0.1,                # Default
        # Any Options from POE::Wheel::Run
        User     => 'bob',
        Group    => 'nobody',
        Priority => 5,
    );

    my $main = POE::Session->create(inline_states => {
        new_event => sub { $poe_kernel->post( pool => dispatch => @_[ARG0] ) },
    });

This will create a pool of 4 workers with the run\_analyze function as the entry point to the pool::dispatch event.  Child processes
should monitor STDIN for availability as the first thing attempted by the parent is an EOF on the STDIN of the child to let it know it should
go away.  Failing this, a kill() is called which is SIGINT by default.

# FUNCTIONS

## spawn()

Creates the worker pool and sets it ready for incoming tasks.
POE::Component::WheelRun::Pool will pass sensible options from POE::Wheel::Run
to the child process.  See:

    perldoc POE::Wheel::Run

For more information on options not covered here.

- **Alias**

    Default is 'pool', use a unique name to make dispatching events to worker pools easier to understand.

- **Program**

    Required! Can be either a CODE reference or a path to an executable to launch.  The script needs to be able to accept data on STDIN and communicate
    back to the parent session using STDOUT or STDERR.  This means the program can be in any language.

- **PoolSize**

    Default is 4.  This is the number of children to spawn and maintain.

- **MaxTasksPerChild**

    Default 0, anything <= 0 means unlimited.  This is the maximum number of tasks that can be handed to any one worker before it needs to respawn.

- **MaxTimePerChild**

    Default 0, anything <= 0 means unlimited.  This is the maximum number of seconds any worker can live before being killed and respawned.  This check occurs only inside of the
    dispatch event trigger and only for that "next" worker.   This means it is possible for processes to live longer that **MaxTimePerChild**, but their next invocation will
    be their last.

- **Splay**

    Default is 0.1 and is unimportant without **MaxTimePerChild** or **MaxTasksPerChild**.  This applies a random splay to the time or tasks checker.  Best thought of as a percentage
    range for max tasks or time.  e. g.

        ChildMaxUpperBound = MaxTasksPerChild + (Splay * MaxTasksPerChild)
        ChildMaxLowerBound = MaxTasksPerChild - (Splay * MaxTasksPerChild)

    When a child is spawned the max tasks/time is calculated inside that range using two calls to rand(), one for the **Splay** and the second for positive/negative.

    The idea behind this is to offset process creation in the parent process as that can be expensive.  If you would like to disable this feature, set the **Splay** to **0**.

- **StatsInterval**

    Default is 60.  Seconds to run the stats handler.

- **StatsHandler**

    Default 'undef'.  If passed a CODE reference, that refernce is run every **StatInterval** seconds. The handler is passed a hash reference with the events tracked and the values
    representing the number of times each event ocurred.

- **StdoutHandler**

    Default 'undef'.  CODE reference with what to do when there's content on STDOUT of the worker process.  Based on **StdioFilter** or **StdoutFilter** this reference may be passed
    the content as a stream, line of text, or even a Perl object.

- **StderrHandler**

    Default 'undef'.  CODE reference with what to do when there's content on STDERR of the worker process.  Based on **StderrFilter** this reference may be passed
    the content as a stream, line of text, or even a Perl object.

# AUTHOR

Brad Lhotsky <brad@divisionbyzero.net>

# COPYRIGHT AND LICENSE

This software is Copyright (c) 2016 by Brad Lhotsky.

This is free software, licensed under:

    The (three-clause) BSD License

# SUPPORT

## Websites

The following websites have more information about this module, and may be of help to you. As always,
in addition to those websites please use your favorite search engine to discover more resources.

- MetaCPAN

    A modern, open-source CPAN search engine, useful to view POD in HTML format.

    [https://metacpan.org/release/POE-Component-WheelRun-Pool](https://metacpan.org/release/POE-Component-WheelRun-Pool)

- RT: CPAN's Bug Tracker

    The RT ( Request Tracker ) website is the default bug/issue tracking system for CPAN.

    [https://rt.cpan.org/Public/Dist/Display.html?Name=POE-Component-WheelRun-Pool](https://rt.cpan.org/Public/Dist/Display.html?Name=POE-Component-WheelRun-Pool)

## Source Code

This module's source code is available by visiting:
[https://github.com/reyjrar/POE-Component-WheelRun-Pool](https://github.com/reyjrar/POE-Component-WheelRun-Pool)