免费注册 查看新帖 |

Chinaunix

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

crontab 执行脚本的奇怪问题--对于时间的理解错误[已解决] [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-03-30 10:42 |只看该作者 |倒序浏览
写个两个脚本加到crontab里,都是有执行权限的
要求一个每50分钟,另一个每20分钟执行:
*/50 * * * * /home/drog/script/kill_recv.sh
*/20 * * * * /home/drog/script/kill_work.sh

kill_recv.sh内容:
        #!/bin/sh
        /home/drog/script/kill_id.sh 1 2

kill_work.sh内容:
        #!/bin/sh
        /home/drog/script/kill_id.sh 3 4

kill_id.sh内容:
        #!/bin/sh
        for args in $@
        do
          kill -9 `ps -ef | grep -v "grep" | awk '{if($(NF-1)==arg && $(NF-2)=="program name") print $2}' arg="$args" -`
        done


但是实际的执行结果是:
Mar 30 09:50:01 localhost crond[26039]: (drog) CMD (/home/drog/script/kill_recv.sh)
Mar 30 10:00:01 localhost crond[11620]: (drog) CMD (/home/drog/script/kill_work.sh)
Mar 30 10:00:01 localhost crond[11624]: (drog) CMD (/home/drog/script/kill_recv.sh)

kill_recv.sh为什么会在十点又执行了一次呢?

[ 本帖最后由 drog1983 于 2009-3-30 11:46 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-03-30 10:50 |只看该作者
kill -9 `ps -ef | grep -v "grep" | awk '{if($(NF-1)==arg && $(NF-2)=="program name") print $2}' arg="$args" -`

这句楞没看懂
难道是这样?
kill -9 `ps -ef | grep -v "grep" | awk -v arg="$args" '{if($(NF-1)==arg && $(NF-2)=="program name") print $2}' `

论坛徽章:
0
3 [报告]
发表于 2009-03-30 10:55 |只看该作者

回复 #2 ywlscpl 的帖子

前后顺序是不重要的,只是实现了传递参数进awk里,主要是我的那个问题见到过吗?

论坛徽章:
0
4 [报告]
发表于 2009-03-30 10:57 |只看该作者

回复 #3 drog1983 的帖子

你把awk语法搞清楚了再说
[root@Mylinux tmp]# a="test";awk 'BEGIN{print var}' var="$a"

[root@Mylinux tmp]# a="test";awk -v var="$a" 'BEGIN{print var}'
test

论坛徽章:
0
5 [报告]
发表于 2009-03-30 11:04 |只看该作者
Mar 30 10:50:01 erpwebservice crond[28548]: (root) CMD (/home/kkg/1.sh)
Mar 30 11:00:01 erpwebservice crond[28567]: (root) CMD (/home/kkg/1.sh)
[root@erpwebservice kkg]# crontab -l
*/50 * * * * /home/kkg/1.sh

我刚做了一个测试,crontab 就是这种运行机制的。
每小时50分钟跟你认为的每50分钟概念是不一样的。

论坛徽章:
9
2015亚冠之阿尔纳斯尔
日期:2015-09-10 16:21:162015亚冠之塔什干火车头
日期:2015-07-01 16:23:022015年亚洲杯之巴勒斯坦
日期:2015-04-20 17:19:46子鼠
日期:2014-11-13 09:51:26未羊
日期:2014-08-28 18:13:36技术图书徽章
日期:2014-02-21 09:30:15酉鸡
日期:2014-01-14 11:12:49天蝎座
日期:2013-12-09 17:56:53平安夜徽章
日期:2015-12-26 00:06:30
6 [报告]
发表于 2009-03-30 11:06 |只看该作者
同意DBA的观点
这个 */50 与每50分钟概念是不一样的
应该是代表0-60 分钟内能被50整除的时间,即0分钟与50分钟这二个时刻

论坛徽章:
0
7 [报告]
发表于 2009-03-30 11:06 |只看该作者

回复 #4 ywlscpl 的帖子

我假如告诉你,我的那个放到脚本里能跑出结果来,你会不会认为是我讲假话呢?

论坛徽章:
0
8 [报告]
发表于 2009-03-30 11:09 |只看该作者

回复 #5 我是DBA 的帖子

谢谢 DBA 的解释,但是我要50分钟执行一次,怎么才能保证呢?
比如:
9:50
10:40
11:30
这种执行方式呢?

论坛徽章:
11
金牛座
日期:2015-03-19 16:56:22数据库技术版块每日发帖之星
日期:2016-08-02 06:20:00数据库技术版块每日发帖之星
日期:2016-04-24 06:20:00数据库技术版块每日发帖之星
日期:2016-04-13 06:20:00IT运维版块每日发帖之星
日期:2016-04-13 06:20:00数据库技术版块每日发帖之星
日期:2016-02-03 06:20:00数据库技术版块每日发帖之星
日期:2015-08-06 06:20:00季节之章:春
日期:2015-03-27 15:54:57羊年新春福章
日期:2015-03-27 15:54:37戌狗
日期:2015-03-19 16:56:41数据库技术版块每日发帖之星
日期:2016-08-18 06:20:00
9 [报告]
发表于 2009-03-30 11:10 |只看该作者
*/50 表示能被50整除的时间.....这个跟你理解的有偏差...
或者说是1小时内(0-59)能每隔50分钟运行....也就是0,50两个时间点..

论坛徽章:
0
10 [报告]
发表于 2009-03-30 11:17 |只看该作者

回复 #8 drog1983 的帖子

用while true
do
sleep
done
这种方式吧。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP