JRuby 安装失败,除非 sudo 与 "undefined local variable or method `r' for main:Object"



更新:当我使用sudo时,一切都起作用(例如sudo rbenv install jruby-9.1.2.0(。但是我不想要那个:(。

$ ruby -v
NameError: undefined local variable or method `v' for main:Object
<top> at -v:1
$ sudo ruby -v
jruby 9.1.2.0 (2.3.0) 2016-05-26 7357c8f Java HotSpot(TM) 64-Bit Server VM 25.51-b03 on 1.8.0_51-b16 +jit [darwin-x86_64]

寻找有关在安装过程中在哪里寻找sudo的提示。C Ruby安装/运行不带sudo


尝试安装jruby,但在将-r标志解释为变量的地方获取问题。使用RVM和Jruby 1.7.x版本时的类似问题。同事没有任何相同的问题。以前可以使用RVM和RBENV安装Jruby 1.7,并且不知道从那以后我的系统上发生了什么变化。用JAVA_HOME设置为1.7和1.8版本的结果。

我无法弄清楚系统上的原因是一个问题 - 在重新成像之前寻找故障排除的想法:(。

rbenv install -v jruby-9.1.2.0
/var/folders/qt/xqr8qztj5tl94l0r3l9t0pm4zbpz12/T/ruby-build.20170420180901.3389 ~
Downloading jruby-bin-9.1.2.0.tar.gz...
HTTP/1.1 200 OK
Content-Type: binary/octet-stream
Content-Length: 32578117
Connection: keep-alive
Date: Thu, 20 Apr 2017 18:41:50 GMT
Last-Modified: Fri, 27 May 2016 22:23:15 GMT
ETag: "749bb917dde9666e365e12bbe776a5c2"
Accept-Ranges: bytes
Server: AmazonS3
Age: 16032
X-Cache: Hit from cloudfront
Via: 1.1 0b1b12cfcb11f71988a190f16ef65179.cloudfront.net (CloudFront)
X-Amz-Cf-Id: mKmI9h4xs22ajaNTInTyIeqrnwQw1XHOJzcbKc--yknq4CUOu3XUmg==
-> https://dqw8nmjcqpjn7.cloudfront.net/60598a465883ab4c933f805de4a7f280052bddc793b95735465619c03ca43f35
/var/folders/qt/xqr8qztj5tl94l0r3l9t0pm4zbpz12/T/ruby-build.20170420180901.3389/jruby-9.1.2.0 /var/folders/qt/xqr8qztj5tl94l0r3l9t0pm4zbpz12/T/ruby-build.20170420180901.3389 ~
Installing jruby-9.1.2.0...
Building native extensions.  This could take a while...
ERROR:  Error installing jruby-launcher:
  ERROR: Failed to build gem native extension.
    current directory: /Users/username/.rbenv/versions/jruby-9.1.2.0/lib/ruby/gems/shared/gems/jruby-launcher-1.1.2-java
/Users/username/.rbenv/versions/jruby-9.1.2.0/bin/jruby -r ./siteconf20170420-3455-1f44pgz.rb extconf.rb
NameError: undefined local variable or method `r' for main:Object
  <top> at -r:1
extconf failed, exit code 1
Gem files will remain installed in /Users/username/.rbenv/versions/jruby-9.1.2.0/lib/ruby/gems/shared/gems/jruby-launcher-1.1.2-java for inspection.
Results logged to /Users/username/.rbenv/versions/jruby-9.1.2.0/lib/ruby/gems/shared/extensions/universal-java-1.7/2.3.0/jruby-launcher-1.1.2-java/gem_make.out
BUILD FAILED (OS X 10.11.6 using ruby-build 20170322)
Inspect or clean up the working tree at /var/folders/qt/xqr8qztj5tl94l0r3l9t0pm4zbpz12/T/ruby-build.20170420180901.3389
Results logged to /var/folders/qt/xqr8qztj5tl94l0r3l9t0pm4zbpz12/T/ruby-build.20170420180901.3389.log
Last 10 log lines:
    current directory: /Users/username/.rbenv/versions/jruby-9.1.2.0/lib/ruby/gems/shared/gems/jruby-launcher-1.1.2-java
/Users/username/.rbenv/versions/jruby-9.1.2.0/bin/jruby -r ./siteconf20170420-3455-1f44pgz.rb extconf.rb
NameError: undefined local variable or method `r' for main:Object
  <top> at -r:1
extconf failed, exit code 1
Gem files will remain installed in /Users/username/.rbenv/versions/jruby-9.1.2.0/lib/ruby/gems/shared/gems/jruby-launcher-1.1.2-java for inspection.
Results logged to /Users/username/.rbenv/versions/jruby-9.1.2.0/lib/ruby/gems/shared/extensions/universal-java-1.7/2.3.0/jruby-launcher-1.1.2-java/gem_make.out

这是我的操作系统

$ uname -a
Darwin username-mbp 15.6.0 Darwin Kernel Version 15.6.0: Fri Feb 17 10:21:18 PST 2017; root:xnu-3248.60.11.4.1~1/RELEASE_X86_64 x86_64

也有jruby-launcher问题,但不确定这是否只是症状:

$ gem install jruby-launcher
ERROR:  Could not find a valid gem 'jruby-launcher' (>= 0) in any repository
ERROR:  Possible alternatives: tmux_launcher, RubyRun_CE, ass_launcher, ec2launcher, jruby-ehcache

更新:使用JRUBY_OPTS中的-S选项出现是Culprit。


我在我的用户会话中未设置所有环境变量,并确保envsudo env完全匹配,但以下内容:

  • 邮件
  • logName
  • 用户
  • 用户名
  • sudo_command
  • sudo_user
  • sudo_uid
  • sudo_gid

然后使用没有sudo的用户我就可以无问题安装jruby。

现在,即使存在与问题完全相同的环境变量,我现在可以在闲暇时安装/执行jruby。仍然不知道为什么有效,或者哪个环境变量有过错。

相关内容

最新更新