[英]invoking a script with fork using 'RAILS_ENV=#{Rails.env} bundle exec . . ' doesn't execute (Rails 2.1)
相当神秘的问题,但出于我自己的兴趣,我很好奇这是如何起作用的。
我有一个在Rails 2.1的旧系统上运行的cron触发的脚本
它获取要执行的任务列表。 由于每个任务可能会长时间运行,因此会使用“ fork”将任务作为后台。
我获取子进程的pid。 使用“ RAILS_ENV = Rails.env bundle exec child_script”调用该过程不起作用。 删除RAILS_ENV确实可以工作(注意:直接从命令行运行子脚本就可以了。)
job_script_path = /path/to/child_script.rb
cmd = "RAILS_ENV=#{Rails.env} bundle exec #{job_script_path}
puts "Preparing to run #{cmd}"
ppid = fork{ system(cmd) }
puts "Fetched #{ppid} as parent process"
cpmd = "ps --ppid #{ppid}"
f = IO.popen(cpmd).readlines
puts "Output of #{cpmd}:"
puts "#{f}"
始终输出:
Preparing to run RAILS_ENV=development bundle exec /path/to/child_script.rb
Fetched 1234 as parent process
Output of ps --ppid 1234
PID TTY TIME CMD
没有列出进程。
如果我放下RAILS_ENV =#{Rails.env},它就可以正常工作。 设置Rails环境强制原子性怎么样?
更新:这更多是一个Ruby问题。 我在跑 。 。 。 。 红宝石1.8.7
显然,您不能派生在Rails环境中运行的并发进程。 但是,您可以派生不依赖Rails环境的并发进程。
#Do not prepend RAILS_ENV to this, it doesn't allow concurrency (for some reason.)
cmd = "bundle exec #{job.script_path}"
logger.info "Preparing to run #{cmd}"
ppid = fork{ system(cmd) }
logger.info "Fetched #{ppid} as parent process"
剥离Rails的环境。 我没有找到确定为什么的确切资源。 Rails环境是单块的。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.