質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.35%
cron

cronは、Unix系OS上でデーモンプロセスとして動作する、スクリプトの自動実行が可能なジョブスケジューラです。

Ruby

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

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Ruby on Rails

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

バージョン管理

バージョン管理はコンピューター上にファイルとして格納されているドキュメント・プログラム・その他の情報の変更履歴等を管理するものです

Q&A

解決済

2回答

3327閲覧

Wheneverとcronを使用した時にbundlerがおかしくなる

launingcat

総合スコア10

cron

cronは、Unix系OS上でデーモンプロセスとして動作する、スクリプトの自動実行が可能なジョブスケジューラです。

Ruby

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

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Ruby on Rails

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

バージョン管理

バージョン管理はコンピューター上にファイルとして格納されているドキュメント・プログラム・その他の情報の変更履歴等を管理するものです

1グッド

2クリップ

投稿2020/03/21 07:48

編集2020/03/30 00:08

前提・実現したいこと

【バージョン】
・macOS Catalina 10.15.3
・ruby : 2.6.5p114
・rails : 5.1.7
・bundler : 2.1.4
・zsh

wheneverとcronを使用した際に定期実行はされているが、下記エラーの為正しく処理ができず詰まっております。
下記エラーの解消方法や関連エラーについて知見ございましたらご教示いただきたいです。

発生している問題・エラーメッセージ

/System/Library/Frameworks/Ruby.framework/Versions/2.6/usr/lib/ruby/2.6.0/rubygems.rb:283:in `find_spec_for_exe': Could not find 'bundler' (2.1.4) required by your /Users/my_name/develop/app_name/Gemfile.lock. (Gem::GemNotFoundException) To update to the latest version installed on your system, run `bundle update --bundler`. To install the missing version, run `gem install bundler:2.1.4` from /System/Library/Frameworks/Ruby.framework/Versions/2.6/usr/lib/ruby/2.6.0/rubygems.rb:302:in `activate_bin_path' from /usr/bin/bundle:23:in `<main>'

該当のソースコード

% which bundler /Users/my_name/.rbenv/shims/bundler % which ruby /Users/my_name/.rbenv/shims/ruby
#Gemfile.lock BUNDLED WITH 2.1.4

#追記事項

#crontab -l SHELL=/usr/local/bin/zsh # Begin Whenever generated tasks for: /Users/my_name/develop/app_name/config/schedule.rb at: 2020-03-30 07:49:19 +0900 PATH=/Users/my_name/develop/app_name/vendor/bundle/ruby/2.6.0/bin:/Users/my_name/.rbenv/versions/2.6.5/bin:/usr/local/Cellar/rbenv/1.1.2/libexec:/Users/my_name/.rbenv/shims:/usr/local/opt/libxml2/bin:/usr/local/bin:/Users/my_name/.pyenv/shims:/Users/my_name/.zplug/bin:/usr/bin:/bin:/usr/sbin:/sbin * * * * * source $HOME/.zshrc; $(which zsh) -l -c 'cd /Users/my_name/develop/app_name && RAILS_ENV=development bundle exec rake tweet:text --silent >> /Users/my_name/develop/app_name/log/cron.log 2>&1' # End Whenever generated tasks for: /Users/my_name/develop/app_name/config/schedule.rb at: 2020-03-30 07:49:19 +0900

ruby

1#/config/schedule.rb 2 3require File.expand_path(File.dirname(__FILE__) + "/environment") 4 5set :environment, Rails.env.to_sym 6env :PATH, ENV['PATH'] 7set :output, "#{Rails.root.to_s}/log/cron.log" 8set :job_template, "source $HOME/.zshrc; $(which zsh) -l -c ':job'" 9job_type :runner, "cd :path && bundle exec rails runner -e :environment ':task' :output" 10 11every 1.minute do 12 rake "tweet:text" 13end 14

ruby

1#/tasks/tweet.rake 2namespace :tweet do 3 4 desc "テスト..." 5 task :text => :environment do 6 logger = Logger.new 'log/test.log' 7 p "ここまでOK" 8 end 9 10end

試したこと

gem install bundler:2.1.4
bundle update --bundler
rubyの再インストール
bundlerの再インストール...etc

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

gnx_vw903👍を押しています

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

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

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

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

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

guest

回答2

0

自己解決

ruby

1#/config/schedule.rb 2set :job_template, "/bin/zsh -l -c ':job'" 3job_type :rake, "export PATH=\"$HOME/.rbenv/bin:$PATH\"; eval \"$(rbenv init -)\"; cd :path && RAILS_ENV=:environment bundle exec rake :task :output"

schedule.rb内でrbenvを初期化することで解決しました。

投稿2020/03/31 22:07

launingcat

総合スコア10

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

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

0

cron や whenever から bundle などを実行する際に、rbenv の設定が効いてないと思われます。
参考: rbenv 管理下のruby script をcron から実行する (備忘録) - Qiita
参考: zsh+rbenv+crontab @wheneverで「no such file to load -- bundler/setup (LoadError)」等のエラー回避法 - Qiita


source $HOME/.zshrc; は zsh -c の引数の中に書く必要がある気がします。

* * * * * $(which zsh) -l -c 'source $HOME/.zshrc; cd /Users/my_name/develop/app_name && RAILS_ENV=development bundle exec rake tweet:text --silent >> /Users/my_name/develop/app_name/log/cron.log 2>&1'
set :job_template, "$(which zsh) -l -c 'source $HOME/.zshrc; :job'"

投稿2020/03/23 06:45

編集2020/03/30 00:17
hoshi-takanori

総合スコア7901

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

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

launingcat

2020/03/29 23:20

上記記事参考に修正したのですがエラー内容は変わらずでした。 rbenvの設定を効くようにしたく試行錯誤してる内にログも吐かなくなってしまった状況です
hoshi-takanori

2020/03/29 23:24

cron や whenever の設定内容を教えてください。
launingcat

2020/03/29 23:45

追記事項の項目に内容追加させていただきました。
launingcat

2020/03/30 00:17

※追記事項のzsh使用に関する記述をschedule.rbとcrontabの中から削除したらログは出力されるように戻りました。エラーは質問時同様のものが吐かれております。
launingcat

2020/03/30 00:31

source $HOME/.zshrc;を引数の中に書く形で修正しましたがログ出力もなくなる形になりました。この場合zshの権限がcronに対して効いてないのでしょうか?
hoshi-takanori

2020/03/30 00:36

もしかして、bundle exec に --silent を指定すると何も出力しないのでは。
launingcat

2020/03/30 01:11

--silentの記述を消しましたがzshではログが出力されませんでした
launingcat

2020/03/30 04:30

set :job_template, "/bin/zsh -l -c ':job'"に変更したらzshでもログ出力はできました。 rbenvの設定が効かない問題については継続して検証中です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問