前几天在写一个脚本, 每隔三天程序更新一下数据,然后重启一下进程。
但是脚本运行一段时间后, 发现程序有些异常,每月9号没有更新数据,也没有重启进程,其它时间点都是工作正常的,难道在shell脚本中 9%3 不等于0吗?看了脚本的运行日记 , 创造这个过错 : -bash: 09: value too great for base (error token is "09"); 在网上搜了一下, date +%d发生 的小时是类似01 02 ... 10 .... 23的样子, 默认情况下, 不足2位的前面补零, 而$(())在做数学运算的时间 , 把0开头的数字认为 是8进制的, 以是 $((09)), 就报了”value too great for base“的错误。
再查了一下date的手册, 发现:
- (hyphen) do not pad the field
0 (zero) pad with zeros (这是缺省行为)
因此,将脚本day =$(date +%d) 修改为day =$(date +%-d),就可以产生类似于 0 1 2 3...12的输出,而不是位数不足前面补0的输出。
day =$(date +%d)
ret=$(($day %3))
if [ $ret -ne 0 ];then
echo "we don\'t restart $spellcmd"
exit 0
fi
但是脚本运行一段时间后, 发现程序有些异常,每月9号没有更新数据,也没有重启进程,其它时间点都是工作正常的,难道在shell脚本中 9%3 不等于0吗?看了脚本的运行日记 , 创造这个过错 : -bash: 09: value too great for base (error token is "09"); 在网上搜了一下, date +%d发生 的小时是类似01 02 ... 10 .... 23的样子, 默认情况下, 不足2位的前面补零, 而$(())在做数学运算的时间 , 把0开头的数字认为 是8进制的, 以是 $((09)), 就报了”value too great for base“的错误。
再查了一下date的手册, 发现:
- (hyphen) do not pad the field
0 (zero) pad with zeros (这是缺省行为)
因此,将脚本day =$(date +%d) 修改为day =$(date +%-d),就可以产生类似于 0 1 2 3...12的输出,而不是位数不足前面补0的输出。