我有一个在AWS Opsworks上运行的项目,该项目在 Ruby 2.2.2 上运行 1.5.3 的最新版本。
我想将捆绑包版本升级到 1.17.3
但是当我尝试这样做的时候,我得到了这个错误。
Mixlib::ShellOut::ShellCommandFailed
------------------------------------
Expected process to exit with [0], but received '1'
---- Begin output of /usr/local/bin/gem install bundler -q --no-rdoc --no-ri -v "1.11.2" ----
STDOUT:
STDERR: ERROR: Error installing bundler:
"bundle" from bundler conflicts with /usr/local/bin/bundle
---- End output of /usr/local/bin/gem install bundler -q --no-rdoc --no-ri -v "1.11.2" ----
Ran /usr/local/bin/gem install bundler -q --no-rdoc --no-ri -v "1.11.2" returned 1
Resource Declaration:
---------------------
# In /var/lib/aws/opsworks/cache.stage2/cookbooks/opsworks_bundler/recipes/default.rb
2: gem_package "Installing Bundler #{node[:opsworks_bundler][:version]}" do
3: gem_binary node[:dependencies][:gem_binary]
4: retries 2
5: package_name "bundler"
6: action :install
7: version node[:opsworks_bundler][:version]
8: if Gem::Version.new(node[:opsworks_rubygems][:version]) > Gem::Version.new("2.6.14")
9: options "--force"
10: end
11: end
Compiled Resource:
------------------
# Declared in /var/lib/aws/opsworks/cache.stage2/cookbooks/opsworks_bundler/recipes/default.rb:2:in `from_file'
gem_package("Installing Bundler 1.11.2") do
provider Chef::Provider::Package::Rubygems
action [:install]
retries 0
retry_delay 2
package_name "bundler"
version "1.11.2"
cookbook_name "opsworks_bundler"
recipe_name "default"
gem_binary "/usr/local/bin/gem"
end
[2019-12-04T04:42:03+00:00] INFO: Running queued delayed notifications before re-raising exception
[2019-12-04T04:42:03+00:00] ERROR: Running exception handlers
[2019-12-04T04:42:03+00:00] ERROR: Exception handlers complete
[2019-12-04T04:42:03+00:00] FATAL: Stacktrace dumped to /var/lib/aws/opsworks/cache.stage2/chef-stacktrace.out
[2019-12-04T04:42:03+00:00] ERROR: gem_package[Installing Bundler 1.11.2] (opsworks_bundler::default line 2) had an error: Mixlib::ShellOut::ShellCommandFailed: Expected process to exit with [0], but received '1'
---- Begin output of /usr/local/bin/gem install bundler -q --no-rdoc --no-ri -v "1.11.2" ----
STDOUT:
STDERR: ERROR: Error installing bundler:
"bundle" from bundler conflicts with /usr/local/bin/bundle
---- End output of /usr/local/bin/gem install bundler -q --no-rdoc --no-ri -v "1.11.2" ----
Ran /usr/local/bin/gem install bundler -q --no-rdoc --no-ri -v "1.11.2" returned 1
[2019-12-04T04:42:03+00:00] FATAL: Chef::Exceptions::ChildConvergeError: Chef run process exited unsuccessfully (exit code 1)
当我在服务器上运行bundle -v
时,我得到的是**1.5.3.**版本,无论我做什么,我都不能改变捆绑包的版本。
root@hades:/srv/www/app_unicorn/current# which gem
/usr/local/bin/gem
root@hades:/srv/www/app_unicorn/current# which ruby
/usr/local/bin/ruby
root@hades:/srv/www/app_unicorn/current# which bundle
/usr/local/bin/bundle
root@hades:/srv/www/app_unicorn/current# gem env
RubyGems Environment:
- RUBYGEMS VERSION: 2.2.2
- RUBY VERSION: 2.1.9 (2016-03-30 patchlevel 490) [x86_64-linux]
- INSTALLATION DIRECTORY: /usr/local/lib/ruby/gems/2.1.0
- RUBY EXECUTABLE: /usr/local/bin/ruby
- EXECUTABLE DIRECTORY: /usr/local/bin
- SPEC CACHE DIRECTORY: /root/.gem/specs
- RUBYGEMS PLATFORMS:
- ruby
- x86_64-linux
- GEM PATHS:
- /usr/local/lib/ruby/gems/2.1.0
- /root/.gem/ruby/2.1.0
- GEM CONFIGURATION:
- :update_sources => true
- :verbose => true
- :backtrace => false
- :bulk_threshold => 1000
- REMOTE SOURCES:
- https://rubygems.org/
- SHELL PATH:
- /usr/local/sbin
- /usr/local/bin
- /usr/sbin
- /usr/bin
- /sbin
- /bin
- /usr/games
- /usr/local/games
root@hades:/srv/www/app_unicorn/current# bundle env
Bundler 1.5.3
Ruby 2.1.9 (2016-03-30 patchlevel 490) [x86_64-linux]
Rubygems 2.2.2
GEM_HOME
Bundler settings
path
Set for your local app (/srv/www/app_unicorn/releases/20061825/.bundle/config): "/home/deploy/.bundler/app_unicorn"
without
Set for your local app (/srv/www/app_unicorn/releases/20061825/.bundle/config): "test:development"
disable_shared_gems
Set for your local app (/srv/www/app_unicorn/releases/20061825/.bundle/config): "1"
有人请我研究这个问题。但我不知道该怎么办https://github.com/chef/chef-dk/issues/536
如何在chef recipe或其他任何地方添加配置来更新bundle版本?
我的烹饪书:-https://gist.github.com/nijeeshjoshy/90ef2dfc693c869205bad589ef1b0e23
我有ssh访问权限,我可以手动重新安装bunder没有任何问题。但我必须通过主厨。如果我每次都手动操作,就违背了使用opsworks的目的
1条答案
按热度按时间lrpiutwd1#
我强烈建议你不要使用Ruby 2.2.2来获得安全性、兼容性、性能、支持、更快的bug修复以及与其他框架/库的更好兼容性。使用像2.2这样过时的版本,你将与软件开发的所有这些领域作斗争。
Ruby 3+有最新的稳定版本,具有长期支持(LTS),可能适合您现有的设置。试试看
至少,使用Bundler 2.4升级到Ruby 2.7。这将解决你的问题。