​老男孩教育每日一题-第85天-下面这个脚本直接执行没有问题,在定时任务中有问题,什么原因?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了​老男孩教育每日一题-第85天-下面这个脚本直接执行没有问题,在定时任务中有问题,什么原因?相关的知识,希望对你有一定的参考价值。

脚本内容:

[[email protected] scripts]# cat /server/scripts/ip.sh 
#!/bin/bash
IP=$(ifconfig eth0 |awk -F "[ :]+" ‘NR==2{print $4}‘)
echo "ip:$IP" >> /tmp/ip.txt

定时任务:
[[email protected] scripts]# crontab -l
* * * * * /bin/bash /server/scripts/ip.sh &> /dev/null

定时任务执行后的结果:

[[email protected] scripts]# cat /tmp/ip.txt 
ip:
ip:
ip:
ip:

参考答案:

原因:

此脚本在定时任务中没有取出ip,说明ifconfig命令没有执行成功,就是没有找到ifconfig,与PATH环境变量有关,PATH环境变量在/etc/profile文件中设置,而定时任务却是以nologin方式调用脚本,不会加载/etc/profile,所以导致此脚本在定时任务中执行失败

解决

方法1:

在脚本中ifconfig 命令写全路径  /sbin/ifconfig

查看结果如下

[[email protected] scripts]# cat /tmp/ip.txt 
ip:
ip:
ip:
ip:
ip:
ip:10.0.0.101
ip:10.0.0.101

方法2:

在脚本中加入  source /etc/profile

备注

今天是每日一题陪伴大家的第85天期待你的进步

对于题目和答案的任何疑问,请在博客评论区留言
往期题目索引

http://lidao.blog.51cto.com/3388056/1914205

本文出自 “李导的博客” 博客,请务必保留此出处http://lidao.blog.51cto.com/3388056/1944566

以上是关于​老男孩教育每日一题-第85天-下面这个脚本直接执行没有问题,在定时任务中有问题,什么原因?的主要内容,如果未能解决你的问题,请参考以下文章

​老男孩教育每日一题-第64天 -sed命令闯关

​老男孩教育每日一题-第73天 -基础命令点:可恶的^C

​老男孩教育每日一题-第79天-命令风暴:打印出001 002 003 这样的格式的数字

​老男孩教育每日一题-第62天-统计/var/log/下所有文件个数

​老男孩教育每日一题-第105天-Linux如何设置每天凌晨三点重启nginx服务

​老男孩教育每日一题-第125天-显示文件oldboy.txt的第20行到30行请问如何做?