Class: Opal::Builder::Scheduler::Prefork::ForkSet
- Inherits:
-
Array
- Object
- Array
- Opal::Builder::Scheduler::Prefork::ForkSet
- Defined in:
- opal/lib/opal/builder/scheduler/prefork.rb
Instance Method Summary collapse
- #close ⇒ Object
- #create_fork ⇒ Object
- #from_io(io, type) ⇒ Object
- #get_events(queue_length) ⇒ Object
-
#initialize(count, &block) ⇒ ForkSet
constructor
A new instance of ForkSet.
- #wait ⇒ Object
Constructor Details
#initialize(count, &block) ⇒ ForkSet
Returns a new instance of ForkSet.
77 78 79 80 81 82 83 |
# File 'opal/lib/opal/builder/scheduler/prefork.rb', line 77 def initialize(count, &block) super([]) @count, @block = count, block create_fork end |
Instance Method Details
#close ⇒ Object
124 125 126 |
# File 'opal/lib/opal/builder/scheduler/prefork.rb', line 124 def close each(&:close) end |
#create_fork ⇒ Object
116 117 118 |
# File 'opal/lib/opal/builder/scheduler/prefork.rb', line 116 def create_fork self << Fork.new(self, &@block) end |
#from_io(io, type) ⇒ Object
120 121 122 |
# File 'opal/lib/opal/builder/scheduler/prefork.rb', line 120 def from_io(io, type) find { |i| i.__send__(type) == io } end |
#get_events(queue_length) ⇒ Object
85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 |
# File 'opal/lib/opal/builder/scheduler/prefork.rb', line 85 def get_events(queue_length) # Wait for anything to happen: # - Either any of our workers return some data # - Or any workers become ready to receive data # - But only if we have enough work for them ios = IO.select( map(&:read_io), sample(queue_length).map(&:write_io), [] ) return [[], []] unless ios events = ios[0].map do |io| io = from_io(io, :read_io) [io, *io.recv] end idles = ios[1].map do |io| from_io(io, :write_io) end # Progressively create forks, because we may not need all # the workers at the time. The number 6 was picked due to # some trial and error on a Ryzen machine. # # Do note that prefork may happen more than once. create_fork if length < @count && rand(6) == 1 [events, idles] end |
#wait ⇒ Object
128 129 130 |
# File 'opal/lib/opal/builder/scheduler/prefork.rb', line 128 def wait each(&:wait) end |