由于 ExecJS,在生产服务器上运行 Rake 任务失败

cyb*_*101 4 javascript rake ruby-on-rails node.js ruby-on-rails-4

我在 RHEL 6 机器上安装了 Rails 4 应用程序。

该产品使用 Passenger 和 Apache2。

最近,我一直在尝试使用 Every Gem 和 Cron 将 Rake 任务作为计划作业集成到生产中。

每当我尝试在生产中运行这些 Rake 任务之一时,都会收到以下错误:

rake aborted!
ExecJS::RuntimeUnavailable: Could not find a JavaScript runtime. See https://github.com/sstephenson/execjs for a list of available runtimes.
Run Code Online (Sandbox Code Playgroud)

值得一提的是,NodeJS 已安装在计算机上。我可以预编译资产等等。具体来说,该命令 node --version生成: v0.10.31

这是我的堆栈跟踪:

  rake aborted!
    ExecJS::RuntimeUnavailable: Could not find a JavaScript runtime. See https://github.com/sstephenson/execjs for a list of available runtimes.
    /var/www/eng_performance/shared/bundle/ruby/2.0.0/gems/execjs-2.2.1/lib/execjs/runtimes.rb:51:in `autodetect'
    /var/www/eng_performance/shared/bundle/ruby/2.0.0/gems/execjs-2.2.1/lib/execjs.rb:5:in `<module:ExecJS>'
    /var/www/eng_performance/shared/bundle/ruby/2.0.0/gems/execjs-2.2.1/lib/execjs.rb:4:in `<top (required)>'
    /var/www/eng_performance/shared/bundle/ruby/2.0.0/gems/activesupport-4.0.4/lib/active_support/dependencies.rb:229:in `require'
    /var/www/eng_performance/shared/bundle/ruby/2.0.0/gems/activesupport-4.0.4/lib/active_support/dependencies.rb:229:in `block in require'
    /var/www/eng_performance/shared/bundle/ruby/2.0.0/gems/activesupport-4.0.4/lib/active_support/dependencies.rb:214:in `load_dependency'
    /var/www/eng_performance/shared/bundle/ruby/2.0.0/gems/activesupport-4.0.4/lib/active_support/dependencies.rb:229:in `require'
    /var/www/eng_performance/shared/bundle/ruby/2.0.0/gems/uglifier-2.5.3/lib/uglifier.rb:3:in `<top (required)>'
    /home/deploy/.rvm/gems/ruby-2.0.0-p481/gems/bundler-1.7.2/lib/bundler/runtime.rb:76:in `require'
    /home/deploy/.rvm/gems/ruby-2.0.0-p481/gems/bundler-1.7.2/lib/bundler/runtime.rb:76:in `block (2 levels) in require'
    /home/deploy/.rvm/gems/ruby-2.0.0-p481/gems/bundler-1.7.2/lib/bundler/runtime.rb:72:in `each'
    /home/deploy/.rvm/gems/ruby-2.0.0-p481/gems/bundler-1.7.2/lib/bundler/runtime.rb:72:in `block in require'
    /home/deploy/.rvm/gems/ruby-2.0.0-p481/gems/bundler-1.7.2/lib/bundler/runtime.rb:61:in `each'
    /home/deploy/.rvm/gems/ruby-2.0.0-p481/gems/bundler-1.7.2/lib/bundler/runtime.rb:61:in `require'
    /home/deploy/.rvm/gems/ruby-2.0.0-p481/gems/bundler-1.7.2/lib/bundler.rb:133:in `require'
    /var/www/eng_performance/releases/20141014084554/config/application.rb:7:in `<top (required)>'
    /var/www/eng_performance/releases/20141014084554/Rakefile:4:in `require'
    /var/www/eng_performance/releases/20141014084554/Rakefile:4:in `<top (required)>'
    (See full trace by running task with --trace)
Run Code Online (Sandbox Code Playgroud)

注意: 我已经从源代码编译安装了 NodeJS,因为当我尝试从存储库安装时,我收到了这个错误,但我不知道如何克服:

Packages skipped because of dependency problems:
    c-ares19-1.9.1-5.el6.3.x86_64 from epel
    http-parser-2.0-4.20121128gitcd01361.el6.x86_64 from epel
    1:libuv-0.10.28-1.el6.x86_64 from epel
    nodejs-0.10.30-1.el6.x86_64 from epel
    1:v8-3.14.5.10-11.el6.x86_64 from epel
Run Code Online (Sandbox Code Playgroud)

cyb*_*101 5

好吧,终于,我能够解决这个问题了:)

事实证明,node.js 安装没有任何问题,但对它的引用却有问题。

我不知道为什么要改变这一点,但在这篇文章之后解决了问题 - 即通过添加符号链接 ln -s /usr/local/bin/node /usr/bin/node

注意:我很确定符号链接不是最佳实践。如果有人可以提出另一个想法 - 我很想听听..

希望这是我在使用 Node.js 时遇到的最后一个错误。如果发生类似的错误,therubyracer 将提供出色的备份解决方案。