NAME

POEx::WorkerPool::Role::WorkerPool - A role that provides common semantics for WorkerPools

VERSION

version 0.092460

ATTRIBUTES

job_class is: ro, isa: ClassName, required: 1

In order for the serializer on the other side of the process boundary to rebless jobs on the other side, it needs to make sure that class is loaded.

This attribute is used to indicate which class needs to be loaded.

queue_type is: ro, isa: enum([qw|round_robin fill_up|]), default: round_robin

This attribute specifies the queue type for the WorkerPool and changes how workers are pulled from the pool

max_workers is: ro, isa: Int, default: 5

This determines how many workers the Pool will spin up

current_worker_index is: rw, isa: ScalarRef

This stores the current index into workers. Dereference to manipulate the Int value.

workers is: ro, isa: ArrayRef[Worker]

This attribute holds all of the workers in the pool

METHODS

incr_worker_index returns Int

This is a convenience method for incrementing the index and wrapping around when it exceeds max_workers

get_next_worker returns (DoesWorker)

This returns the next worker in the pool as determined by the queue_type attribute.

For round_robin, it will return the next immediate worker if isn't active. fill_up will continue to return the same worker until its job queue is full.

If it is unable to return a suitable worker (all of the workers are currently active or all of their job queues are full, etc), it will throw a POEx::WorkerPool::Error::NoAvailableWorkers exception.

queue_job(DoesJob $job) returns (SessionAlias)

This method grabs the next available worker, enqueues the job, starts the worker's queue processing and returns the worker's pubsub alias that can be used to subscribe to various events that the worker fires.

halt is Event

This method will halt any active workers in the worker pool and force them to release resouces and clean up.

AUTHOR

Nicholas Perez <nperez@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2009 by Infinity Interactive.

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