红宝石的动物园管理员观察者

时间:2016-06-09 14:40:10

标签: ruby-on-rails ruby apache-zookeeper

我使用此gem:https://github.com/zk-ruby/zk连接到zookeeper,getset命令正常工作。

我尝试使用随服务器构建一起提供的示例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项目上尝试过,尝试在thinpassenger上运行,但我看不出它会有什么帮助。

我也没有看到eventmachine是这个gem的依赖项,所以我真的不知道如何收到回调。

1 个答案:

答案 0 :(得分:1)

我阅读了更新日志并决定在注册观察者后添加@z.stat("/mypath", :watch => true)。它开始工作了。不知道为什么。