
#!/bin/bash
Timeout=0;
Timeout_limit=1;
Timeout_flag=0;
IP="8888"
while [ 1 ]
do
# 取平均延迟的整数位
Timeout="`ping $IP -c 3 | grep 'min/avg/max/mdev'|awk '{print $4}'|cut -b '7'`"
if [ $Timeout -ge $Timeout_limit ] && [ $Timeout_flag -ne 1 ]; then
echo ping timeout, average delay=$Timeout ms
mail -s 'Ping Delay' 邮箱 < ar/log/bootlog
Timeout_flag=1
fi
if [ $Timeout -lt $Timeout_limit ] && [ $Timeout_flag -ne 0 ]; then
echo ping recovery, average delay=$Timeout ms
mail -s 'Ping recovery' 邮箱 < ar/log/bootlog
Timeout_flag=0
fi
sleep 5
done第三行Timeout_limit值写错了,应该是100哈,代码提交了不能改了。你这个不需要把延迟结果保存在文件的,而是应该需要作定时检测的。
@echo off 这个是取消屏幕显示命令(可以不写)
你的第一个命令
ping -n 05 1271>nul (说明:这个05就代表等待5秒,其实就是ping自己5秒,然后5秒后,运行下一个命令)
你的第二个命令
BAT 实现延时不好 建议用VBS
比如
这个为开机延迟拨号上网的命令,适合开机比较卡的用户比如装了卡巴斯基的
set hipon=CreateObject("WscriptShell")
Wscriptsleep 7500
hiponrun "rasdial adsl 上网账号 上网密码"
前提你的宽带连接名字为 adsl
7500为毫秒(75秒) 可以自己定义
建立文本文档 输入以上内容 保存为autoadslvbs 存在 开始 程序 启动里面
hiponrun "程序地址 程序名称 参数"
其他
1、利用“死”循环:设定一个时间差,如果当前时间与设定时间之差不大于设定之时间差,则不退出该循环,从而达到延时的目的
@echo off
set /a Start=%time:~6,2%
:ProDelay
set /a Now=%time:~6,2%
set /a Diff=%Now%-%Start%
rem 以下这一句可以防止秒数从59跳到1时产生的错误。
if %Diff% lss 0 set /a Diff=%Diff%+60
if %Diff% leq 2 goto :ProDelay
echo ok!
2、利用ping命令实现延时,方法巧妙而且可以控制,但精度不高。
如:ping -n 3 127001>nul大约可以停顿2秒
-n后的数字是发送包的数目,为暂停秒数加一。此法每秒有05%的偏差,时间精度为1秒。
思路:
1 用RegWrite将vbs文件名写入开机启动注册表项:
"HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run"
Set WshShell = WScriptCreateObject("WScriptShell")WshShellRegWrite "HKCU\Software\Microsoft\Windows\CurrentVersion\Run", "ThunderSpyvbs", "REG_SZ" 'vbs文件名请自己修改
不过写注册表 *** 作可能会被杀软拦截。
2 等待10分钟
WScriptSleep 106010003 启动迅雷并隐藏
Set oShell = WScriptCreateObject ("WSCriptshell")oShellrun "cmd /c start C:\Program Files\Thunder", 0 '自己修改迅雷路径
/c 选项表示执行指定的命令后关闭命令提示窗口(黑窗口)。
第二个参数0表示隐藏应用。
4 关闭迅雷(杀进程)
两种方法。
DOS命令TASKKILL方法:
Set wshShell = WScriptCreateObject("WScriptShell")wshShellrun "TASKKILL /IM Thunderexe", 0 '自己确认迅雷的进程名
WMI方法:
strComputer=""Set objWMIService = GetObject("winmgmts:\\" & strComputer & "\root\cimv2")
Set colProcessList=objWMIServiceExecQuery ("select from Win32_Process where Name='Thunderexe'") '自己确认迅雷的进程名
For Each objProcess in colProcessList
objProcessTerminate()
Next
使用权限 : 所有使用者
使用方式 : sleep [--help] [--version] number[smhd]
说明 : sleep 可以用来将目前动作延迟一段时间
参数说明 :
--help : 显示辅助讯息
--version : 显示版本编号
number : 时间长度,后面可接 s、m、h 或 d
其中 s 为秒,m 为 分钟,h 为小时,d 为日数
例子 :
显示目前时间后延迟 1 分钟,之后再次显示时间 :
date;sleep 1m;date
这个命令更多应用于shell脚本编程里和程序里
如下面的一段程序:
应用程序:
复制代码
代码如下:
#include <syswaith>
usleep(n) //n微秒
Sleep(n)//n毫秒
sleep(n)//n秒
驱动程序:
#include <linux/delayh>
mdelay(n) //milliseconds 其实现
#ifdef notdef
#define mdelay(n) (\
{unsigned long msec=(n); while (msec--) udelay(1000);})
#else
#define mdelay(n) (\
(__builtin_constant_p(n) && (n)<=MAX_UDELAY_MS) udelay((n)1000) : \
({unsigned long msec=(n); while (msec--) udelay(1000);}))
#endif
调用asm/delayh的udelay,udelay应该是纳秒级的延时
Dos:
sleep(1); //停留1秒
delay(100); //停留100毫秒
Windows:
Sleep(100); //停留100毫秒
Linux:
sleep(1); //停留1秒
usleep(1000); //停留1毫秒
每一个平台不太一样,最好自己定义一套跨平台的宏进行控制
秒还是微秒?关于延时函数sleep()
因为要写一段代码,需要用到sleep()函数,在我印象中,sleep(10)好像是休眠10微秒,结果却是休眠了10秒(在Linux下)。觉得很奇怪,因为头儿也记得好像是微秒为单位的。所以就查了一下。
原来linux下的sleep函数原型为:
unsigned int sleep(unsigned int seconds);
而MFC中的Sleep函数原型为:
void Sleep(DWORD dwMilliseconds);
也就是说,Linux下(使用的gcc的库),sleep()函数是以秒为单位的,sleep(1);就是休眠1秒。而MFC下的sleep()函数是以微秒为单位的,sleep(1000);才是休眠1秒。原来如此啊。而如果在Linux下也用微妙为单位休眠,可以使用线程休眠函数:void usleep(unsigned long usec);当然,使用的时候别忘记#include <systemh>哦。
另外值得一提的是,linux下还有个delay()函数,原型为extern void delay(unsigned int msec);它可以延时msec4毫秒,也就是如果想延时一秒钟的话,可以这么用 delay(250);
以上就是关于Linux下shell脚本PING命令只要延迟高于100ms就发送个邮件全部的内容,包括:Linux下shell脚本PING命令只要延迟高于100ms就发送个邮件、怎么做延迟打开两个exe文件的bat文件譬如让其间隔时间为5秒,5秒后打开下一个、windows延迟启动程序批处理等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)