其他分享
首页 > 其他分享> > Redmine Whining cron NameError: method `source‘ not defined in Gem::Specification

Redmine Whining cron NameError: method `source‘ not defined in Gem::Specification

作者:互联网

Redmine在使用Whining Redmine计划任务

Redmine 在使用Whining Redmine插件时,需要创建计划任务,根据Whining Redmine安装和配置指导,计划任务如下:

0 7 * * 1,2,3,4,5 www-data cd /path/to/redmine && /usr/bin/rake redmine:send_whining days=7 RAILS_ENV="production" 

但是经过多次测试,均为能成功,一开始报邮件错误

Apr 30 15:01:01 10-10-1-158 postfix/sendmail[18138]: fatal: parameter inet_interfaces: no local interface found for ::1

解决方案:

[root@Captain redmine]# vi /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6

注释掉 ::1行:

[root@Captain redmine]# vi /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
# ::1         localhost localhost.localdomain localhost6 localhost6.localdomain6

后又报错:

rake aborted! 
crontab  rake aborted! cannot load such file -- bundler/setup
.......
.......
.......
.......
.......
NameError: method `source' not defined in Gem::Specification
.......
.......

解决方案:

一、如果是使用计划任务+脚本执行,需要在脚本中做特殊处理:

定时计划任务:

[root@Captain redmine]# vi /etc/crontab 

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed

0 8 * * * 1,2,3,4,5 root /var/redmine/crontab.sh

脚本文件:

[root@Captain redmine]# cat crontab.sh 
#!/bin/bash
source /etc/profile
Prog_dir=/var/redmine
Day=2
cd $Prog_dir
rake redmine:send_whining days= $Day RAILS_ENV="production"

需要在脚本中增加

source /etc/profile

二、如果使用计划任务(crontab)直接执行

报错如上所述不在赘述

解决方案

计划任务指令如下:

[root@10-10-1-158 redmine]# vi /etc/crontab 

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed

0 8 * * * 1,2,3,4,5 root cd /var/redmine && source /etc/profile && rake redmine:send_whining days=2 RAILS_ENV="production" &> /var/redmine/log/crontab.log

同样需要调用source

# 搞定,本人小白,这只是我自己的学习和总结

标签:bin,Whining,defined,.......,crontab,NameError,redmine,root,localhost
来源: https://blog.csdn.net/qq_34797683/article/details/116308300