我使用此gem:https://github.com/zk-ruby/zk
连接到zookeeper,get
和set
命令正常工作。
我尝试使用随服务器构建一起提供的示例zookeeper客户端添加一个观察者客户端,并且一切正常。我可以添加一个观察者,当我从另一个客户端更新一些znode时,会通知客户端。
但我希望将一个观察者集成到ruby代码中,当节点上的数据发生变化时,我没有收到任何事件。
这是一个示例类:
class ZkConnect
attr_accessor :z, :sub, :k
include Singleton
@z = nil
@sub = nil
@watcher = nil
@callback = nil
@watcher = nil
def initialize
initialize_conns
end
def initialize_conns
@z = ZK.new("localhost:2181")
Rails.logger.info @z.inspect
# Rails.logger.info z.get_children(:path => "/system/production")
# Rails.logger.info z.get(:path => "/system/production")[:data]
# @sub = @z.register("/mypath") do |event, zookeeper_client|
# Rails.logger.info "got an event"
# Rails.logger.info "got an event on: #{event.inspect} #{zookeeper_client.inspect}"
# end
# Rails.logger.info @sub.inspect
w = watch
Rails.logger.info "dsmcldsm: #{w.inspect}"
end
# def watcher_callback
# @callback ||= Proc.new do |event|
# Rails.logger.info "dcbskcn : #{event.inspect}"
# # Set new watcher
# watch
# # Rediscover
# # discover
# end
# Rails.logger.info "nckdj cudsnciu sdcn: #{@callback.inspect}"
# return @callback
# end
def watch
# return if @z.nil?
Rails.logger.info "synapse: setting watch at "
# @watcher = @z.register("/mypath", &watcher_callback)
@watcher = @z.register("/mypath") do |event|
Rails.logger.info "dcbskcn : #{event.inspect}"
puts "dcbskcn : #{event.inspect}"
watch
end
Rails.logger.info "cudsnciu: #{@watcher.inspect}"
return @watcher
# Verify that we actually set up the watcher.
# unless @zk.exists?(@discovery['path'], :watch => true)
# log.error "synapse: zookeeper watcher path #{@discovery['path']} does not exist!"
# zk_cleanup
# end
# log.debug "synapse: set watch at #{@discovery['path']}"
end
end
我从此处https://github.com/airbnb/synapse/blob/master/lib/synapse/service_watcher/zookeeper.rb
获取了一些代码,但没有帮助。
我在rails项目上尝试过,尝试在thin
和passenger
上运行,但我看不出它会有什么帮助。
我也没有看到eventmachine是这个gem的依赖项,所以我真的不知道如何收到回调。
答案 0 :(得分:1)
我阅读了更新日志并决定在注册观察者后添加@z.stat("/mypath", :watch => true)
。它开始工作了。不知道为什么。