concurrent-ruby
concurrent-ruby copied to clipboard
Actor pool terminated event sent as message
- Operating system: Linux
- Ruby implementation: Ruby
-
concurrent-ruby
version: 1.1.5 -
concurrent-ruby-edge
version: 0.5.0
Given this code:
require 'concurrent-edge'
class WorkerActor < Concurrent::Actor::RestartingContext
def on_event(event)
puts "#{name} event: #{event.inspect}"
end
end
class Actor < Concurrent::Actor::RestartingContext
def initialize
@worker_pool = Concurrent::Actor::Utils::Pool.spawn('worker_pool', 10) do |index|
WorkerActor.spawn(name: "worker[#{index}]", supervise: true)
end
end
def on_message(message)
puts "#{name} message: #{message.inspect}"
end
def on_event(event)
puts "#{name} event: #{event.inspect}"
end
end
actor = Actor.spawn(name: 'parent')
actor << :terminate!
sleep 0.1
-why does the Actor
receive both an event :terminated
and a message :terminated
? Output from the above:
parent event: [:terminated, nil]
worker[0] event: [:terminated, nil]
worker[1] event: [:terminated, nil]
worker[2] event: [:terminated, nil]
worker[3] event: [:terminated, nil]
worker[4] event: [:terminated, nil]
worker[5] event: [:terminated, nil]
worker[6] event: [:terminated, nil]
worker[7] event: [:terminated, nil]
worker[8] event: [:terminated, nil]
worker[9] event: [:terminated, nil]
parent message: [:terminated, nil]
It only seems to receive a message when I use a Pool
. If I replace the #initialize
method with:
@worker = WorkerActor.spawn(name: 'worker', supervise: true)
Then the output includes only events and no message:
parent event: [:terminated, nil]
worker event: [:terminated, nil]