【发布时间】:2013-07-07 21:21:47
【问题描述】:
我有一个 bash 脚本,它将forever list 的输出保存到一个字符串中,进行一些操作并将其保存到一个 XML 文件中。在同一个文件中,我还调用了 shell 命令uptime。该文件位于/var/www/html/ytca/rss.sh。如果我执行该命令,则文件将正确更新。我有一个 cron 作业正在运行:
*/2 * * * * /var/www/html/ytca/rss.sh
并在根目录下使用crontab -e 命令创建,forever list 命令没有显示任何内容,但uptime 命令显示内容。
这里有你可能需要的一切:
rss.sh
#!/bin/bash
DATE=`date`
RESULT=`/usr/local/bin/forever list | sed -r "s/\x1B\[([0-9]{1,2}(;[0-9]{1,2})?)?[m|K]//g"`
OTHER=$(/usr/local/bin/forever list)
upt=`uptime`
String='<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
<channel>
<title>Server Details</title>
<link>http://www.google.com/</link>
<description>Server details for Chris</description>
<item>
<title> Updated: '$DATE'</title>
<link>www.google.com</link>
<guid>abc123</guid>
<pubDate>'$DATE'</pubDate>
<description><![CDATA[Service uptime: '$RESULT';<br/>DbServer uptime: '$OTHER';<br/>Server uptime: '${upt:0:23}']]></description>
</item>
</channel>
</rss>'
echo $String > '/var/www/html/ytca/site/update.xml'
永远:
/usr/local/bin/forever
删除一些不必要的垃圾:
从命令行运行时的输出:
<?xml version="1.0" encoding="UTF-8"?> ...<![CDATA[Service uptime: info: Forever processes running data: uid command... 0:0:23:31.723 ;<br/>DbServer uptime: [32minfo[39m: Forever processes running [9...3:31.932[39m ;<br/>Server uptime: 00:02:57 up 4 days, 48]]></description> </item> </channel> </rss>
从 cron 运行时的输出:
<?xml version="1.0" encoding="UTF-8"?>...<![CDATA[Service uptime: ;<br/>DbServer uptime: ;<br/>Server uptime: 00:00:01 up 4 days, 45]]></description> </item> </channel> </rss>
我已经为此工作了好几个小时,但这似乎没有意义。我已经尝试在 crontab 中回显永远列表,但它最终是空白的。有什么想法吗?
【问题讨论】:
-
/usr/local/bin/在你的root'sPATH中吗? -
检查
OTHER=$(/usr/local/bin/forever list)的输出。当您通过 cron 执行时,似乎forever进程甚至没有运行。 -
@devnull Forever 正在运行并且已经运行了数周,并且因为我可以通过命令执行 .sh 文件并且它可以正确更新问题不是永远列表不起作用,而是它从 cron 调用时特别不起作用。
-
@JS웃 是的,这是我回显 $PATH 时得到的结果:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/ bin:/usr/sbin:/usr/bin:/sbin:/bin:/root/bin
-
@ChrisJones cron 是否以能够从命令行成功执行脚本的同一用户身份运行?
标签: bash cron centos crontab forever