Ruby Gem - LoadError - PullRequest
       14

Ruby Gem - LoadError

8 голосов
/ 12 ноября 2010

Новичок Руби здесь пытается выяснить, как использовать Драгоценный камень, и пока опыт не настолько велик.

После установки mysql2 через gem я попытался использовать его в простом файле.

require 'mysql2'

#client = Mysql2::Client.new(:host => "localhost", :username => "username")

Хотя, когда я запускаю это, я получаю:


Parse.rb:1:in `require': no such file to load -- mysql2 (LoadError)
 from Parse.rb:1

Все же мой список драгоценных камней содержит mysql2:

Tanner-Smiths-MacBook-Pro:Humans_vs_Zombies_Parse tanner$ gem list

*** LOCAL GEMS ***

abstract (1.0.0)
actionmailer (3.0.1, 2.3.5, 1.3.6)
actionpack (3.0.1, 2.3.5, 1.13.6)
actionwebservice (1.2.6)
activemodel (3.0.1)
activerecord (3.0.1, 2.3.5, 1.15.6)
activeresource (3.0.1, 2.3.5)
activesupport (3.0.1, 2.3.5, 1.4.4)
acts_as_ferret (0.4.3)
arel (2.0.2)
builder (2.1.2)
capistrano (2.5.19, 2.5.2)
cgi_multipart_eof_fix (2.5.0)
daemons (1.1.0, 1.0.10)
dnssd (1.4, 0.6.0)
erubis (2.6.6)
fastthread (1.0.7, 1.0.1)
fcgi (0.8.8, 0.8.7)
ferret (0.11.6)
gem_plugin (0.2.3)
highline (1.6.1, 1.5.0)
hpricot (0.8.3, 0.6.164)
i18n (0.4.2)
jk-ferret (0.11.8.2)
libxml-ruby (1.1.4, 1.1.2)
mail (2.2.9)
mime-types (1.16)
mongrel (1.1.5)
mysql2 (0.2.6)
needle (1.3.0)
net-scp (1.0.4, 1.0.1)
net-sftp (2.0.5, 2.0.1, 1.1.1)
net-ssh (2.0.23, 2.0.4, 1.1.4)
net-ssh-gateway (1.0.1, 1.0.0)
polyglot (0.3.1)
rack (1.2.1, 1.0.1)
rack-mount (0.6.13)
rack-test (0.5.6)
rails (2.3.5, 1.2.6)
railties (3.0.1)
rake (0.8.7, 0.8.3)
RedCloth (4.2.3, 4.1.1)
ruby-openid (2.1.8, 2.1.2)
ruby-yadis (0.3.4)
rubynode (0.1.5)
sqlite3-ruby (1.3.2, 1.2.4)
termios (0.9.4)
thor (0.14.4)
treetop (1.4.8)
tzinfo (0.3.23)
xmpp4r (0.5, 0.4)

Результаты "ruby env":

RubyGems Environment:
  - RUBYGEMS VERSION: 1.3.5
  - RUBY VERSION: 1.8.7 (2009-06-12 patchlevel 174) [universal-darwin10.0]
  - INSTALLATION DIRECTORY: /Library/Ruby/Gems/1.8
  - RUBY EXECUTABLE: /System/Library/Frameworks/Ruby.framework/Versions/1.8/usr/bin/ruby
  - EXECUTABLE DIRECTORY: /usr/bin
  - RUBYGEMS PLATFORMS:
    - ruby
    - universal-darwin-10
  - GEM PATHS:
     - /Library/Ruby/Gems/1.8
     - /Users/tanner/.gem/ruby/1.8
     - /System/Library/Frameworks/Ruby.framework/Versions/1.8/usr/lib/ruby/gems/1.8
  - GEM CONFIGURATION:
     - :update_sources => true
     - :verbose => true
     - :benchmark => false
     - :backtrace => false
     - :bulk_threshold => 1000
  - REMOTE SOURCES:
     - http://gems.rubyforge.org/

Что я здесь не так делаю? Я не могу понять это.

Спасибо

-Tanner

Ответы [ 3 ]

6 голосов
/ 15 ноября 2010

Как вы, наверное, заметили, у вас установлено несколько версий ruby. Я настоятельно рекомендую вам использовать RVM для управления несколькими версиями ruby.

Это дикое предположение, но если вы не используете командную строку для запуска приложения и не используете такие инструменты, как TextMate, вам может потребоваться установить переменную оболочки "TM_RUBY", чтобы указать версию ruby ​​с установленными рубинами ( 1.8.7 (2009-06-12, уровень исправления 174)).

Вы можете попробовать:

/System/Library/Frameworks/Ruby.framework/Versions/1.8/usr/bin/irb

чтобы получить версию irb с установленными рубинами и затем попытаться:

require 'rubygems'
require 'mysql2'

Если это работает, и вы довольны тем, что можете обновить символические ссылки в / usr / bin / ruby, / usr / bin / irb, / usr / bin / gem, чтобы они указывали на более старую версию ruby, или один раз снова установите RVM и сделайте вашу жизнь намного проще.

6 голосов
/ 12 ноября 2010

Попробуйте:

require 'rubygems'
require 'mysql2'
0 голосов
/ 12 ноября 2010

Чтобы получить больше информации, запустите irb и запустите:

require 'rubygems'
gem 'mysql2'  #=> does this cause an error?
$:.grep /mysql2/  #=> if no error from previous line, please post what this shows

Также в командной строке терминала запустите "gem contents mysql2".Вы видите пути, заканчивающиеся на следующие?

lib/mysql2/error.rb
lib/mysql2/mysql2.bundle
lib/mysql2/client.rb
lib/mysql2/result.rb
lib/mysql2.rb
...