免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 2883 | 回复: 18
打印 上一主题 下一主题

奇怪的SHEEL结果求解 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-31 17:47 |只看该作者 |倒序浏览
以下是我在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 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-07-31 18:17 |只看该作者
会不会你的测试没有持续不到十分钟

当然是猜的的。。。

论坛徽章:
0
3 [报告]
发表于 2008-07-31 20:02 |只看该作者

回复 #2 无声无息 的帖子

测试10分钟也试过,1分钟也试过,不是这个原因造成的。

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
4 [报告]
发表于 2008-07-31 21:50 |只看该作者
原帖由 lhming 于 2008-7-31 17:47 发表
以下是我在FreeBSD下检测ADSL线路是否正常连接的SHELL代码,我用crontab 设置每10分钟执行一次,是执行了,但运行结果是不是和我的代码所得到的一样,但我手动去运行这段代码,结果就是我想得到的了,不知道什么 ...


把 curl 命令的绝对路径带上试试。

论坛徽章:
0
5 [报告]
发表于 2008-07-31 21:54 |只看该作者

回复 #1 lhming 的帖子

! /bin/sh

=>

#!/bin/sh

论坛徽章:
0
6 [报告]
发表于 2008-08-01 01:25 |只看该作者
会不会是curl的问题?换其他的实现方法,比如ping dns,看看通不通。

论坛徽章:
0
7 [报告]
发表于 2008-08-01 12:59 |只看该作者

回复 #4 ly5066113 的帖子

路径带了,也是一样。

论坛徽章:
0
8 [报告]
发表于 2008-08-01 13:00 |只看该作者

回复 #5 cruelex 的帖子

我的代码复制过来这里的时候忘记#,我的是有的,不关这个原因,

论坛徽章:
0
9 [报告]
发表于 2008-08-01 13:01 |只看该作者

回复 #6 walkerxk 的帖子

你能帮我改写一下吧一,其它方法我不懂,谢谢!

论坛徽章:
0
10 [报告]
发表于 2008-08-01 13:28 |只看该作者
加上echo "$Content" >> /home/nat1/adsl.log 到脚本里,然后观察一下在断线和正常情况下,crontab执行后获取到的$Content内容是什么
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP