2012-03-02 60 views
1

試圖獲得安裝在Ubuntu上的gem mysql2,我嘗試了所有的建議,但我不能讓它運行。這是我的應用程序中的錯誤。mysql2與ruby問題

./bla.rb:65:in `post_init': undefined method `query' for nil:NilClass (NoMethodError) 
    from /var/lib/gems/1.8/gems/eventmachine-0.12.10/lib/em/timers.rb:51:in `call' 
    from /var/lib/gems/1.8/gems/eventmachine-0.12.10/lib/em/timers.rb:51:in `fire' 
    from /var/lib/gems/1.8/gems/eventmachine-0.12.10/lib/eventmachine.rb:256:in `call' 
    from /var/lib/gems/1.8/gems/eventmachine-0.12.10/lib/eventmachine.rb:256:in `run_machine' 
    from /var/lib/gems/1.8/gems/eventmachine-0.12.10/lib/eventmachine.rb:256:in `run' 
    from ./bla.rb:234:in `start_server' 
    from ./bin/minibardaemon:15 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons/application.rb:254:in `call' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons/application.rb:254:in `start_proc' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons/application.rb:263:in `call' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons/application.rb:263:in `start_proc' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons/application.rb:295:in `start' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons/controller.rb:73:in `run' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons.rb:197:in `run_proc' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons/cmdline.rb:109:in `call' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons/cmdline.rb:109:in `catch_exceptions' 
    from /var/lib/gems/1.8/gems/daemons-1.1.8/lib/daemons.rb:196:in `run_proc' 

我已經安裝了所有的包被推薦並通過安裝寶石,但仍然沒有運氣mysql2。

libmysqlclient-dev 

已安裝。

Im在Ubuntu上。

# gem -v 
1.3.7 

# ruby -v 
ruby 1.8.7 (2010-08-16 patchlevel 302) [x86_64-linux] 

安裝寶石

# gem install mysql 
Building native extensions. This could take a while... 
Successfully installed mysql-2.8.1 
1 gem installed 
Installing ri documentation for mysql-2.8.1... 
Installing RDoc documentation for mysql-2.8.1... 



# gem install mysql2 
Building native extensions. This could take a while... 
Successfully installed mysql2-0.3.11 
1 gem installed 
Installing ri documentation for mysql2-0.3.11... 
Installing RDoc documentation for mysql2-0.3.11... 


    def create_mysql2 
    begin 
     mysql2 = Mysql2::EM::Client.new(
     :username => DBUSER, 
     :password => DBPASS, 
     :host  => DBHOST, 
     :port  => DBPORT, 
     :socket => DBSOCKET, 
     :database => DBNAME 
    ) 
     return mysql2 
    rescue Mysql2::Error => exception 
     $stderr.puts "Mysql Error: #{ exception.message }" 
     EventMachine::stop_event_loop 
    end 
    end 

...

begin 
    mysql2 = create_mysql2 
rescue Exception => ex 
    p ex 
end 

    # query the db every x seconds. 
    EventMachine::add_periodic_timer(QUERY_INTERVAL) do 
     defer1 = mysql2.query "SELECT * FROM table LIMIT #{QUERY_LIMIT}" 

回答

1

並不真的像mysql2寶石的問題,請你告訴你bla.rb文件65'th行?可能還有一些圍繞它的線條。

它實際上看起來像你的mysql2客戶端由於某種原因得到未初始化。 我會建議檢查是否是這樣工作的:

require 'mysql2' 
mysql_client = Mysql2::Client.new(:host => "localhost", :username => "root") 
mysql_client.query('sql .. ') 

如果是這樣,顯然有一個問題,在您的腳本

+0

線65:defer1 = mysql2.query「SELECT * FROM minibar_usage其中狀態=假LIMIT #{QUERY_LIMIT}「 - >用更多的代碼更新了我的問題。 – 2012-03-02 12:22:34

+0

謝謝,你指出我在正確的方向 - 這是一個嚴峻的問題:https://github.com/brianmario/mysql2/issues/112 - 每次都需要啓動連接。 – 2012-03-02 12:43:11