summaryrefslogtreecommitdiff
path: root/sample/drb/ring_echo.rb
diff options
context:
space:
mode:
Diffstat (limited to 'sample/drb/ring_echo.rb')
-rw-r--r--sample/drb/ring_echo.rb30
1 files changed, 30 insertions, 0 deletions
diff --git a/sample/drb/ring_echo.rb b/sample/drb/ring_echo.rb
new file mode 100644
index 0000000..0fde11b
--- /dev/null
+++ b/sample/drb/ring_echo.rb
@@ -0,0 +1,30 @@
+require 'drb/drb'
+require 'drb/eq'
+require 'rinda/ring'
+require 'thread'
+
+class RingEcho
+ include DRbUndumped
+ def initialize(name)
+ @name = name
+ end
+
+ def echo(str)
+ "#{@name}: #{str}"
+ end
+end
+
+DRb.start_service
+
+renewer = Rinda::SimpleRenewer.new
+
+finder = Rinda::RingFinger.new
+ts = finder.lookup_ring_any
+ts.read_all([:name, :RingEcho, nil, nil]).each do |tuple|
+ p tuple[2]
+ puts tuple[2].echo('Hello, World') rescue nil
+end
+ts.write([:name, :RingEcho, RingEcho.new(DRb.uri), ''], renewer)
+
+$stdin.gets
+