こんにちは、本日はDBスキーマを管理すためのツールの一つである「Ridgepole」についてブログ投稿をします。
「rails migrate」ではなく、なぜ「Ridgepole」を使ってみたかなどの背景から、「rails migrate」からの移行手順まで記載しましたので、ぜひ最後までお読みいただければと思います。
railsのmigrateのようなDBスキーマを管理すためのツールです。クックパッドのエンジニアの方が開発され、GitHub上で公開され、gemとして簡単に組み込むことができます。
https://github.com/winebarrel/ridgepole
特徴としては、下記があります。
正直言うと、rails migrateで、現在開発中のプロジェクトであれば、全く問題はありません(笑)。また、rails migrateはrailsに標準で組み込まれているため、他の開発者の認知度も高く、railsともにコミュニティでメンテされるため、安心感もあるかもしれません。
では、なぜridgepoleを使うことにしたのか!それは、「使ってみたかった」からです。Webサイトや他社での利用事例は読み聞きしていますが、実際のプロジェクトで利用経験がなかったため、使ってみたいと思い、今のプロジェクトは一からgemやら開発方法やらを自己責任で決定できるので使ってみようと思いました。
とはいえ、それだけでは開発メンバへの説明にならないので、実用的には下記を説明しています。
1. Gemfileにridgepoleを追加
gem 'ridgepole'
2. 既に存在する DB 上のテーブル定義を Schemafile にエクスポート
「Schemafile」ひとつでと上で書いておきながら、今回はテーブル毎にスキーマファイルを分割します。(–splitオプション)
./bin/bundle exec ridgepole -c database.yml -E development --export --split --output db/schemas/Schemafile Export Schema write `db/schemas/user_favorite_contents.schema` write `db/schemas/schemas/users.schema` write `db/schemas/Schemafile`
3. db/migrateフォルダを削除
もう、rails migrateは使用しないため、潔く削除しましょう。
4. テーブル定義変更後にridgepoleの実行
./bin/bundle exec ridgepole -c config/database.yml -E development --apply -f db/schemas/Schemafile
5. おまけ:RubyMineでsyntax highlightさせる
.schemaファイル及びSchemafileファイルはrails migrate DSLと同じsyntaxですが、RubyMineの初期設定ではsyntax highlightされません。
そこで、設定を変えておくだけで視認性があがるのでやっておきましょう。(Macでの説明です。)
1. Capistrano3でのdeploy環境の基本設定をする
ここは割愛します。
2. Gemfileにcapistrano3-ridgepoleを追加
group :development, :test do gem 'capistrano' gem 'capistrano-rails' gem 'capistrano-rbenv' gem 'capistrano-bundler' gem 'capistrano3-ridgepole' gem 'capistrano3-unicorn' end
3. deploy.rbもしくは、deploy/production.rbにridgepole関連の設定を追加
set :rails_env, 'production' set :ridgepole_env, fetch(:rails_env) set :ridgepole_roles, :db set :ridgepole_schema_file, File.join(current_path, 'db/schemas', 'Schemafile') set :ridgepole_config_file, File.join(current_path, 'config', 'database.yml')
4. deploy.rbにridgepoleが実行されるように設定
after 'deploy:publishing', 'ridgepole:ridgepole_apply' namespace :ridgepole do desc 'ridgepole apply' task :ridgepole_apply do invoke 'ridgepole:apply' end end
5. その他
必要に応じてdb:migrateが実行されないようにするなどを環境に合わせて修正してもよいでしょう。
rspec実行時にmigrationのチェックがはしらないようにspec/rails_helper.rbで該当箇所をコメントアウトしておきましょう。
# Checks for pending migration and applies them before tests are run. # If you are not using ActiveRecord, you can remove this line. # ActiveRecord::Migration.maintain_test_schema!
説明としては、多少省略した部分もあるかと思いますが、DBスキーマを管理するツールを導入する際の候補の一つとして、ridgepoleも検討してみては如何でしょうか。
また、タイトルには、さらば「rails migrate」と記載していますが、rails migrateの仕組みも十分素晴らしいと思います。今回は、タイトルでのインパクトのためにこのような表現とさせていただきました。(別のプロジェクトでは「rails migrate」で運用しています!)