Ruby 2.4

DRb::ExtServManager

class DRb::ExtServManager

父类:ObjectIncluded模块:DRb :: DRbUndumped,MonitorMixin

属性

uriRW

公共类方法

command()显示源

# File lib/drb/extservm.rb, line 17 def self.command @@command end

command=(cmd) 显示源

# File lib/drb/extservm.rb, line 21 def self.command=(cmd) @@command = cmd end

new() 显示源

调用超类方法MonitorMixin.new

# File lib/drb/extservm.rb, line 25 def initialize super() @cond = new_cond @servers = {} @waiting = [] @queue = Thread::Queue.new @thread = invoke_thread @uri = nil end

公共实例方法

regist(name, ro) 显示源

# File lib/drb/extservm.rb, line 47 def regist(name, ro) synchronize do @servers[name] = ro @cond.signal end self end

service(name) 显示源

# File lib/drb/extservm.rb, line 36 def service(name) synchronize do while true server = @servers[name] return server if server&.alive? invoke_service(name) @cond.wait end end end

unregist(name) 显示源

# File lib/drb/extservm.rb, line 55 def unregist(name) synchronize do @servers.delete(name) end end

私有实例方法

invoke_service(name) 显示源

# File lib/drb/extservm.rb, line 71 def invoke_service(name) @queue.push(name) end

invoke_service_command(name,command)显示源

# File lib/drb/extservm.rb, line 75 def invoke_service_command(name, command) raise "invalid command. name: #{name}" unless command synchronize do return if @servers.include?(name) @servers[name] = false end uri = @uri || DRb.uri if command.respond_to? :to_ary command = command.to_ary + [uri, name] pid = spawn(*command) else pid = spawn("#{command} #{uri} #{name}") end th = Process.detach(pid) th[:drb_service] = name th end

invoke_thread()显示源

# File lib/drb/extservm.rb, line 62 def invoke_thread Thread.new do while true name = @queue.pop invoke_service_command(name, @@command[name]) end end end