13

尝试安装 ffi gem 时出现错误:

~ - 16:54>gem i ffi
Building native extensions.  This could take a while...
ERROR:  Error installing ffi:
        ERROR: Failed to build gem native extension.

        rake RUBYARCHDIR=/home/mdemare/.rvm/gems/ruby-1.9.2-p136/gems/ffi-1.0.6/lib RUBYLIBDIR=/home/mdemare/.rvm/gems/ruby-1.9.2-p136/gems/ffi-1.0.6/lib
/home/mdemare/.rvm/rubies/ruby-1.9.2-p136/lib/ruby/site_ruby/1.9.1/rubygems.rb:370:in `bin_path': can't find gem rake ([">= 0"]) with executable rake (Gem::GemNotFoundException)
        from /home/mdemare/.rvm/gems/ruby-1.9.2-p136/bin/rake:19:in `<main>'

Gem files will remain installed in /home/mdemare/.rvm/gems/ruby-1.9.2-p136/gems/ffi-1.0.6 for inspection.
Results logged to /home/mdemare/.rvm/gems/ruby-1.9.2-p136/gems/ffi-1.0.6/gen/gem_make.out

在安装带有本机扩展的 gem 时,我经常遇到各种错误,所以我认为我的 Ubuntu 安装有问题,但我不知道是什么。我将发布您诊断问题所需的任何信息。

编辑:当我 cd 到 ffi gem(在第二行但最后一行中提到)并在第 6 行运行 rake 行时,我得到“找不到 RubyGem rake-compiler”。

在 gem 我 rake-compiler 之后,再次运行 rake,我得到了这个:

configure: error: source directory already configured; run "make distclean" there first
make: *** [/home/mdemare/.rvm/gems/ruby-1.9.2-p136/gems/ffi-1.0.6/build/x86_64-linux/ffi_c/1.9.2/libffi/.libs/libffi_convenience.a] Error 1
rake aborted!
Command failed with status (2): [make...]

更新:

这些是我的 rake gemspecs:

~ - 10:59>find ~/.rvm/ -name 'rake-0.8.7.gemspec'
~/.rvm/gems/ruby-1.9.2-p136/specifications/rake-0.8.7.gemspec
~/.rvm/gems/ruby-1.9.2-p136@global/specifications/rake-0.8.7.gemspec
~/.rvm/rubies/ruby-1.9.2-p136/lib/ruby/gems/1.9.1/specifications/rake-0.8.7.gemspec

最后一个是 gem 的外观,但 gemspec 与第一个不同,并且不包含可执行文件。不过,复制长文件并不能完全解决问题——我得到了一个找不到 rake 可执行文件的文件。

4

5 回答 5

13

这让我在波士顿黑客日尝试安装 Vagrant(FFI 是依赖项)时非常恼火。我最终浪费了很多时间,以至于我换了机器来解决这个问题。

事后,我发现了一个可行的方法(尽管我确信有更好的解决方案)。错误消息所抱怨的文件

~/.rvm/gems/ruby-1.9.2-p180/bin/rake

与其他类似副本的不同之处在于它在头部缺少路径设置内容,因此我从包含它们的文件之一复制了这些行:

[根据@danv 在下面的回答进行泛化。感谢改进!]

ENV['GEM_HOME']=ENV['GEM_HOME'] || '~/.rvm/gems/ruby-1.9.2-p180'
ENV['GEM_PATH']=ENV['GEM_PATH'] || '~/.rvm/gems/ruby-1.9.2-p180:~/.rvm/gems/ruby-1.9.2-p180@global'
ENV['PATH']='~/.rvm/gems/ruby-1.9.2-p180/bin:~/.rvm/gems/ruby-1.9.2-p180@global/bin:~/.rvm/rubies/ruby-1.9.2-p180/bin:' + ENV['PATH']

那为我修好了。这是一个新的 Ubuntu 10.10 安装,没有默认的 Ruby 安装(这可能是问题的一部分)和使用 RVM 安装的 Ruby 1.9.2。许多其他 gem 安装得很好,包括那些需要本地编译的,所以问题是 FFI 特有的。

于 2011-03-01T20:16:28.597 回答
6

我遇到了类似的问题, http://bugs.debian.org/cgi-bin/bugreport.cgi? bug=529663的解决方法帮助了我。简而言之,尝试使用以下命令安装 gem: $ rake=/usr/bin/rake gem install ffi

于 2011-02-28T20:56:14.857 回答
3

@Tom Morris - 尝试了你的方法,效果很好。

我在第 12 行之后将您的路径规范(已修改 - 见下文)插入 ~/.rvm/gems/ruby-1.9.2-p180/bin/rake 中。

我修改了路径规范,因此它们~对于用户主页是通用的:

ENV['GEM_HOME']=ENV['GEM_HOME'] || "~/.rvm/gems/ruby-1.9.2-p180"
ENV['GEM_PATH']=ENV['GEM_PATH'] || "~/.rvm/gems/ruby-1.9.2-p180:~/.rvm/gems/ruby-1.9.2-p180@global"
ENV['PATH']="~/.rvm/gems/ruby-1.9.2-p180/bin:~/.rvm/gems/ruby-1.9.2-p180@global/bin:~/.rvm/rubies/ruby-1.9.2-p180/bin:"+ ENV['PATH']

感谢您找到此修复程序!

于 2011-04-09T21:47:38.067 回答
2

感谢@Tim Morris 和@danv,您的回答/评论很有帮助。我调整了我的设置,它更基于超级用户环境。现在这是 /usr/local/rvm/gems/ruby-1.9.2-p180/bin/rake 在我的服务器上的样子:

require 'rubygems'

version = ">= 0"
ENV['GEM_HOME']=ENV['GEM_HOME'] || "/usr/local/rvm/gems/ruby-1.9.2-p180"
ENV['GEM_PATH']=ENV['GEM_PATH'] || "/usr/local/rvm/gems/ruby-1.9.2-p180:/usr/local/rvm/gems/ruby-1.9.2-p180@global"

if ARGV.first =~ /^_(.*)_$/ and Gem::Version.correct? $1 then
  version = $1
  ARGV.shift
end

gem 'rake', version
load Gem.bin_path('rake', 'rake', version)
于 2011-04-12T17:03:50.443 回答
0

安装程序尝试运行 rake 但找不到时失败:

can't find gem rake ([">= 0"]) with executable rake (Gem::GemNotFoundException)

您需要安装 rake gem: gem install rake

于 2011-02-26T17:12:38.760 回答