Gefolgt von diesem Tutorial (http://arfon.org/twitter-streaming-with-eventmachine-and-dynamodb) in einem Versuch, eine Amazon-Hörumgebung zu drehen; empfängt bestimmte Tweets und fügt sie einer Dynamo-Datenbank hinzu (über einen neuen Thread). Alles funktioniert jedoch gut, wenn eventmachine mit den Threads zu erstellen, ich folgendes erhalten:Eventmachine Gem -> Block in spawn_threadpool
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
}
undefined lokale Variable oder Methode `Tabelle 'für Haupt: 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
Block in spawn_threadpool'“ ]
Ich glaube, ich vermisse etwas -> sieht aus wie eine genaue Paste von dem, was ich eingereicht habe. –