0

尝试在 Rails 中使用 GroupMe gem EM-C2DM,https://github.com/groupme/em-c2dm,这是一个使用 Event Machine 的 Google C2DM Ruby 库。我知道它应该在 Heroku 上工作,因为有一个特定于 Heroku 的配置,但是我似乎无法让它运行。

我正在通过 Resque Worker 执行,并且该工作者正常工作并被排队和调用。但是,它无法通过身份验证,并且永远不会报告推送通知的响应。它似乎永远不会结束。

  module PushAndroid

  require "eventmachine"
  require "em-c2dm"

  @queue = :android_push

  def self.perform(opts)
    puts "entering android push"
    EM.next_tick do
      EM::C2DM.authenticate(ENV["C2DM_EMAIL"], ENV["C2DM_PASSWORD"])
      @push = Push.find(opts['push_id'])
      message = "Message #{@push.title}"
      push_id = "#{@push.id}"
      opts['tokens'].each{ |token|
        EM::C2DM.push(token, :message => message, :push_id => push_id) do |response|
            if response.success?
                puts "success! id=#{response.id}" # ID of sent message
            else
                puts "response:"
                puts response.inspect
                #case response.error
                #when "InvalidToken"
                    # reauthenticate
                #when "InvalidRegistration"
                    # clear our registration id
                #when "RetryAfter"
                    # pause sending for response.retry_after seconds
                #end        
            end
        end
      }
    end
  end
end

我也尝试过不使用 EM::next_tick 或 EM.next_tick 并且它通过了身份验证,但是从不推送任何东西,从不返回响应或任何东西。实际上它从不进入 EM::next_tick。

关于如何让它发挥作用的任何想法?这是在 Heroku 上,使用带有 Thin 的 Rails 3.1.1

从我的 Gemfile.lock:

   thin (1.3.1)
      daemons (>= 1.0.9)
      eventmachine (>= 0.12.6)
      rack (>= 1.0.0)

eventmachine (1.0.0.beta.4)

    em-apn (0.0.3)
      eventmachine (>= 1.0.0.beta.3)
      yajl-ruby (>= 0.8.2)
    em-http-request (1.0.2)
      addressable (>= 2.2.3)
      cookiejar
      em-socksify
      eventmachine (>= 1.0.0.beta.4)
      http_parser.rb (>= 0.5.3)
    em-socksify (0.2.0)
      eventmachine (>= 1.0.0.beta.4)

  remote: git://github.com/groupme/em-c2dm.git
  revision: 2d853ff771908785f23b8c64fa5d5508b4eba40a
  specs:
    em-c2dm (0.0.1)
      em-http-request (>= 1.0.0.beta.4)
      eventmachine (>= 1.0.0.beta.3)
      uuid
4

1 回答 1

0

把它放在 EM.run 中已经解决了这个问题。我猜工人没有连接到 Thin,因此需要运行他们自己的 Reactor

于 2012-06-07T12:26:38.783 回答