/usr/share/doc/ruby-amqp/examples/legacy/multiclock.rb is in ruby-amqp 0.9.5-2.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | #!/usr/bin/env ruby
# encoding: utf-8
require "bundler"
Bundler.setup
$:.unshift(File.expand_path("../../../lib", __FILE__))
require 'amqp'
require 'time'
AMQP.start(:host => 'localhost') do |connection|
# Send Connection.Close on Ctrl+C
trap(:INT) do
unless connection.closing?
connection.close { exit! }
end
end
def log(*args)
p args
end
#AMQP.logging = true
clock = AMQP::Channel.new.headers('multiformat_clock')
EM.add_periodic_timer(1) {
puts
time = Time.new
["iso8601", "rfc2822"].each do |format|
formatted_time = time.send(format)
log :publish, format, formatted_time
clock.publish "#{formatted_time}", :headers => {"format" => format} if connection.open?
end
}
["iso8601", "rfc2822"].each do |format|
amq = AMQP::Channel.new
amq.queue(format.to_s).bind(amq.headers('multiformat_clock'), :arguments => {"format" => format}).subscribe { |time|
log "received #{format}", time
}
end
show_stopper = Proc.new {
connection.close do
EM.stop
end
}
Signal.trap "INT", show_stopper
Signal.trap "TERM", show_stopper
EM.add_timer(3, show_stopper)
end
|