Home Software Libraries Ruby rails Railsを用いた運用中のサービスのアップグレードの仕方 @wakairo 18 Apr, 2023 02:29 +00:00 Last edited 25 Apr, 2023 04:14 +00:00 まずはRubyをアップグレード 「RubyのアップグレードとRailsのアップグレードは別々に行うのがよい方法です。最初にRubyを可能な限り最新版にアップグレードし、それからRailsをアップグレードします。」 Railsガイドより 次にRailsを1つずつアップグレード 「Railsのバージョンを変更する場合、マイナーバージョンを1つずつゆっくりと上げながら、その都度表示される非推奨機能の警告メッセージを上手に利用するのがベストです。」Railsガイドより 具体的には、以下の手順を繰り返す。 テストを書き、テストがパスすることを確認する。 現時点のバージョンのパッチバージョンを最新のパッチに移行する。 テストを修正し、非推奨の機能を修正する。 次のマイナーバージョンの最新パッチに移行する。 マイナーバージョン以上を上げる場合、Gemfileに記載されているRailsのバージョンを更新した後にbin/rails app:updateを実行して設定等を最新のバージョンに合わせる。参考:1.4 アップデートタスク、1.5 フレームワークのデフォルトを設定する
Home Software Libraries Ruby rails ファイル名とクラス名の対応関係などが命名規則に従っているかのチェック方法 @wakairo 08 Feb, 2023 12:51 +00:00 Last edited 08 Feb, 2023 12:52 +00:00 Railsでは、自動で定数の読み込みと再読み込みが行われます。 この自動システムをきちんと動作させるには、ファイルパス・ファイル名とモジュール構造・クラス名を命名規則に従って対応させる必要があります。 Railsガイドによれば、 以下のコマンドを実行することでこの命名規則に従っているかの確認を行えます。 bin/rails zeitwerk:check このコマンドの実行結果の末尾に「All is good!」が表示されれば命名規則は守られています。
Home Software Libraries Ruby zeitwerk Rails7以降はZeitwerkに完全移行 @wakairo 08 Feb, 2023 02:13 +00:00 Rails 6でZeitwerkが導入され、Rails 7でclassicと呼ばれる旧来のオートローダーは廃止されました。 以下は、 https://railsguides.jp/classic_to_zeitwerk_howto.html からの引用です。 Railsは最初期からRails 5まで、Active Supportで実装されたオートローダーを用いていました。このオートローダーはclassicと呼ばれ、Rails 6.xでは引き続き利用可能です。classicオートローダーはRails 7で廃止されました。 Rails 6から、より優れた新しいオートロード方法がRailsに搭載されました。これはZeitwerkというgemに一任されています。これがzeitwerkモードです。デフォルトでは、Railsフレームワーク6.0および6.1の読み込みはzeitwerkモードで実行され、Rails 7で利用できるのはzeitwerkモードのみとなります。
Home Software Libraries Ruby actionpack redirect_backよりもredirect_back_or_toを使った方が良さそう @wakairo 06 Feb, 2023 14:33 +00:00 以下のコードから分かるとおり、redirect_backはredirect_back_or_toをラップしているだけです。 https://github.com/rails/rails/blob/v7.0.4/actionpack/lib/action_controller/metal/redirecting.rb#L96 普通はfallback_locationを指定する必要があるはずですので、第1引数にfallback_locationを指定してredirect_back_or_toを呼び出した方が素直のように思います。
Home Software Libraries Ruby activerecord unscopeはscope系以外の条件も外す @wakairo 06 Feb, 2023 01:42 +00:00 Last edited 06 Feb, 2023 02:03 +00:00 RailsのActive Recordには、scopeやdefault_scopeという機能があり、SQLクエリの条件を指定してあらかじめ付けておくことが可能です。 unscopeやunscopedは、これらのscope系で付けた条件を外すことが出来ます。 ただ、注意点として、scope系以外で付けた条件も外してしまいます。 以下に例を示します。 irb(main):001:0> puts User.where(id: 1).all.to_sql SELECT "users".* FROM "users" WHERE "users"."id" = 1 => nil irb(main):002:0> puts User.where(id: 1).unscope(:where).all.to_sql SELECT "users".* FROM "users" => nil irb(main):003:0> puts User.where(id: 1).unscoped.all.to_sql SELECT "users".* FROM "users" => nil unscopeやunscopedが、直前のwhere句で指定した条件を外していることが確認できます。 確認した環境 Rails 7.0.4 参考 Railsガイド:Active Record クエリインターフェイス:9 条件を上書きする
Railsを用いた運用中のサービスのアップグレードの仕方
まずはRubyをアップグレード
「RubyのアップグレードとRailsのアップグレードは別々に行うのがよい方法です。最初にRubyを可能な限り最新版にアップグレードし、それからRailsをアップグレードします。」 Railsガイドより
次にRailsを1つずつアップグレード
「Railsのバージョンを変更する場合、マイナーバージョンを1つずつゆっくりと上げながら、その都度表示される非推奨機能の警告メッセージを上手に利用するのがベストです。」Railsガイドより
具体的には、以下の手順を繰り返す。
bin/rails app:update
を実行して設定等を最新のバージョンに合わせる。参考:1.4 アップデートタスク、1.5 フレームワークのデフォルトを設定するファイル名とクラス名の対応関係などが命名規則に従っているかのチェック方法
Railsでは、自動で定数の読み込みと再読み込みが行われます。 この自動システムをきちんと動作させるには、ファイルパス・ファイル名とモジュール構造・クラス名を命名規則に従って対応させる必要があります。
Railsガイドによれば、 以下のコマンドを実行することでこの命名規則に従っているかの確認を行えます。
このコマンドの実行結果の末尾に「All is good!」が表示されれば命名規則は守られています。
Rails7以降はZeitwerkに完全移行
Rails 6でZeitwerkが導入され、Rails 7でclassicと呼ばれる旧来のオートローダーは廃止されました。
以下は、 https://railsguides.jp/classic_to_zeitwerk_howto.html からの引用です。
redirect_backよりもredirect_back_or_toを使った方が良さそう
以下のコードから分かるとおり、
redirect_back
はredirect_back_or_to
をラップしているだけです。https://github.com/rails/rails/blob/v7.0.4/actionpack/lib/action_controller/metal/redirecting.rb#L96
普通は
fallback_location
を指定する必要があるはずですので、第1引数にfallback_location
を指定してredirect_back_or_to
を呼び出した方が素直のように思います。unscopeはscope系以外の条件も外す
RailsのActive Recordには、
scope
やdefault_scope
という機能があり、SQLクエリの条件を指定してあらかじめ付けておくことが可能です。unscope
やunscoped
は、これらのscope系で付けた条件を外すことが出来ます。ただ、注意点として、scope系以外で付けた条件も外してしまいます。
以下に例を示します。
unscope
やunscoped
が、直前のwhere
句で指定した条件を外していることが確認できます。確認した環境
参考