我们希望从cron作业运行Rails脚本(例如rails runner -e生产脚本/ test.rb),但它会自动失败。该脚本在从命令行运行时独立运行。在cron工作中运行Rails脚本?
这里是我们的crontab行:(此设定在晚上11:40)
45 23 * * * rails runner -e production /home/t/T/script/ia.rb
我们做错了什么在运行这个Rails的从cron作业脚本?
谢谢!
日志文件的内容(服药后伊万的建议):
[[email protected] T]# cat script/script.log
Usage:
rails new APP_PATH [options]
Options:
-r, [--ruby=PATH] # Path to the Ruby binary of your choice
# Default: /usr/local/bin/ruby
-d, [--database=DATABASE] # Preconfigure for selected database (options: mysql/oracle/postgresql/sqlite3/frontbase/ibm_db)
# Default: sqlite3
-b, [--builder=BUILDER] # Path to an application builder (can be a filesystem path or URL)
-m, [--template=TEMPLATE] # Path to an application template (can be a filesystem path or URL)
[--dev] # Setup the application with Gemfile pointing to your Rails checkout
[--edge] # Setup the application with Gemfile pointing to Rails repository
[--skip-gemfile] # Don't create a Gemfile
-O, [--skip-active-record] # Skip Active Record files
-T, [--skip-test-unit] # Skip Test::Unit files
-J, [--skip-prototype] # Skip Prototype files
-G, [--skip-git] # Skip Git ignores and keeps
Runtime options:
-f, [--force] # Overwrite files that already exist
-p, [--pretend] # Run but do not make any changes
-q, [--quiet] # Supress status output
-s, [--skip] # Skip files that already exist
Rails options:
-v, [--version] # Show Rails version number and quit
-h, [--help] # Show this help message and quit
Description:
The 'rails new' command creates a new Rails application with a default
directory structure and configuration at the path you specify.
Example:
rails new ~/Code/Ruby/weblog
This generates a skeletal Rails installation in ~/Code/Ruby/weblog.
See the README in the newly created application to get going.
日志中的所有输出的地方。所以我们可以看到究竟是什么失败。 –
尝试使用rails脚本的完整路径,并确保运行cron脚本的用户可以读取'/ home/t/T/script/ia.rb' – eugen
我们内部有日志语句,但没有显示任何内容,@ IvanDenisov。 – Crashalot