13

当我尝试将 chef-solr 作为服务启动时,它失败并出现以下错误

# service chef-solr start
Starting chef-solr: /usr/bin/env: ruby_noexec_wrapper: No such file or directory
                                                       [FAILED]

但是当我从命令行手动运行它时,它运行成功

# chef-solr -d -c /etc/chef/solr.rb -L /var/log/chef/solr.log -P /var/run/chef/solr.pid
# echo $?
0
# ps -ef | grep chef
root      2691     1 12 04:19 ?        00:00:01 java -Xmx256M -Xms256M -Dsolr.data.dir=/var/lib/chef/solr/data -Dsolr.solr.home=/var/lib/chef/solr/home -jar /var/lib/chef/solr/jetty/start.jar

这是我的 rvm 信息

# rvm info

ruby-1.9.3-p194:

  system:
    uname:       "Linux Console 2.6.32-220.el6.x86_64 #1 SMP Wed Nov 9 08:03:13 EST 2011 x86_64 x86_64 x86_64 GNU/Linux"
    bash:        "/bin/bash => GNU bash, version 4.1.2(1)-release (x86_64-redhat-linux-gnu)"
    zsh:         " => not installed"

  rvm:
    version:      "rvm 1.15.6 (stable) by Wayne E. Seguin <wayneeseguin@gmail.com>, Michal Papis <mpapis@gmail.com> [https://rvm.io/]"
    updated:      "7 hours 1 minute 51 seconds ago"

  ruby:
    interpreter:  "ruby"
    version:      "1.9.3p194"
    date:         "2012-04-20"
    platform:     "x86_64-linux"
    patchlevel:   "2012-04-20 revision 35410"
    full_version: "ruby 1.9.3p194 (2012-04-20 revision 35410) [x86_64-linux]"

  homes:
    gem:          "/usr/local/rvm/gems/ruby-1.9.3-p194"
    ruby:         "/usr/local/rvm/rubies/ruby-1.9.3-p194"

  binaries:
    ruby:         "/usr/local/rvm/rubies/ruby-1.9.3-p194/bin/ruby"
    irb:          "/usr/local/rvm/rubies/ruby-1.9.3-p194/bin/irb"
    gem:          "/usr/local/rvm/rubies/ruby-1.9.3-p194/bin/gem"
    rake:         "/usr/local/rvm/gems/ruby-1.9.3-p194/bin/rake"

  environment:
    PATH:         "/usr/local/rvm/gems/ruby-1.9.3-p194/bin:/usr/local/rvm/gems/ruby-1.9.3-p194@global/bin:/usr/local/rvm/rubies/ruby-1.9.3-p194/bin:/usr/local/rvm/bin:/usr/lib64/qt-3.3/bin:/usr/java/default/bin:/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/usr/sbin:/usr/bin:/root/bin"
    GEM_HOME:     "/usr/local/rvm/gems/ruby-1.9.3-p194"
    GEM_PATH:     "/usr/local/rvm/gems/ruby-1.9.3-p194:/usr/local/rvm/gems/ruby-1.9.3-p194@global"
    MY_RUBY_HOME: "/usr/local/rvm/rubies/ruby-1.9.3-p194"
    IRBRC:        "/usr/local/rvm/rubies/ruby-1.9.3-p194/.irbrc"
    RUBYOPT:      ""
    gemset:       ""

下面是对应的环境变量

declare -x GEM_HOME="/usr/local/rvm/gems/ruby-1.9.3-p194"
declare -x GEM_PATH="/usr/local/rvm/gems/ruby-1.9.3-p194:/usr/local/rvm/gems/ruby-1.9.3-p194@global"
declare -x IRBRC="/usr/local/rvm/rubies/ruby-1.9.3-p194/.irbrc"
declare -x MY_RUBY_HOME="/usr/local/rvm/rubies/ruby-1.9.3-p194"
declare -x PATH="/usr/local/rvm/gems/ruby-1.9.3-p194/bin:/usr/local/rvm/gems/ruby-1.9.3-p194@global/bin:/usr/local/rvm/rubies/ruby-1.9.3-p194/bin:/usr/local/rvm/bin:/usr/lib64/qt-3.3/bin:/usr/java/default/bin:/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/usr/sbin:/usr/bin:/root/bin"
declare -x RUBY_VERSION="ruby-1.9.3-p194"

如何解决这个问题?

4

5 回答 5

24

确保所有变量都设置正确,尤其是PATHand GEM_PATH,您可以使用此代码为您设置环境:

source /usr/local/rvm/environments/ruby-1.9.3-p194

chef-solr在运行之前将其添加到服务中

于 2012-08-26T05:03:36.237 回答
4

我的问题很相似,我的回答也是:

我的问题是

Permission denied - /usr/local/rvm/gems/ruby-1.9.3-p194/bin/ruby_noexec_wrapper

ruby_noexec_wrapperruby-1.9.3-p194@global不在列出的路径中

我的解决方案是

source /usr/local/rvm/environments/ruby-1.9.3-p194@global

我赞成 mpapis,因为他的回答对于找到我的答案至关重要。随意支持他而不是我。只需添加一个额外的答案来尝试帮助有类似问题的任何人。

于 2012-12-03T02:49:08.800 回答
1

答案与厨师无关,但将来可能会有所帮助。

我有一个类似的问题,但是因为我正在按照教程在 RVM 中设置瘦。我通过使用 RVM 为瘦服务生成的包装器进行了修复

/home/thin/.rvm/bin/bootup_thin

因此更改了初始化脚本中的行

DAEMON=/home/thin/.rvm/gems/ree-1.8.7-2012.02/bin/thin

DAEMON=/home/thin/.rvm/bin/bootup_thin

发布在 RVM 包装器RVM 和瘦、root 与本地用户

于 2013-02-24T16:44:21.537 回答
0

我尝试了所有这些答案,都失败了。但我找到了解决这个问题的另一种方法,可能会有所帮助:

gem install rubygems-bundler

您还可以从noexec 库中找到答案

于 2013-07-30T18:11:04.307 回答
0

在我的 Mac 上安装 ruby​​ 2.0 后,我遇到了这个问题。部分原因是我安装了最新的 rvm

rvm get stable

然后我开始收到这个错误。也许我在这之后跑了一些'gemset pristine'。

无论如何,对我来说,这行得通。警告!如果您按照我的方式进行操作,您的红宝石宝石将被完全移除并重建。也许你想要一个新的备份?但这就是锤子。

# WARNING!!! THIS RECIPE IS POTENTIALLY DESTRUCTIVE!
rvm remove ruby-1.9.3-p194 # this will remove the gemsets for this version as well
rvm install ruby-1.9.3-p194 # time for coffee
rvm use ruby-1.9.3-p194
rvm gemset create aura-rover-config # my gemset name
rvm use ruby-1.9.3-p194@aura-rover-config # do I need to do this?  Can't 'member
bundle
# now it all works

有趣的是,我在安装的 gemsets 中做的所有小技巧,都被吹走了。进行备份

于 2015-02-13T18:31:50.190 回答