Rails3.2で Could not find a JavaScript runtime エラー発生対応メモ

環境を変える前は特にエラー無かったなと思ったのですが、どうやら Node.js がインストールされているとそちらを利用するそうです。

今回は Node.js をインストールする予定はないので、 gem で対応します。

環境

  • OS: Ubuntu 12.04 64bit
  • Ruby on Rails 3.2.6
  • Gem
    • execjs 1.4.0
    • therubyracer 0.10.1

rake を実行したらエラー

ちなみに rails s を実行でも同じエラーが出ました。

Terminal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
$ rake db:create --trace
rake aborted!
Could not find a JavaScript runtime. See https://github.com/sstephenson/execjs for a list of available runtimes.
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/execjs-1.4.0/lib/execjs/runtimes.rb:51:in `autodetect'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/execjs-1.4.0/lib/execjs.rb:5
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:236:in `load_dependency'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/coffee-script-2.2.0/lib/coffee_script.rb:1
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:236:in `load_dependency'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/coffee-script-2.2.0/lib/coffee-script.rb:1
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:236:in `load_dependency'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/activesupport-3.2.6/lib/active_support/dependencies.rb:251:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/coffee-rails-3.2.2/lib/coffee-rails.rb:1
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/bundler-1.1.4/lib/bundler/runtime.rb:68:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/bundler-1.1.4/lib/bundler/runtime.rb:68:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/bundler-1.1.4/lib/bundler/runtime.rb:66:in `each'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/bundler-1.1.4/lib/bundler/runtime.rb:66:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/bundler-1.1.4/lib/bundler/runtime.rb:55:in `each'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/bundler-1.1.4/lib/bundler/runtime.rb:55:in `require'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/bundler-1.1.4/lib/bundler.rb:119:in `require'
/home/nanigashi/workspace/hoge/branches/hoge/config/application.rb:7
/home/nanigashi/workspace/hoge/branches/hoge/Rakefile:5:in `require'
/home/nanigashi/workspace/hoge/branches/hoge/Rakefile:5
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/rake_module.rb:25:in `load'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/rake_module.rb:25:in `load_rakefile'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/application.rb:501:in `raw_load_rakefile'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/application.rb:82:in `load_rakefile'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/application.rb:133:in `standard_exception_handling'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/application.rb:81:in `load_rakefile'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/application.rb:65:in `run'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/application.rb:133:in `standard_exception_handling'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/lib/rake/application.rb:63:in `run'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/gems/rake-0.9.2.2/bin/rake:33
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/bin/rake:19:in `load'
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/bin/rake:19
/home/nanigashi/.rvm/gems/ruby-1.8.7-p358@global/bin/ruby_noexec_wrapper:14

javascriptの生成エンジンをインストール

javascriptの生成エンジンが無いためエラーになってるようなのでインストールします。

node.js でも問題ないようですが、利用する予定はないので今回はgemで対応します。

Gemfile に以下を記述します。

Gemfile
1
2
gem 'execjs'
gem 'therubyracer'

bundle install を実行すれば大丈夫です。

以上です。

Ubuntu + Mysql5 + Rails3.2 に mysql2 をインストールしようとしてエラー

Ubuntu + Mysql5 + Rails3.2 に mysql2 をインストールしようとしてエラーが出た時の対処メモ。

環境

  • OS: Ubuntu 12.04 64bit
  • DB: MySQL 5.5.24-0ubuntu0.12.04.1
  • Ruby on Rails 3.2.6
  • Gem
    • mysql2 0.3.11

mysql2 をインストールしようとしてエラー

mysql2 をインストールするため Gemfile に追記します。

Gemfile
1
gem 'mysql2'

いつも通り bundle install を実行するとエラーが発生して mysql2 がインストール出来ません。

Terminal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
Installing mysql2 (0.3.11) with native extensions
Gem::Installer::ExtensionBuildError: ERROR: Failed to build gem native extension.

/home/nanigashi/.rvm/rubies/ruby-1.8.7-p358/bin/ruby extconf.rb
checking for rb_thread_blocking_region()... no
checking for rb_wait_for_single_fd()... no
checking for mysql_query() in -lmysqlclient... no
checking for main() in -lm... yes
checking for mysql_query() in -lmysqlclient... no
checking for main() in -lz... yes
checking for mysql_query() in -lmysqlclient... no
checking for main() in -lsocket... no
checking for mysql_query() in -lmysqlclient... no
checking for main() in -lnsl... yes
checking for mysql_query() in -lmysqlclient... no
checking for main() in -lmygcc... no
checking for mysql_query() in -lmysqlclient... no
*** extconf.rb failed ***
Could not create Makefile due to some reason, probably lack of
necessary libraries and/or headers. Check the mkmf.log file for more
details. You may need configuration options.

Provided configuration options:
--with-opt-dir
--without-opt-dir
--with-opt-include
--without-opt-include=${opt-dir}/include
--with-opt-lib
--without-opt-lib=${opt-dir}/lib
--with-make-prog
--without-make-prog
--srcdir=.
--curdir
--ruby=/home/nanigashi/.rvm/rubies/ruby-1.8.7-p358/bin/ruby
--with-mysql-config
--without-mysql-config
--with-mysql-dir
--without-mysql-dir
--with-mysql-include
--without-mysql-include=${mysql-dir}/include
--with-mysql-lib
--without-mysql-lib=${mysql-dir}/lib
--with-mysqlclientlib
--without-mysqlclientlib
--with-mlib
--without-mlib
--with-mysqlclientlib
--without-mysqlclientlib
--with-zlib
--without-zlib
--with-mysqlclientlib
--without-mysqlclientlib
--with-socketlib
--without-socketlib
--with-mysqlclientlib
--without-mysqlclientlib
--with-nsllib
--without-nsllib
--with-mysqlclientlib
--without-mysqlclientlib
--with-mygcclib
--without-mygcclib
--with-mysqlclientlib
--without-mysqlclientlib


Gem files will remain installed in /home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/mysql2-0.3.11 for inspection.
Results logged to /home/nanigashi/.rvm/gems/ruby-1.8.7-p358@hoge_rails3/gems/mysql2-0.3.11/ext/mysql2/gem_make.out
An error occured while installing mysql2 (0.3.11), and Bundler cannot continue.
Make sure that `gem install mysql2 -v '0.3.11'` succeeds before bundling.

必要なライブラリをインストール

調べたらライブラリが足りないとのことなのでインストールします。

Terminal
1
$ sudo aptitude install libmysql-ruby libmysqlclient-dev

再度 bundle install を実行すると無事入りました。

以上です。

RVMをインストールしようとしたら「ディレクトリを作成できません」エラー対応メモ

rvm を新規にインストールしようとしたらとんでもなくハマったので対応メモ。

環境

  • OS: Ubuntu 12.04 64bit

apt 経由でインストールしてエラー

ubuntuにてaptでrvmを管理しようとすると、現行バージョンにはバグがあるらしくインストールできない。

Terminal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
$ sudo apt-get install ruby-rvm
パッケージリストを読み込んでいます... 完了
依存関係ツリーを作成しています
状態情報を読み取っています... 完了
以下の特別パッケージがインストールされます: libreadline-gplv2-dev
以下のパッケージは「削除」されます:
libreadline6-dev
以下のパッケージが新たにインストールされます:
libreadline-gplv2-dev ruby-rvm
アップグレード: 0 個、新規インストール: 2 個、削除: 1 個、保留: 0 個。
956 kB 中 0 B のアーカイブを取得する必要があります。
この操作後に追加で 2,216 kB のディスク容量が消費されます。
続行しますか [Y/n]? y
(データベースを読み込んでいます ... 現在 217049 個のファイルとディレクトリがインストールされています。)
libreadline6-dev を削除しています ...
install-info のトリガを処理しています ...
Selecting previously unselected package libreadline-gplv2-dev.
(データベースを読み込んでいます ... 現在 217022 個のファイルとディレクトリがインストールされています。)
(.../libreadline-gplv2-dev_5.2-11_amd64.deb から) libreadline-gplv2-dev を展開しています...
Selecting previously unselected package ruby-rvm.
(.../ruby-rvm_1.6.9-0ubuntu2_all.deb から) ruby-rvm を展開しています...
install-info のトリガを処理しています ...
man-db のトリガを処理しています ...
libreadline-gplv2-dev (5.2-11) を設定しています ...
ruby-rvm (1.6.9-0ubuntu2) を設定しています ...
dpkg-statoverride: error: 文法エラー: statoverride ファイルに未知のグループ 'admin' があります
dpkg: ruby-rvm の処理中にエラーが発生しました (--configure):
サブプロセス インストール済みの post-installation スクリプト はエラー終了ステータス 2 を返しました
以下のパッケージの処理中にエラーが発生しました:
ruby-rvm
E: Sub-process /usr/bin/dpkg returned an error code (1)

調べるとすぐ出てくるが、どうやらインストール時に、chown -R root:admin と実行している部分でエラーが発生している模様。
これはubuntuの場合 root:root が正しいため。
パッチあてるなりして書き換えると問題なくインストールできるようだが、aptのソースに手をあまり入れたくない人なのでそれは保留。

ソースからrvmをインストール

公式にある通りにrvmのインストール時に、$HOME/.rvm ではなく /usr/share/ruby-rvm にインストールしようとして /usr/share/ruby-rvm' permission denied などのエラーになる場合がある。

Terminal
1
2
3
4
5
6
$ curl -L get.rvm.io | bash -s stable
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 185 100 185 0 0 440 0 --:--:-- --:--:-- --:--:-- 793
100 9241 100 9241 0 0 6620 0 0:00:01 0:00:01 --:--:-- 11565
mkdir: ディレクトリ `/usr/share/ruby-rvm' を作成できません: 許可がありません

これの原因は、どうやら apt 経由でのインストール時に環境変数が書き換えられて /usr/share/ruby-rvm にインストールするように指定されてる模様。

Terminal
1
2
3
4
5
$ env |grep rvm
rvm_path=/usr/share/ruby-rvm
rvm_prefix=/usr/share
rvm_user_install_flag=0
rvm_loaded_flag=0

なので一度綺麗にする。

Terminal
1
2
3
$ sudo aptitude purge ruby-rvm
$ sudo rm -rf /usr/share/ruby-rvm /etc/rvmrc /etc/profile.d/rvm.sh
$ unset rvm_path rvm_prefix rvm_user_install_flag rvm_loaded_flag

その後通常通りインストール。

Terminal
1
2
3
4
5
6
$ curl -L get.rvm.io | bash -s stable
$ rvm requirements
$ sudo aptitude install build-essential openssl libreadline6 libreadline6-dev curl git-core zlib1g zlib1g-dev libssl-dev libyaml-dev libsqlite3-dev sqlite3 libxml2-dev libxslt-dev autoconf libc6-dev ncurses-dev automake libtool bison subversion
$ rvm -v

rvm 1.14.3 (stable) by Wayne E. Seguin <wayneeseguin@gmail.com>, Michal Papis <mpapis@gmail.com> [https://rvm.io/]

以上です。

© 2018 磁力式駆動 All Rights Reserved.
Theme by hiero