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