0

このチュートリアル (http://arfon.org/twitter-streaming-with-eventmachine-and-dynamodb) に従って、Amazon リスニング環境を起動しようとしました。特定のツイートを受信し、dynamo db に (新しいスレッドを介して) 追加します。すべて正常に動作しますが、eventmachine を使用してスレッドを生成すると、次のようになります。

require 'aws-sdk'
require 'eventmachine'
require 'tweetstream'

AWS_ACCESS_KEY = 'HERE IT IS'
AWS_SECRET_KEY = 'YES HERE'


dynamo_db = AWS::DynamoDB.new(:access_key_id => AWS_ACCESS_KEY, :secret_access_key => AWS_SECRET_KEY)

table = dynamo_db.tables['tweets']
table.load_schema

TweetStream.configure do |config|
  config.username = 'geezlouis'
  config.password = 'password'
  config.auth_method = :basic
end

EM.run{
  client = TweetStream::Client.new

  def write_to_dynamo(status)
    EM.defer do
      tweet_hash = {:user_id => status.user.id, 
                    :created_at => status.created_at,
                    :id => status.id,
                    :screen_name => status.user.screen_name}

      begin
        table.items.create(tweet_hash)
      rescue Exception => e  
        puts e.message  
        puts e.backtrace.inspect
      end
    end
  end

  client.track("Romney", "Gingrich") do |status|
    write_to_dynamo(status)
  end  
}  

main:Object の未定義のローカル変数またはメソッド「テーブル」

["tweets.rb:31:in `block in write_to_dynamo'", "/.rvm/gems/ruby-1.9.3-p125/gems/eventmachine-0.12.10/lib/eventmachine.rb:1060:in

call'", "/.rvm/gems/ruby-1.9.3-p125/gems/eventmachine-0.12.10/lib/eventmachine.rb:1060:in spawn_threadpool のブロック'"]

4

1 に答える 1

0

table はローカル変数であるため、メソッド スコープからアクセスすることはできません。

次のものが必要です。

require 'aws-sdk'
require 'eventmachine'
require 'tweetstream'

AWS_ACCESS_KEY = 'HERE IT IS'
AWS_SECRET_KEY = 'YES HERE'


dynamo_db = AWS::DynamoDB.new(:access_key_id => AWS_ACCESS_KEY, :secret_access_key => AWS_SECRET_KEY)

table = dynamo_db.tables['tweets']
table.load_schema

TweetStream.configure do |config|
  config.username = 'geezlouis'
  config.password = 'password'
  config.auth_method = :basic
end

EM.run{
  client = TweetStream::Client.new

  def write_to_dynamo(status, table)
    EM.defer do
      tweet_hash = {:user_id => status.user.id, 
                    :created_at => status.created_at,
                    :id => status.id,
                    :screen_name => status.user.screen_name}

      begin
        table.items.create(tweet_hash)
      rescue Exception => e  
        puts e.message  
        puts e.backtrace.inspect
      end
    end
  end

  client.track("Romney", "Gingrich") do |status|
    write_to_dynamo(status, table)
  end  
}

また、"Exception" のキャッチを停止し、代わりに "StandardError" をキャッチすることをお勧めします。そうしないと、たとえば CTRL+C でプログラムを実行できなくなります。

于 2012-03-28T02:59:13.340 に答える