6

我正在处理的代码库最近从 Ruby 1.9.2 升级到 Ruby 1.9.3,从 Rails 3.1 升级到 Rails 3.2.2。因为我使用的是 RVM,所以我只是做rvm install 1.9.3了我所期望的所有必要的事情。

当我跑

rails s

我得到错误

[BUG] 开启跨线程冲突rb_gc()

我找到了许多与此问题相关的链接。StackOverflow 上有一个,但它并没有真正给出答案。最有希望的答案是在 RVM 网站上

到目前为止,在我所看到的每一种情况下,它总是最终是一个带有 C 扩展的 ruby​​ gem/库是针对不同的 ruby​​ 和/或架构编译的,而不是尝试加载它的那个。尝试卸载并重新安装带有 C 扩展的 gem,您的应用程序使用这些 gem 来寻找这个 buggar。

这很有帮助,但是我的 Ruby-fu 不够强大,无法知道哪些 gem 有 C 扩展,哪些我应该尝试重新安装。关于该主题的相当多的其他链接似乎表明 json gem 有问题,所以我尝试遵循建议的解决方案。

gem uninstall json 
gem install --platform=ruby

这对我来说并没有真正改变任何事情——我在尝试启动 Rails 环境时仍然遇到完全相同的错误。

我如何追踪这个问题?

如果有帮助,这里是 gem 列表的输出:

actionmailer (3.2.2)
actionpack (3.2.2)
activemodel (3.2.2)
activerecord (3.2.2)
activeresource (3.2.2)
activesupport (3.2.2)
addressable (2.2.7)
akami (1.0.0)
arel (3.0.2)
bcrypt-ruby (3.0.1)
bson (1.6.1)
bson_ext (1.6.1)
builder (3.0.0)
bundler (1.1.3, 1.0.21)
capybara (1.1.2)
carmen (0.2.13)
childprocess (0.3.1)
ci_reporter (1.7.0)
coderay (1.0.5)
coffee-rails (3.2.2)
coffee-script (2.2.0)
coffee-script-source (1.2.0)
commonjs (0.2.5)
cucumber (1.1.9)
cucumber-rails (1.3.0)
database_cleaner (0.7.2)
devise (2.0.4)
diff-lcs (1.1.3)
ejs (1.0.0)
email_spec (1.2.1)
engineyard (1.4.28)
engineyard-serverside-adapter (1.6.3)
erubis (2.7.0)
escape (0.0.4)
execjs (1.3.0)
factory_girl (3.0.0)
factory_girl_rails (3.0.0)
faker (1.0.1)
fakeweb (1.3.0)
ffi (1.0.11)
gherkin (2.9.3)
gyoku (0.4.4)
haml (3.1.4)
haml-rails (0.3.4)
hash-deep-merge (0.1.1)
highline (1.6.11)
hike (1.2.1)
httpi (0.9.6)
i18n (0.6.0)
jasmine (1.1.2)
jasmine-core (1.1.0)
jasminerice (0.0.8)
journey (1.0.3)
jquery-rails (2.0.1)
json (1.6.6)
json_pure (1.6.6)
kaminari (0.13.0)
kgio (2.7.4)
launchy (2.0.5)
less (2.1.0)
less-rails (2.2.0)
libv8 (3.3.10.4 x86_64-darwin-11)
log4r (1.1.10)
mail (2.4.4)
metaclass (0.0.1)
method_source (0.7.1)
mime-types (1.18)
mocha (0.10.5)
mongo (1.6.1)
mongoid (2.4.7)
mongoid-rspec (1.4.4)
multi_json (1.2.0)
net-ssh (2.2.2)
newrelic_rpm (3.3.3)
nokogiri (1.5.2)
nori (1.1.0)
open4 (1.3.0)
orm_adapter (0.0.7)
polyglot (0.3.3)
pr_geohash (1.0.0)
pry (0.9.8.4)
pry-highlight (0.0.1)
pry_debug (0.0.1)
rack (1.4.1)
rack-cache (1.2)
rack-ssl (1.3.2)
rack-test (0.6.1)
rails (3.2.2)
rails-footnotes (3.7.6)
railties (3.2.2)
raindrops (0.8.0)
rake (0.9.2.2)
rdoc (3.12)
recursive-open-struct (0.2.1)
rest-client (1.6.7)
rpm_contrib (2.1.8)
rsolr (1.0.7)
rspec (2.9.0)
rspec-core (2.9.0)
rspec-expectations (2.9.0)
rspec-mocks (2.9.0)
rspec-rails (2.9.0)
rubyzip (0.9.6.1)
sass (3.1.15)
sass-rails (3.2.5)
savon (0.9.9)
selenium-webdriver (2.20.0)
settings-tree (0.2.1)
simplecov (0.6.1)
simplecov-html (0.5.3)
simplecov-rcov (0.2.3)
slop (2.4.4)
spine-rails (0.1.0)
spork (1.0.0rc2)
sprockets (2.1.2)
sunspot (1.3.1)
sunspot_mongoid (0.4.1)
sunspot_rails (1.3.1)
sunspot_solr (1.3.1)
term-ansicolor (1.0.7)
therubyracer (0.10.1)
thor (0.14.6)
tilt (1.3.3)
treetop (1.4.10)
twitter-bootstrap-rails (2.0.6)
tzinfo (0.3.32)
uglifier (1.2.4)
unicorn (4.2.1)
warden (1.1.1)
wasabi (2.1.0)
xpath (0.1.4)
4

5 回答 5

6

您可以尝试以下各种方法。

清理

要清理旧版本的 gem:

gem cleanup --dryrun

json

要暂时查看 json gem 是否存在问题,请从 json(本机)切换到 json(纯 ruby​​)并更改您的 Gemfile:

gem install json_pure 

本土宝石

您的宝石列表中有一些对我来说是原生的:

  • bcrypt
  • 布森
  • 厄鲁比斯
  • ffi(启用大量本机连接)
  • 小黄瓜
  • 公斤
  • 较少的
  • 小切
  • 雨滴
  • therubyracer(许多不可预知的问题恕我直言)
  • 独角兽

你的宝石ffi特别有趣——你碰巧知道你在用它做什么吗?

ffi使 Ruby 代码能够调用本机代码,例如,如果您的 Ruby 应用程序的某些部分需要连接到本机库。

当你诊断你的问题时,我会先看看这个宝石。

生成文件

要查找任何具有 Makefile 文件的 gem,这很好地表明它们具有本机代码:

find / | grep "/ruby/gems/" | grep Makefile

要查找所有宝石以便删除它们:

find / | grep "/ruby/gems/"

核动力车

要对 RVM 或其碎片进行核攻击,您可以使用rvm uninstallrvm implode或此脚本对 RVM 进行核攻击并找到任何挥之不去的碎片:

https://raw.github.com/SixArm/sixarm_unix_shell_scripts/master/rvm-uninstall-danger

尝试 rbenv + 捆绑器

我从使用 rvm 更改为使用 rbenv + bundler,它对我来说非常有用。

rbenv 工具是 rvm 管理 Ruby 版本的直接竞争对手: https ://github.com/sstephenson/rbenv

Bundler 是管理 gemset 和 gem 依赖项的好方法:http: //gembundler.com/

酿造

如果您在 Mac 上并使用 MacPorts,要更改为 Homebrew:

关联

于 2012-04-22T04:09:32.277 回答
4
  1. 通过运行卸载所有版本的 json gem: gem uninstall json

  2. 然后运行: gem install json --platform=ruby

  3. 再次运行捆绑:bundle install

于 2013-04-03T14:40:12.893 回答
1

您应该尝试使用该命令对所有gem 进行 nuking 并为您的应用程序重新安装它们。bundle

引用此错误的 RVM 文档

尝试卸载并重新安装带有 C 扩展的 gem,您的应用程序使用这些 gem 来寻找这个 buggar。

使用 RVM 删除 gem的命令很简单:

rvm uninstall
于 2012-04-19T00:49:11.750 回答
0

在走干净的 ruby​​/rvm 安装路线之前,您应该检查是否删除了 ruby​​ 1.8.7(在大多数发行版上默认安装)。我相信这会干扰我用 1.9.2 编译的一些 gem(我认为它是原生的之一)。我使用 apt-get 完全删除了 1.8.7,然后创建了一个新的 rvm 配置文件(通过更改 .rvmrc 中的配置文件名称),然后运行 ​​bundle install 以完全刷新所有 gem。

于 2012-04-24T13:39:22.930 回答
0

全新重新安装 RVM 最新版本是最佳选择。

rvm implode

rm -rf ~/.rvm

curl -L get.rvm.io | bash -s stable

于 2012-04-24T03:09:48.287 回答