Class: Concurrent::Actor::Utils::Pool
| Relationships & Source Files | |
| Super Chains via Extension / Inclusion / Inheritance | |
| Class Chain: | |
| Instance Chain: | |
| Inherits: | Concurrent::Actor::RestartingContext 
 | 
| Defined in: | lib/concurrent-ruby-edge/concurrent/actor/utils/pool.rb | 
Overview
Allows to create a pool of workers and distribute work between them
Constant Summary
Concern::Logging - Included
  
Class Method Summary
- .new(size, &worker_initializer) ⇒ Pool constructor
Actor::AbstractContext - Inherited
| .spawn | Behaves as Concurrent::Actor.spawn but  | 
| .spawn! | behaves as Concurrent::Actor.spawn! but  | 
| .to_spawn_options | |
Instance Attribute Summary
Instance Method Summary
Actor::RestartingContext - Inherited
Actor::AbstractContext - Inherited
| #<< | Alias for AbstractContext#tell. | 
| #ask, | |
| #ask! | Alias for AbstractContext#ask. | 
| #behaviour_definition, | |
| #dead_letter_routing | Defines an actor responsible for dead letters. | 
| #default_executor | override to se different default executor, e.g. | 
| #default_reference_class | override if different class for reference is needed. | 
| #envelope, | |
| #on_event | override to add custom code invocation on internal events like  | 
| #on_message, | |
| #pass | if you want to pass the message to next behaviour, usually  | 
| #tell | tell self a message. | 
| #initialize_core, #on_envelope | |
Actor::InternalDelegations - Included
| #behaviour | see Core#behaviour | 
| #behaviour! | see Core#behaviour! | 
| #children, #context, #dead_letter_routing, | |
| #log | delegates to core.log. | 
| #redirect, #terminate! | |
Concern::Logging - Included
| #log | Logs through Concurrent.global_logger, it can be overridden by setting @logger. | 
Actor::PublicDelegations - Included
| #actor_class | Alias for PublicDelegations#context_class. | 
| #context_class, #executor, #name, #parent, #path, | |
| #ref | Alias for PublicDelegations#reference. | 
| #reference | |
Actor::TypeCheck - Included
Constructor Details
    .new(size, &worker_initializer)  ⇒ Pool 
  
# File 'lib/concurrent-ruby-edge/concurrent/actor/utils/pool.rb', line 31
def initialize(size, &worker_initializer) @balancer = Balancer.spawn name: :balancer, supervise: true @workers = ::Array.new(size, &worker_initializer) @workers.each do |worker| Type! worker, Reference @balancer << [:subscribe, worker] end end
Instance Method Details
#on_message(message)
[ GitHub ]# File 'lib/concurrent-ruby-edge/concurrent/actor/utils/pool.rb', line 40
def () command, _ = return if [:restarted, :reset, :resumed, :terminated].include? command # ignore events from supervised actors envelope_to_redirect = if envelope.future envelope else Envelope.new(envelope., Promises.resolvable_future, envelope.sender, envelope.address) end envelope_to_redirect.future.on_fulfillment! { @balancer << :subscribe } # TODO check safety of @balancer reading redirect @balancer, envelope_to_redirect end