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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Ruby on Rails

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

Q&A

解決済

1回答

1411閲覧

【Rails】pumaをforkしてバックグラウンドでpythonスクリプトを動かす。

ninginnn

総合スコア35

Ruby on Rails

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

0グッド

0クリップ

投稿2019/05/26 02:08

編集2019/05/26 02:23

やりたいこと

pumaをforkしてバックグラウンドでpythonスクリプトを動かす。

やったこと

この記事
を参考にJobTaskを作った。

Ruby

1class JobTask 2 class << self 3 def execute(~~, ~~) 4 return execute_job(~~, ~~) 5 end 6 7 def cancel(pid) 8 command = "ps -p #{pid} -o \"pgid\"" 9 pgid = system_command(command).lines.to_a.last.lstrip.chomp 10 if pgid =~ /[0-9]/ 11 system_command "kill -TERM -#{pgid}" 12 return true 13 else 14 Rails.logger.error 'Process was not found' 15 end 16 end 17 private 18 19 def create_command(~~, ~~) 20 #command = <<-"EOS" 21 #debugger 22 command = "python3 ○○.py"+" "+~~.to_s()+" "+~~ 23 #EOS 24 script_path = "tmp/test_command" 25 #debugger 26 File.open(script_path, "w", 0750) do |f| 27 f.write command 28 end 29 30 # execute background and return pid 31 "#{script_path} > tmp/test.log 2>&1 & echo $!" 32 end 33 34 def execute_job(~~, ~~) 35 begin 36 fork do 37 Process.setsid 38 pid = system_command(create_command(~~, ~~)).lstrip.chomp 39 if pid =~ /[0-9]/ 40 pid 41 else 42 Rails.logger.error 'command has not pid' 43 "error" 44 end 45 end 46 rescue => e 47 Rails.logger.error e.message 48 "error" 49 end 50 end 51 52 def system_command(command) 53 `#{command}` 54 end 55 end 56end

controllerで上のタスクを実行するように書いた

Ruby

1def job 2 ~~ 3 pid = JobTask.execute(~, ~) 4 ~~ 5end

詰まっているところ

この記事を参考に,
本番環境でコントローラー上でpid = JobTask.execute(~, ~)を実行したが、python3が見つからない。というエラーが出た。tmp/test_command: line 1: python3: command not found

開発環境では動作する
本番環境でrails s -b 0.0.0.0 -p 3000をして、そこのサーバー上で起動した場合も動作する
本番環境でコマンド入力でJobTask.execute(~, ~)した場合も動作する

なぜ、本番環境だけでエラーが出るのかがわからない。ご教授願いたいです。pumaに問題があるのだとは思います。
python3 --version
>> python 3.6.3

puma.rbの設定は以下の通りです。

Ruby

1threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }.to_i 2threads threads_count, threads_count 3 4port ENV.fetch("PORT") { 3000 } 5 6environment 'production' 7environment ENV.fetch("RAILS_ENV") { "development" } 8 9workers 1 10preload_app! 11 12before_fork do 13 PumaWorkerKiller.config do |config| 14 # サーバのメモリ(1024MB) 15 config.ram = 1024 16 17 # 確認頻度(5秒毎) 18 config.frequency = 5 19 20 # workerを再起動する閾値(メモリ使用量が65%になったらkill) 21 # 一番メモリ使用量の多いworkerを再起動する 22 config.percent_usage = 0.65 23 24 # rolling_restartの頻度(12時間に1回) 25 # rolling_restart: メモリ使用量に関係なく、順番にworkerを再起動する仕組み 26 config.rolling_restart_frequency = 12 * 3600 27 28 # falseにすると監視ログを止める 29 # 普通のログに混ざって紛らわしい 30 config.reaper_status_logs = true 31 32 end 33 PumaWorkerKiller.start 34end 35plugin :tmp_restart

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

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

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

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

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

guest

回答1

0

自己解決

/home/ec2-user/.pyenv/shims/python3
フルパスで実行するのと
実行権限を与えるとうまくいきました。
なぜ本番環境のコントローラーで実行するときだけ、フルパスで指定しなければいけないのか
疑問は残っています。

投稿2019/05/26 05:03

ninginnn

総合スコア35

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問