Отвечая на мой вопрос, поскольку я не смог найти правильного решения в другом месте в Интернете для этого сценария:
Проблема, кажется, заключается в взаимодействии bundler
и mongrel
использования gem_plugin
. Да, это могут быть средства жизнеобеспечения, но, к сожалению, многие производственные конфиги людей все еще зависят от них.
Кажется, что с mongrel --pre
, установленным из источника git
, он смотрит в bundle/ruby/1.9.1/gems/mongrel_
вместо bundle/ruby/1.9.1/bundler/gems/mongrel_
, где bundler
хранит драгоценный камень, клонированный из git
.
Итак, решение, которое сработало для нашего конфига, это просто символическая ссылка:
ln -s /mnt/app/shared/bundle/ruby/1.9.1/bundle/gems/mongrel* \
/mnt/app/shared/bundle/ruby/1.9.1/gems/mongrel-1.2.0.beta.1
Это явно что-то простое, что упаковщик может сделать автоматически. Полный след исключения был:
/mnt/app/shared/bundle/ruby/1.9.1/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:166:in `require':
no such file to load -- /mnt/app/shared/bundle/ruby/1.9.1/gems/mongrel-1.2.0.beta.1/lib/mongrel/init.rb (MissingSourceFile)
from /mnt/app/shared/bundle/ruby/1.9.1/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:166:in `require'
from /mnt/app/shared/bundle/ruby/1.9.1/gems/gem_plugin-0.2.3/lib/gem_plugin.rb:134:in `block in load'
from /usr/local/lib/ruby/site_ruby/1.9.1/rubygems/source_index.rb:241:in `each'
from /usr/local/lib/ruby/site_ruby/1.9.1/rubygems/source_index.rb:241:in `each'
from /mnt/services/shared/bundle/ruby/1.9.1/gems/gem_plugin-0.2.3/lib/gem_plugin.rb:112:in `load'
from /mnt/app/shared/bundle/ruby/1.9.1/bundler/gems/mongrel-f3e69eb8e6fb/lib/mongrel/configurator.rb:231:in `load_plugins'