Chinaunix

标题: 奇怪的SHEEL结果求解 [打印本页]

作者: lhming    时间: 2008-07-31 17:47
标题: 奇怪的SHEEL结果求解
以下是我在FreeBSD下检测ADSL线路是否正常连接的SHELL代码,我用crontab 设置每10分钟执行一次,是执行了,但运行结果是不是和我的代码所得到的一样,但我手动去运行这段代码,结果就是我想得到的了,不知道什么原因,帮我研究一下,谢谢!

这是我用的脚本
  1. #! /bin/sh                                         
  2. Content=$(curl -s [url]http://www.test.com/Online.html[/url])
  3.                                                    
  4. if [ "${Content}" = "Online" ];then               
  5.         echo $(date) "线路正常!" >> /home/nat1/adsl.log
  6. else                                               
  7.         echo $(date) "线路异常!" >> /home/nat1/adsl.log
  8.         curl -s -u admin:Pass2233 "http://192.168.199.23/rs232/rr.htm"
  9.                                                    
  10. fi
复制代码


如果ADSL断线,自动执行后 adsl.log 文件的输出结果如下。[PS:应该是断线了就显示"线路异常"才对,但不知道为什么总显示"线路正常"而我用手动去执行一下以上的代码,就会显示出我要的结果,就显示"线路异常"然后就重启路由器了。]
Thu Jul 31 14:00:02 CST 2008 线路正常!
Thu Jul 31 14:10:00 CST 2008 线路正常!
Thu Jul 31 14:20:03 CST 2008 线路正常!
Thu Jul 31 14:30:02 CST 2008 线路正常!
Thu Jul 31 14:40:02 CST 2008 线路正常!
Thu Jul 31 14:50:03 CST 2008 线路正常!
=======================================

我应该如何做才能让自动运行也得到我想要的结果,谢谢指教!

[ 本帖最后由 lhming 于 2008-8-1 13:50 编辑 ]
作者: 无声无息    时间: 2008-07-31 18:17
会不会你的测试没有持续不到十分钟

当然是猜的的。。。
作者: lhming    时间: 2008-07-31 20:02
标题: 回复 #2 无声无息 的帖子
测试10分钟也试过,1分钟也试过,不是这个原因造成的。
作者: ly5066113    时间: 2008-07-31 21:50
原帖由 lhming 于 2008-7-31 17:47 发表
以下是我在FreeBSD下检测ADSL线路是否正常连接的SHELL代码,我用crontab 设置每10分钟执行一次,是执行了,但运行结果是不是和我的代码所得到的一样,但我手动去运行这段代码,结果就是我想得到的了,不知道什么 ...


把 curl 命令的绝对路径带上试试。
作者: cruelex    时间: 2008-07-31 21:54
标题: 回复 #1 lhming 的帖子
! /bin/sh

=>

#!/bin/sh
作者: walkerxk    时间: 2008-08-01 01:25
会不会是curl的问题?换其他的实现方法,比如ping dns,看看通不通。
作者: lhming    时间: 2008-08-01 12:59
标题: 回复 #4 ly5066113 的帖子
路径带了,也是一样。
作者: lhming    时间: 2008-08-01 13:00
标题: 回复 #5 cruelex 的帖子
我的代码复制过来这里的时候忘记#,我的是有的,不关这个原因,
作者: lhming    时间: 2008-08-01 13:01
标题: 回复 #6 walkerxk 的帖子
你能帮我改写一下吧一,其它方法我不懂,谢谢!
作者: infernor    时间: 2008-08-01 13:28
加上echo "$Content" >> /home/nat1/adsl.log 到脚本里,然后观察一下在断线和正常情况下,crontab执行后获取到的$Content内容是什么
作者: lhming    时间: 2008-08-03 15:59
原帖由 infernor 于 2008-8-1 13:28 发表
加上echo "$Content" >> /home/nat1/adsl.log 到脚本里,然后观察一下在断线和正常情况下,crontab执行后获取到的$Content内容是什么


已经照你的提示加上echo "$Content" >> /home/nat1/adsl.log观察结果,断线和在连线的情况下,adsl.log里都没有任何结果显示,是什么原因呢?
作者: sainio    时间: 2008-08-03 20:15
crontab?

楼主用什么用户登录的?
作者: lhming    时间: 2008-08-04 16:00
原帖由 sainio 于 2008-8-3 20:15 发表
crontab?

楼主用什么用户登录的?

用的是超级管理员ROOT
作者: lhming    时间: 2008-08-04 16:03
问题解决了,把程序放到/root目录,把CRUL都加上绝对路径就可以用CRONTAB定时自动运行成功了,分析了一下,应该是环境变量问题和权限问题,但ROOT用户是超级用户,怎么就没办法运行别的目录下的程序呢,这个是我想不通的。
作者: ly5066113    时间: 2008-08-04 16:05
原帖由 lhming 于 2008-8-4 16:03 发表
问题解决了,把程序放到/root目录,把CRUL都加上绝对路径就可以用CRONTAB定时自动运行成功了,分析了一下,应该是环境变量问题和权限问题,但ROOT用户是超级用户,怎么就没办法运行别的目录下的程序呢,这个是我 ...


不是没权限运行,而是找不到。
作者: d38179677    时间: 2008-08-04 16:09
学习学习:wink:
作者: d38179677    时间: 2008-08-04 16:13
测试一下
不好意思

1212982975013.gif (2.83 MB, 下载次数: 18)

1212982975013.gif

作者: lhming    时间: 2008-08-06 13:53
原帖由 ly5066113 于 2008-8-4 16:05 发表


不是没权限运行,而是找不到。


请问一下,为什么找不到呢,也是用相同的路径的。
作者: ly5066113    时间: 2008-08-06 14:04
原帖由 lhming 于 2008-8-6 13:53 发表


请问一下,为什么找不到呢,也是用相同的路径的。


因为环境变量PATH的值不一样。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2