# apt-get update # apt-get install rtmpdump libav-tools swftools ruby git # gem install bundler # adduser radioarc # su - radioarc $ git clone https://github.com/yayugu/net-radio-archive.git $ cd net-radio-archive $ git submodule update --init --recursive
ここまで実行したら次のようなエラーが出る。
$ git submodule update --init --recursive Cloning into 'niconico'... Permission denied (publickey). fatal: Could not read from remote repository. Please make sure you have the correct access rights and the repository exists. Clone of 'git@github.com:yayugu/niconico.git' into submodule path 'niconico' failed
ニコ動は取らないのでとりあえず無視しておく。
$ bundle install --without development test agon
しまった。root権限を求められた。
# bundle install --without development test agon
rootで実行してみた。
Installing unf_ext 0.0.7.1 with native extensions Gem::Ext::BuildError: ERROR: Failed to build gem native extension. /usr/bin/ruby2.1 extconf.rb mkmf.rb can't find header files for ruby at /usr/lib/ruby/include/ruby.h extconf failed, exit code 1 Gem files will remain installed in /var/lib/gems/2.1.0/gems/unf_ext-0.0.7.1 for inspection. Results logged to /var/lib/gems/2.1.0/extensions/x86_64-linux/2.1.0/unf_ext-0.0.7.1/gem_make.out An error occurred while installing unf_ext (0.0.7.1), and Bundler cannot continue. Make sure that `gem install unf_ext -v '0.0.7.1'` succeeds before bundling.
何かが足りない。ruby-develって無いのかな。
Debian — Package Contents Search Results — ruby.hで調べてみた。
# apt-get install ruby-dev
ruby-devだった。
You have to install development tools first.
あー、build-essentialが入っていないか。
# apt-get install build-essential
これで、unf_ext 0.0.7.1 with native extensionsが入った。
のこぎりのインストールにしばらく時間がかかる。
Installing mysql2 0.3.17 with native extensions Gem::Ext::BuildError: ERROR: Failed to build gem native extension. /usr/bin/ruby2.1 extconf.rb checking for ruby/thread.h... yes checking for rb_thread_call_without_gvl() in ruby/thread.h... yes checking for rb_thread_blocking_region()... yes checking for rb_wait_for_single_fd()... yes checking for rb_hash_dup()... yes checking for rb_intern3()... yes 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... no 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.
lmysqlclientが足りないか。
# apt-get install libmariadb2
こうかな。
まだ足りない。
# apt-get install libmariadbd-dev
違った…
# apt-get install mariadb-client
# apt-get install libmariadb-client-lgpl-dev
これも違う…
# gem install mysql2
# apt-get install libmysqld-dev
これだとうまく行った。
どうやらmysqlにしか対応していない?
$ cp config/database.example.yml config/database.yml $ cp config/settings.example.yml config/settings.yml $ vim.tiny config/database.yml $ vim.tiny config/settings.yml
apt-get install mariadb-server
mariadbのrootパスワードの設定を求められるので、head -c 16 /dev/random | base64で生成した。
$ RAILS_ENV=production bundle exec rake db:create db:migrate Could not find gem 'niconico (>= 0) ruby' in source at niconico. Source does not contain any versions of 'niconico (>= 0) ruby'
orz
niconicoが無いとダメなのか…
困った。
SSH経由でサブモジュールを読み込むらしいが、これはSSH鍵による認証が必要だ。
SSH鍵を管理するのはなかなか面倒なんだよな。
16:56追記:
鍵を作ってgithubに登録した。
$ git submodule update --init --recursive $ RAILS_ENV=production bundle exec rake db:create db:migrate rake aborted! ExecJS::RuntimeUnavailable: Could not find a JavaScript runtime. See https://github.com/sstephenson/execjs for a list of available runtimes.
うぇ。何かが足りない。
# apt-get install nodejs
jessie標準なので古そうだが動いて欲しい。
$ RAILS_ENV=production bundle exec rake db:create db:migrate == 20150515174349 CreateJob: migrating ======================================== == 20150515174349 CreateJob: migrated (0.0141s) =============================== == 20150515174821 CreateOnsenProgram: migrating =============================== == 20150515174821 CreateOnsenProgram: migrated (0.0123s) ====================== == 20150515174949 CreateHibikiProgram: migrating ============================== == 20150515174949 CreateHibikiProgram: migrated (0.0112s) ===================== == 20150521174524 CreateAnitamaProgram: migrating ============================= == 20150521174524 CreateAnitamaProgram: migrated (0.0113s) ==================== == 20150527135411 CreateNiconicoLivePrograms: migrating ======================= == 20150527135411 CreateNiconicoLivePrograms: migrated (0.0120s) ============== == 20150602100911 NicoAddColumn: migrating ==================================== == 20150602100911 NicoAddColumn: migrated (0.0361s) =========================== == 20150607130411 KeyValue: migrating ========================================= == 20150607130411 KeyValue: migrated (0.0115s) ================================ == 20151002075432 CreateAgonProgram: migrating ================================ == 20151002075432 CreateAgonProgram: migrated (0.0146s) =======================
うまく行ったっぽい。
$ bundle exec whenever --update-crontab [write] crontab file updated
これでセットアップ完了か?
新幹線の無線LANの遅延がひどすぎて、作業がなかなか進まなかったが、なんとか完了したようだ。
アップデート
$ git pull origin master $ git submodule update --init --recursive $ bundle install --without development test agon $ RAILS_ENV=production bundle exec rake db:migrate $ bundle exec whenever --update-crontab