2004-02-13 21:28:02 -05:00
|
|
|
=begin
|
|
|
|
distributed Ruby --- dRuby Sample Server
|
2011-05-15 07:55:52 -04:00
|
|
|
Copyright (c) 1999-2000,2002 Masatoshi SEKI
|
2004-02-13 21:28:02 -05:00
|
|
|
=end
|
|
|
|
|
|
|
|
=begin
|
|
|
|
How to play.
|
|
|
|
|
|
|
|
Terminal 1
|
2011-05-15 07:55:52 -04:00
|
|
|
| % ruby drbs.rb
|
2004-02-13 21:28:02 -05:00
|
|
|
| druby://yourhost:7640
|
|
|
|
|
|
|
|
Terminal 2
|
|
|
|
| % ruby drbc.rb druby://yourhost:7640
|
|
|
|
| "hello"
|
|
|
|
| ....
|
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
require 'drb/drb'
|
|
|
|
|
|
|
|
class DRbEx
|
|
|
|
include DRbUndumped
|
|
|
|
|
|
|
|
def initialize
|
|
|
|
@hello = 'hello'
|
|
|
|
end
|
|
|
|
|
|
|
|
def hello
|
|
|
|
cntxt = Thread.current['DRb']
|
|
|
|
if cntxt
|
|
|
|
p cntxt['server'].uri
|
|
|
|
p cntxt['client'].peeraddr
|
|
|
|
end
|
|
|
|
Foo::Unknown.new
|
|
|
|
end
|
|
|
|
|
|
|
|
def err
|
|
|
|
raise FooError
|
|
|
|
end
|
|
|
|
|
|
|
|
def sample(a, b, c)
|
|
|
|
a.to_i + b.to_i + c.to_i
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class Foo
|
|
|
|
class Unknown
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class FooError < RuntimeError
|
|
|
|
end
|
|
|
|
|
|
|
|
if __FILE__ == $0
|
|
|
|
DRb.start_service(ARGV.shift || 'druby://:7640', DRbEx.new)
|
|
|
|
puts DRb.uri
|
|
|
|
Thread.new do
|
|
|
|
sleep 10
|
|
|
|
DRb.stop_service
|
|
|
|
end
|
|
|
|
DRb.thread.join
|
|
|
|
end
|
|
|
|
|