Jenkins使用错误版本的Ruby(rvm)

时间:2017-01-13 11:36:25

标签: jenkins rvm jenkins-plugins

有下一个情况:

  • 使用jenkins
  • 安装了不同ruby版本的rvm(2 +)
  • 已安装rvm plugin

使用ruby版本ruby-2.3.0@global

在“构建环境”中启用选项“在RVM托管环境中运行构建”

现在关于问题。每次jenkins工作开始后,我都可以看到下一个输出:

Capturing environment variables produced by 'rvm use ruby-2.3.0@global'
$ bash -c export
[workspace] $ bash -c " source /usr/local/rvm/scripts/rvm && rvm use --install --create ruby-2.3.0@global && export > rvm.env"
Using /usr/local/rvm/gems/ruby-2.3.0 with gemset global
...

似乎一切都应该可行。 但实际上jenkins使用ruby-2.2.0,因为在日志中我发现了这个:

+++ __path_to_ruby=/usr/local/rvm/rubies/ruby-2.2.0/bin/ruby
+++ [[ -z /usr/local/rvm/rubies/ruby-2.2.0/bin/ruby ]]
+++ [[ /usr/local/rvm/rubies/ruby-2.2.0/bin/ruby != \/\u\s\r\/\l\o\c\a\l\/\r\v\m* ]]
+++ [[ /usr/local/rvm/rubies/ruby-2.2.0/bin/ruby == \/\u\s\r\/\l\o\c\a\l\/\r\v\m\/\b\i\n\/\r\u\b\y ]]
+++ [[ /usr/local/rvm/rubies/ruby-2.2.0/bin/ruby == \/\u\s\r\/\l\o\c\a\l\/\r\v\m* ]]
+++ [[ -z /usr/local/rvm/gems/ruby-2.2.0 ]]
+++ [[ -z /usr/local/rvm/gems/ruby-2.2.0:/usr/local/rvm/gems/ruby-2.2.0@global ]]
...

下一个问题源于此:

Gem::InstallError: activesupport requires Ruby version >= 2.2.2.

此外,如果我在“执行shell”区域中键入ruby -v命令 - 那么在日志中我看到了这个

+ ruby -v
ruby 2.2.0p0 (2014-12-25 revision 49005) [x86_64-linux]

我还尝试直接在“执行shell”中启动命令rvm use ruby-2.3.0

我还将其添加到/var/lib/jenkis/.bashrc

[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm"

并尝试将$HOME/.rvm更改为/usr/local/rvm

但每次结果都一样。 Jenkins不使用ruby-2.3.0

请帮我弄清楚我错过了什么?

1 个答案:

答案 0 :(得分:5)

我也遇到了这个问题。事实证明,如果您以root用户身份安装rvm,则会出现问题。我们必须完全卸载rvm并重新安装为jenkins用户,之后插件正确加载了rubies。

您可以通过列出Jenkins的$ HOME变量指向的目录内容来检测此问题。如果没有.rvm目录,则可能需要重新安装。