カテゴリー: BackEnd

configに追記したのに、rails runnerが起動しない?

はじめに

tonnyです。
最近はVue.js関連の記事を書いておりましたが、今回はRailsに関して困ったことを記載したいと思います。
割と短めです。

環境

  • Ruby: 2.4.1
  • Ruby on Rails: 5.1.3
  • Mac OS X: 10.10.5

rails runnerを使用してみる

rails runnerコマンドは、Railsでバッチ処理する際に使用します。
すでに多くの方が記事にされておりますので、簡単にまとめたいと思います。
runner (リファレンス)

バッチファイルの作成

バッチファイルを作成します。
人や組織によるかと思いますが、lib/tasks以下に作成することが一般的なようです。
簡単なバッチを作成します。

class Tasks::Test
  def self.execute
    p 'Test'
  end
end

configにパスを追記

libはRailsで自動的にロードされないので、config/application.rbに追記してあげます。

config.autoload_paths += Dir["#{config.root}/lib"]

実行

これでパスに追加されたので、下記のコマンドで実行します。

$ ./bin/rails runner "Tasks::Test.execute"
Test!!

ところが…

configに追記しているはずなのに、いつまでたっても`uninitialized constant`のエラーが消えません。

ちなみに、autoload_pathを確認するコマンドは下記になります。

$ ./bin/rails r 'puts ActiveSupport::Dependencies.autoload_paths'

解決方法

結論からいうと、rails runnerコマンドの裏で動いているSpringが悪さをしていたようです。
こちらの記事を参考にさせていただきました。
rails runnerでconfig設定値が再読み込みされない問題の対処方法

$ Spring stop

詳細はよく分かっておりませんが、Spring経由で実行するとキャッシュ?されてしまうのかな、と思っています。

おまけ(runnerコマンドでバッチに引数を渡す)

あまりやらないかもしれませんが、コマンドからバッチに引数を渡す場合は、""で囲います。

$ ./bin/rails runner "Tasks::Test.execute('hogehoge')"
class Tasks::Test
  def self.execute(word)
    p word
  end
end

さいごに

今回はRailsのエラーに関する備忘録になります。

私自身が困ったエラーも今後はまとめていこうと思いますので、よろしくお願いします。

naoki85

シェア
執筆者:
naoki85
タグ: Rails

最近の投稿

フロントエンドで動画デコレーション&レンダリング

はじめに 今回は、以下のように…

3週間 前

Goのクエリビルダー goqu を使ってみる

はじめに 最近携わっているとあ…

1か月 前

【Xcode15】プライバシーマニフェスト対応に備えて

はじめに こんにちは、suzu…

2か月 前

FSMを使った状態管理をGoで実装する

はじめに 一般的なアプリケーシ…

3か月 前