红联Linux门户
Linux帮助

通过crontab调用rvm下的rake命令

发布时间:2014-09-14 09:45:51来源:linux网站作者:zjueman

需要通过crontab调用rvm下的rake命令,折腾了很久才搞定。

环境是Ubuntu 10.04


crontab的问题有90%是和path相关的,找不到正确的ruby, 找不到正确的gems。理解了这一点就变得容易了。只要正确设置:PATH, GEM_HOME, GEM_PATH就和命令行下运营一样了。


1. 确保你在正常的命令行下能够运行你想要调用的脚本或者程序。


2. 在上一步成功的基础上,查看PATH, GEM_HOME和GEM_PATH

$ echo $PATH  
$ echo $GEM_HOME  
$ echo $GEM_PATH


3. 把上面的变量设置到一个脚本中,比如set_cron_path.sh,下面是我们列子:

export PATH=/home/someboy/.rvm/gems/ruby-1.9.3-p125@zyt/bin:/home/someboy/.rvm/gems/ruby-1.9.3-p125@global/bin:/home/someboy/.rvm/rubies/ruby-1.9.3-p125/bin:/home/someboy/.rvm/bin:/usr/local/ruby/bin:/usr/local/ImageMagick/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games  
export GEM_HOME=/home/someboy/.rvm/gems/ruby-1.9.3-p125@zyt 
export GEM_PATH=/home/someboy/.rvm/gems/ruby-1.9.3-p125@zyt:/home/someboy/.rvm/gems/ruby-1.9.3-p125@global


4. 在crontab里面调用这个脚本,比如:

03 * * * * . /home/someboy/set_cron193_path.sh; /bin/bash -l -c 'cd /home/someboy/apps/zyt && RAILS_ENV=production rake platform_comment:get_comments --trace >>/home/someboy/apps/zyt/log/platform_comment.log 2>&1'  


这样应该就可以了。还有其他可能常见的问题,比如某些文件没有权限等。


上面的例子会把日子输入到相应的log中,可以查看运营的情况。
crontab自己的log写在/var/log/syslog中。