🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

2179閲覧

【rails】gem wheneverを実行するもエラーが出てしまう。

hurousyotoku500

総合スコア27

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

Ruby on Rails 6は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2021/01/29 14:16

railsアプリにおいて、定期実行したい処理があり、wheneverを使おうとしておりますが、エラーが出て困っております。
基本的には、こちらのリンクを参考にすすめております。

https://kyoto-diary.com/rails-whenever-cron/

まずは簡単な処理からと思い、このように書いております。
1分ごとにputs "hoge"します。

ruby

1#lib/tasks/test.rake 2 3namespace :test do 4 desc 'test' 5 task test: :environment do 6 logger = Logger.new 'log/test.log' 7 puts 'hoge' 8 end 9end

ruby

1# config/schedule.rb 2set :output, 'log/crontab.log' 3set :environment, ENV['RAILS_ENV'] 4 5every 1.mininute do 6 rake "test:test" 7end

rails -Tを実行すると、問題なく下記表示されました。
rails test:test # test

crontab -eを実行すると、下記表示されました。問題なさそうです。

# Begin Whenever generated tasks for: /Users/***/rails/golfscore/config/schedule.rb at: 2021-01-29 22:43:07 +0900 * * * * * /bin/bash -l -c 'cd /Users/***/rails/golfscore && RAILS_ENV=production bundle exec rake test:test --silent >> log/crontab.log 2>&1' # End Whenever generated tasks for: /Users/***/rails/golfscore/config/schedule.rb at: 2021-01-29 22:43:07 +0900 ~ ~ ~ ~ ~ "/tmp/crontab.aeGyjbmox6" 6L, 380C

で、log/crontab.logを確認すると、このようなエラーがでました。
開発環境では、MySQLを使用しています。本番環境はPGですが、gemがインストールされていないと言っている思うのですが、ひとまず開発環境でのみ、MySQLのまま実行したいのですが、その場合はどこで設定すればよろしいでしょうか。

rake aborted! LoadError: Error loading the 'postgresql' Active Record adapter. Missing a gem it depends on? pg is not part of the bundle. Add it to your Gemfile. /Users/***/rails/golfscore/vendor/bundle/ruby/2.6.0/gems/activerecord-6.0.3.4/lib/active_record/connection_adapters/postgresql_adapter.rb:4:in `<main>' 略 ・ ・ ・ Caused by: Gem::LoadError: pg is not part of the bundle. Add it to your Gemfile. /Users/***/rails/golfscore/vendor/bundle/ruby/2.6.0/gems/activerecord-6.0.3.4/lib/active_record/connection_adapters/postgresql_adapter.rb:4:in `<main>' 略 ・ ・ ・ Tasks: TOP => test:test => environment

gemfile

source 'https://rubygems.org' git_source(:github) { |repo| "https://github.com/#{repo}.git" } ruby '2.6.6' # Bundle edge Rails instead: gem 'rails', github: 'rails/rails' gem 'rails', '~> 6.0.3', '>= 6.0.3.4' # Use mysql as the database for Active Record gem 'mysql2', '>= 0.5.3' # Use Puma as the app server gem 'puma', '~> 4.1' # Use SCSS for stylesheets gem 'sass-rails', '>= 6' # Transpile app-like JavaScript. Read more: https://github.com/rails/webpacker gem 'webpacker', '~> 4.0' # Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks gem 'turbolinks', '~> 5' # Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder gem 'jbuilder', '~> 2.7' gem 'bootsnap', '>= 1.4.2', :require => false gem 'tzinfo-data', :platforms => [:mingw, :mswin, :x64_mingw, :jruby] gem 'devise' gem 'carrierwave' gem 'kaminari' gem 'bullet', :group => :development gem 'parser', '>= 2.7.1.5' gem 'whenever', require: false gem 'active_decorator' gem 'pry-rails' gem 'jquery-rails' gem "foreman" gem "bootstrap-sass", "~>3.3.6" gem "jquery-ui-rails" group :development do gem 'web-console', '>= 3.3.0' gem 'listen', '~> 3.2' gem 'spring' gem 'spring-watcher-listen', '~> 2.0.0' gem 'rubocop', :require => false gem 'rubocop-performance', :require => false gem 'rubocop-rails', :require => false gem 'rubocop-rspec' gem "better_errors" gem "binding_of_caller" end group :test do gem 'capybara', '>= 2.15' gem 'selenium-webdriver' gem 'webdrivers' gem 'webmock' end group :production do gem 'pg', '>= 0.18', '< 2.0' end group :development, :test do gem 'byebug', :platforms => [:mri, :mingw, :x64_mingw] gem 'rspec-rails', '~> 3.6' gem 'spring-commands-rspec' gem 'factory_bot_rails', '~> 4.11' gem 'guard-rspec' gem 'vcr' end

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

wheneverで発行したcronのRAILS_ENVがproductionになっているからproductionの設定を読み込んでしまってるんではないかと。

* * * * * /bin/bash -l -c 'cd /Users/***/rails/golfscore && RAILS_ENV=production bundle exec rake test:test --silent >> log/crontab.log 2>&1'

なのでRAILS_ENVが開発環境のENV(たぶんdevelopment)となるように実行すればいいんじゃないでしょうか。

RAILS_ENV=development whenever --update-crontab

投稿2021/01/29 15:55

schindler

総合スコア112

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hurousyotoku500

2021/01/30 01:14

出来ました!ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問