2012-03-24 7 views
0

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'“ ]

Antwort

0

Tabelle ist eine lokale Variable, so dass Sie nicht in der Lage sein werden, sie über den Methodenbereich zu erreichen.

Sie möchten die folgenden:

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 
} 

Sie werden auch wollen wahrscheinlich aufhören zu kontrollieren „Exception“ und stattdessen fangen „Standarderror“, sonst werden Sie nicht in der Lage sein, zum Beispiel STRG + C das Programm .

+0

Ich glaube, ich vermisse etwas -> sieht aus wie eine genaue Paste von dem, was ich eingereicht habe. –

Verwandte Themen