Category: ‘Ruby’

Capstrano3とRuby2.2 on Rails4.2 の設定

2015年10月18日 Posted by PURGE

Capstrano3を使用しようと試しているが、かなりハマっている。
下記は覚え書き。

rbenvでrubyのバージョンが設定されていないエラー

ERROR rbenv: rbenv_ruby is not set

rbenvのパスが検出されないエラー

ERROR rbenv: 2.2.2 is not installed or not found in ~/.rbenv/versions/2.2.2

deploy.rb

## デプロイサーバのパスを記述
set :rbenv_path, '/var/rbenv'
set :rbenv_ruby, '2.2.2'
set :application, 'Sample'
set :repo_url, 'ssh://hoge@whoocus.com/path/to/git/repo/sample.git'

サーバ上でbundleが見つからないエラー

bundle stderr: rbenv: bundle: command not found

サーバ上でインストール。

gem install bundler

JavaScript runtimeが見つからないとのエラー。

JS::RuntimeUnavailable: Could not find a JavaScript runtime. See https://github.com/rails/execjs for a list of available runtimes.

Gemfile

gem 'execjs'
gem 'therubyracer', platforms: :ruby

Ruby2.X.XのCentOS6へのインストール方法

2015年10月2日 Posted by PURGE

Rubyのバージョンを管理しやすいようにrbebvを使用して最新Rubyをインストールしようと思い覚え書き。

rbenvのインストール

$ mkdir /var/rbenv
$ git clone git://github.com/sstephenson/rbenv.git
$ chmod -R 777 /var/rbenv
$ cd /var/rbenv/plugins
$ git clone git://github.com/sstephenson/ruby-build.git

環境変数設定

$ vi /etc/profile.d/rbenv.sh
export RBENV_ROOT="/var/rbenv"
export PATH="${RBENV_ROOT}/bin:${PATH}"
eval "$(rbenv init -)"

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

$ yum install -y readline-devel

Rubyのインストール

$ rbenv install 2.X.X
Installing ruby-2.X.X...

Rubyバージョンの選択

$ rbenv global 2.X.X

Rubyバージョンの確認

$ ruby --version
ruby 2.X.X (2015-08-18 revision 51636) [x86_64-linux]

成功した。

Capistrano3.x の覚え書き。

2015年9月22日 Posted by PURGE

以前といっても既に、3年程前に、Capstranoを設定していたが、既にCapstrano3.xの時代。
久しぶりに設定する機会があったので覚え書き。

Railsの設定
Gemfile にデフォルトでコメントアウトされている下記の記述を有効にして、bundle update 。

# Use Capistrano for deployment
gem 'capistrano-rails', group: :development
$ bundle update
$ capify .
--------------------------------------------------------------------------------
Capistrano 3.x is incompatible with Capistrano 2.x. 

This command has become `cap install` in Capistrano 3.x

For more information see http://www.capistranorb.com/
--------------------------------------------------------------------------------

capify . にて設定ファイルを作成しようとしたが、怒られたので、cap install を実行する。

$ cap install
mkdir -p config/deploy
create config/deploy.rb
create config/deploy/staging.rb
create config/deploy/production.rb
mkdir -p lib/capistrano/tasks
create Capfile
Capified

すると、Capfile と、config/deploy.rb、config/deploy/staging.rb、config/deploy/production.rb が作成される。

Gitのサーバ設定

Gitのインストール。

$ yum install git

Git共有リポジトリの作成。

$ mkdir /var/lib/git/public_git/sample.git
$ cd /var/lib/git/public_git/sample.git
$ git init --bare --share 

Gitのクライアント設定

$ git init
$ git add .
$ git commit -m "First commit"
$ git remote add sample ssh://User名@Host名:SSHポート番号/var/lib/git/public_git/sample.git
$ git push sample

Redmine2.1.2からRedmine3.1.0へのDB移行時のエラー

2015年8月24日 Posted by PURGE

Mysqlのダンプファイルをインポートしようとしたが、Redmineがサーバエラーを起こしていたので覚え書き。

データダンプファイルを新規のDBに移行し、新たにマイグレーション。

$ mysql redmine_db < Dmpfile.sql
$ rake db:migrate RAILS_ENV=production

エラーログを見るとマイグレーションで失敗していたようなので、下記のテーブル群が件数0件であることを確認してDROP。

drop table custom_fields_roles;
drop table queries_roles;
drop table email_addresses;
drop table roles_managed_roles;

その後も下記エラーとなったが、Redmineのサーバを再起動したら直った。

Mysql2::Error: Unknown column 'users.mail'

Redmineのファイルバックアップスクリプト

2015年8月14日 Posted by PURGE

特にエラーハンドリングしていないが、覚え書きで。

#!/bin/sh
#
# Redmine DB backup script

FILE_DIR=/app/redmine/files/
DMP_DIR=/var/tmp/
MNT_DIR=/mnt/svn/
BAK_DIR="//10.10.10.10/windows/Backup/server/dir"
PERIOD=5
DB_USER=user
DB_PASS=pass

USER_NAME=winuser
PASSWD=winpass
EXIT_STATUS=0

FILE_NAME=`date +%y%m%d`
RM_FILE_NAME=`date --date "$PERIOD days ago" +%y%m%d`

DMP_FILE=$DMP_DIR/Redmine_DB_$FILE_NAME.sql.gz
ARC_FILE=$DMP_DIR/Redmine_FILE_$FILE_NAME.tar.gz

RM_DMP_FILE=$MNT_DIR/Redmine_DB_$RM_FILE_NAME.sql.gz
RM_ARC_FILE=$MNT_DIR/Redmine_FILE_$RM_FILE_NAME.tar.gz

# ファイルサーバへマウント
mount -t cifs -o username=$USER_NAME,password=$PASSWD $BAK_DIR $MNT_DIR

# データのダンプ
mysqldump --opt --single-transaction --default-character-set=binary -u $DB_USER --password=$DB_PASS --all-databases | gzip > $DMP_FILE

# 添付ファイルのアーカイブ
tar cfvz $ARC_FILE $FILE_DIR

# ファイルの移動
mv $DMP_FILE $MNT_DIR
mv $ARC_FILE $MNT_DIR

# ファイルの削除
rm $RM_DMP_FILE
rm $RM_ARC_FILE
echo "Redmine Backup OK"

umount -l $MNT_DIR

exit $EXIT_STATUS

gem install mysql2 インストールエラー

2015年8月14日 Posted by PURGE

対象環境

  • CentOS 6.7
  • Ruby2.1
  • Rails4.1
  • MySQL Community Server 5.6.26

概要

Redmineをインストールするにあたって、MySQLをインストールし、Railsで使用するライブラリmysql2のインストールでエラーとなる。

$ gem install mysql2 -v '0.3.19'
Fetching: mysql2-0.3.19.gem (100%)
Building native extensions.  This could take a while...
ERROR:  Error installing mysql2:
        ERROR: Failed to build gem native extension.

    /usr/local/ruby2.2/bin/ruby -r ./siteconf20150814-32250-1l3iwxf.rb 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()... no
checking for rb_wait_for_single_fd()... yes
checking for rb_hash_dup()... yes
checking for rb_intern3()... yes
-----
Using mysql_config at /usr/bin/mysql_config
-----
checking for mysql.h... no
checking for mysql/mysql.h... no
-----
mysql.h is missing. Try 'apt-get install libmysqlclient-dev' or
'yum install mysql-devel', check your installation of mysql and try again.
-----
*** 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=/usr/local/ruby2.2/bin/$(RUBY_BASE_NAME)
        --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-mysql-config
        --without-mysql-config

extconf failed, exit code 1

Windows環境でハマった時の対応方法は、この記事であるが、今回の環境はまた異なるし、対応方法が異なるようだ。

そこで下記`mysql-devel`をインストール。

$ yum install mysql-devel
読み込んだプラグイン:fastestmirror, security
インストール処理の設定をしています
Loading mirror speeds from cached hostfile
 * base: ftp.iij.ad.jp
 * extras: ftp.iij.ad.jp
 * updates: centos.usonyx.net
パッケージ mysql-devel は mysql-community-devel によって不要になりました。代わりに mysql-community-devel-5.6.26-2.el6.x86_64 のインストールを試みています。
依存性の解決をしています
--> トランザクションの確認を実行しています。
---> Package mysql-community-devel.x86_64 0:5.6.26-2.el6 will be インストール
--> 依存性解決を終了しました。

依存性を解決しました

====================================================================================================
 パッケージ                    アーキテクチャ バージョン            リポジトリー               容量
====================================================================================================
インストールしています:
 mysql-community-devel         x86_64         5.6.26-2.el6          mysql56-community         3.2 M

トランザクションの要約
====================================================================================================
インストール         1 パッケージ

総ダウンロード容量: 3.2 M
インストール済み容量: 20 M
これでいいですか? [y/N]y
パッケージをダウンロードしています:
mysql-community-devel-5.6.26-2.el6.x86_64.rpm                                | 3.2 MB     00:01
rpm_check_debug を実行しています
トランザクションのテストを実行しています
トランザクションのテストを成功しました
トランザクションを実行しています
  インストールしています  : mysql-community-devel-5.6.26-2.el6.x86_64                           1/1
  Verifying               : mysql-community-devel-5.6.26-2.el6.x86_64                           1/1

インストール:
  mysql-community-devel.x86_64 0:5.6.26-2.el6

完了しました!

再度、試したら上手く行った。

$ gem install mysql2
Building native extensions.  This could take a while...
Successfully installed mysql2-0.3.19
Parsing documentation for mysql2-0.3.19
Installing ri documentation for mysql2-0.3.19
Done installing documentation for mysql2 after 1 seconds
1 gem installed

gemでのインストールエラー

2015年8月12日 Posted by PURGE

bundlerのインストール

社内プロキシの関係でインストールできない場合がある

$ gem install bundler --no-rdoc --no-ri -p http://user:password@proxy:8080
ERROR:  Could not find a valid gem 'bundler' (>= 0), here is why:
          Unable to download data from https://rubygems.org/ 
          - no such name (https://rubygems.org/specs.4.8.gz)

社内プロキシの関係でインストールできない場合は、ローカルにダウンロードしてインストールする。

$ gem install --local /usr/local/src/bundler-1.10.6.gem
Successfully installed bundler-1.10.6
Parsing documentation for bundler-1.10.6
Installing ri documentation for bundler-1.10.6
Done installing documentation for bundler after 7 seconds
1 gem installed

但し、インストール対象に依存関係がある場合は面倒くさい。

Ruby2.2.2のソースコードからのインストール

2015年8月12日 Posted by PURGE

いまどき、Rubyのインストール等は、rbenv等を使用するのが普通だが、必要があって直接ソースコンパイルしてRubyのインストールしてみた。

Rubyのダウンロード

$ curl -O https://cache.ruby-lang.org/pub/ruby/2.2/ruby-2.2.2.tar.gz
$ mv ruby-2.2.2.tar.gz /usr/local/src/

Rubyの解凍&インストール

$ tar xvf ruby-2.2.2.tar.gz
$ cd ruby-2.2.2
$ ./configure --prefix=/usr/local/ruby2.2/ --disable-install-doc
$ make
$ make install

Rubyインストール場所の確認

$ ls /usr/local/ruby2.2

Rubyをパスに追加

$ vi /etc/skel/.bash_profile
$ vi ~/.bash_profile
RUBY_HOME=/usr/local/ruby2.2
PATH=$PATH:$RUBY_HOME/bin

Rubyの確認

$ ruby -v
ruby 2.2.2p95 (2015-04-13 revision 50295) [x86_64-linux]

初めてのRake

2015年5月13日 Posted by PURGE

Rakefileというファイルに下記を記述する。

desc 'Make Dir'
task :make_dir do
  tm = Time.now.strftime('%Y%m%d%H%M%S')
  sh "mkdir #{tm}"
end

Rakefileを作成したディレクトリで下記コマンドを打つと、タスクの一覧が表示される。

C:\RakeSample>rake -T
rake mkdir_dir   # Make Dir

タスクの実行はタスク名を指定してrakeコマンドを打つ。

C:\RubySample>rake make_dir
mkdir 20150513204035

時間のディレクトリが作成される。

database.yml 等の Git管理

2014年11月18日 Posted by PURGE

Railsプロジェクトを作成し、Git等のバージョン管理システムを使用してプロジェクトをそのまま git add、git commitしてしまい公開してしまうことがある。しかし、セキュリティ上思わしくない設定ファイル等がある。

database.ymlやsecrets.yml等だ。

そこで一度バージョン管理に入れてしまった場合に、バージョン管理から外す方法。

$ git rm --cached database.yml

–cachedオプションを使用しないと、ファイル自体削除されてしまうので注意。

そして再びバージョン管理されないように.gitignoreに下記を必ず追記する。

/config/database.yml

プロジェクトをチームで共有する場合には、database.ymlをコピーしてdatabase.yml.sample等を作成し、これをバージョン管理しておく方法がよい。当然、その中身に重要情報を記述してしまっては意味が無いので注意。

ちなみに、万が一–cachedオプションを使用しないで、ファイル自体を削除して焦ってしまった時のリカバリ方法。

$ git reset HEAD database.yml
$ git checkout database.yml

これは参考までに覚え書き。