0

我有一个奇怪的问题,与通过 cron 运行 BASH 脚本有关(通过 crontab -e 调用)。

这是脚本:

#!/bin/bash

SIG1="$(iwconfig wlan0 | awk '/Quality=/ { print $2} ' | cut -c 9-10)"
SIG2="$(iwconfig wlan0 | awk '/Quality=/ { print $2} ' | cut -c 12-13)"

echo "$SIG1:$SIG2" >> test.txt
exit

从命令行运行时,我得到45:70回显到文本文件末尾的预期输出。但是,当我通过 cron(使用 crontab -e)和以下条目运行脚本时:

* * * * * bash /home/rupert/test.sh

我只是将冒号 (:) 回显到文本文件中,没有创建值 SIG1 和 SIG2,我不知道为什么。为什么通过 cron 运行会弄乱脚本?

FWIW,这是 iwconfig wlan0 的输出,没有额外的处理:

wlan0     IEEE 802.11abgn  ESSID:"plumternet"
          Mode:Managed  Frequency:2.452 GHz  Access Point: 00:18:84:2A:68:AD
          Bit Rate=54 Mb/s   Tx-Power=15 dBm
          Retry  long limit:7   RTS thr:off   Fragment thr:off
          Power Management:off
          Link Quality=46/70  Signal level=-64 dBm
          Rx invalid nwid:0  Rx invalid crypt:0  Rx invalid frag:0
          Tx excessive retries:0  Invalid misc:0   Missed beacon:0

我这样做是因为我想在 LCD 屏幕上显示 WiFi 链接质量值“46/70”,而我使用的程序通过读取文本文件来执行此操作。但是,当通过 cron 运行时,值会丢失......???

我正在使用 cut -c 9-10 和 cut -c 12-13 因为我认为“/”可能会导致脚本出现问题,我很乐意使用 cut -c 9-13,但我认为它可以解决问题,但它没有。

帮助!!

酷,感谢你们,我意识到这是一个 PATH 问题,只需提供 iwconfig 的完整路径(/sbin/iwconfig)即可修复它。这是现在显示所有正确信息的 LCD 屏幕的图片:

http://img835.imageshack.us/img835/4175/20100825122413.jpg

4

3 回答 3

2

您需要提供通过 cron 执行的任何命令的完整路径。cron 运行与任何终端分离的命令,这意味着您需要正确设置环境。cut 可能可用,但给出 iwconfig 和 awk 的绝对路径

于 2010-08-25T11:09:06.857 回答
0

把这个文件的权限改成777

chmod 777 /home/rupert/test.sh

也许这会有所帮助。

于 2010-08-25T11:09:01.683 回答
0

我不知道防止这种情况(以干净的方式)发生的确切步骤(我不是一个 linux 专家),但是,这对我来说似乎是一个权限问题。不允许运行 cron 作业的用户执行您要执行的命令之一。

如果您修复权限,我认为它可能运行得很好!

于 2010-08-25T11:09:21.877 回答