L018-crond的生产场景经验小节
L018-crond的生产场景经验小节
怎么说呢,其实L018这节课还是巩固crond的知识,前半堂课主要是解决上堂课老师留的作业(在L017已经更新,拉到最后),然后剩下的半堂客主要是讲解了一些生产场景实例,不过大多数还是总结要点,所以这篇主要还是把关于crond定时任务所有的内容做一个总结贴出来,以后使用crontab时可以参考,下面开始:
企业生产场景如何调试crontab定时任务
一、增加执行任务频率调试任务(某些任务不能用于生产环境)
在调试时,把任务执行频率调调快一点,如:每分钟、每5分钟执行一次,或者笔当前时间退出5分钟以后,看能否执行,是不是按照你的想象去执行了,如果整整没问题,再改成需要的任务的执行时间。
注意:有些计划任务不允许频繁执行的,例如:定时往数据库里插数据,这样的任务就要在测试机上测试好,然后部署到正式线上,这样正式工作的问题的寄回就少了。
规范的操作流程:个人的开发配置环境-->办公室的测试环境-->idc机房的测试环境-->idc机房的正式环境
使用log文件调试任务,把/dev/null 2>&1换成某一对象定向,这样通过看文件就可知道定时任务是否执行,是正确还是错误。
二、调整系统时间调试任务(不能用于生产环境)
用正确的执行任务的时间,设置完成后,可以修改当前时间,改成任务执行时间的前几分钟来测试(或者重启定时任务服务)。如:定时任务9:00执行,我们可以把系统时间改成8:55分,然后观察是不是正确执行了,当前时间比任务时间要提前足够长,如果是生产环境服务器不可以这样处理,测试环境可以使用这个手段。
例如:周三的2:00执行。
把系统时间调整为周三凌晨1:55分(至少5分钟)
三、通过脚本日志输出调试定时任务
在脚本中加入日志输出,然后把输出打到指定的日志中,然后观察日志内容结果,看是否执行或正确执行。或像下面的内容把脚本结果定向到一个log文件里,重定向“>”即可。不需要“>>”追加,这样日志就不会一直变大,如/app/log.log。也可以在脚本里面打日志。
这个就是我在第一方面里后面说的话。
四、注意一些任务命令带来的问题
注意:*/1 * * * * echo "==" >> /tmp/oldboy.log >/dev/null 2>&1这是隐蔽的无法正确执行的任务配置,原因是前面多了">>",或者去掉结尾的>/dev/null 2>&1。
强调:此问题时因为前面已经有重定向,后面要去掉>/dev/null 2>&1
五、注意环境变量导致的定时任务故障
在调试java程序任务的时候,注意环境变量,把环境变量的定义加到脚本里。
六、通过crond定时任务服务日志调试定时任务
查看定时任务服务日志
[root@moban ~]# tail -f /var/log/cron
由此来找到出问题的时间点,给解决问题带来抓手
七、其他稀奇古怪的问题调试方法
结合前面1-6的方法就可以解决几乎所有遇到的问题,此类问题主要是多看crond服务日志,并且把程序输出到指定日志分析。
关于编写定时任务的方法要领总结:
要领1:为定时任务规则加必要的注释
要领2:执行shell脚本任务前加/bin/sh
要领3:定时任务命令或脚本的结尾加>/dev/null 2>&1
要领4:定时任务命令或程序最好写到脚本里执行
要领5:在指定用户下执行相关定时任务
要领6:在生产任务程序不要随意打印输出信息 tar zcf echo 123 >a.log
要领7:定时任务执行的脚本要规范路径
要领8:配置定时任务规范操作过程
生产应用问题10箴言
1.系统环境变量问题
2.定时任务要用绝对路径
3.脚本权限问题加/bin/sh
4.时间变量问题要用反斜线 如“%”
5.>/dev/null 2>&1问题 (1>/dev/null 2>/dev/null)防止占满inode
6.定时任务规则之前加注释
7.使用脚本替代命令定时任务
8.避免不必要的程序及命令输出
9.切到目标目录的上一级打包目标
10.定时任务脚本中的程序命令用全路径
还有一个小问题
当文件太多,使用rm -fr *.* 无法删除的时候,我们可以使用下面的命令
1.ls | xargs rm -f
2.find ./ -typr -f | xargs rm -f
3.删除原文件夹,但是前提记住原目录属性,重新建立后恢复(但是一定要小心谨慎)
最后,学linux也已经有一阵子了,发现前面的也快忘差不多了,下周一周的时间我会统一复习一下之前的课程内容作为巩固,可能会更新一篇心得吧。
L018-crond的生产场景经验小节的更多相关文章
- 生产场景NFS共享存储优化及实战
生产场景NFS共享存储优化: 1.硬件:sas/ssd磁盘,买多块,raid0/raid10,网卡好 2.NFS服务器端优化加all_squash,async /backup/NFS 192.168. ...
- 根据生产场景对Linux系统进行分区
转自:http://oldboy.blog.51cto.com/2561410/629558 老鸟谈生产场景如何对linux系统进行分区? █ 前言: 我们买房子时,会考虑1室1厅,2室1厅, ...
- Mysql DBA 运维 MySQL数据库索引优化及数据丢失案例 MySQL备份-增量备份及数据恢复基础实战 MySQL数据库生产场景核心优化
需要的联系我,QQ:1844912514
- 互联网公司linux运维生产场景常用软件工具一览
linux的世界真的很精彩,还没入门的朋友赶紧进来吧! 操作系统:Centos※,Freebsd,Ubuntu,Redhat linux,suse linux网站服务:apache※,nginx※,l ...
- NFS生产场景优化
1.硬件上多块网卡bond,增加吞吐量,至少千兆.sas/ssd磁盘组raid5或raid10 2.服务端配置:/data 172.16.1.0/24(rw,sync,all_squash,anonu ...
- oracle经验小节2
1,instr 函数 在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置. 语法如下: instr( string1, string2 [, start_position ...
- Linux实战教学笔记21:Rsync数据同步工具
第二十一节 Rsync数据同步工具 标签(空格分隔): Linux实战教学笔记-陈思齐 ---本教学笔记是本人学习和工作生涯中的摘记整理而成,此为初稿(尚有诸多不完善之处),为原创作品,允许转载,转载 ...
- Linux系统——Rsync数据同步工具
Rsync的优点及缺点 优点:类似cp命令.scp命令,但rsync为增量复制工具 缺点:针对大文件,效率非常高(打包再比对),针对小文件,效率非常低. Rsync作用 (1)可使本地和远程两台主机之 ...
- 【基础】:Rsync数据同步工具
第二十一节 Rsync数据同步工具 1.1 Rsync介绍 1.1.1 什么是Rsync? 1.1.2 Rsync简介 1.3 Rsync的特性 1.1.4 Rsync的企业工作场景说明 1.2 Rs ...
随机推荐
- stylus的用法
参考链接:预处器的对比——Sass.LESS和Stylus http://www.w3cplus.com/css/sass-vs-less-vs-stylus-a-preprocessor-sho ...
- No.5 - 纯 CSS 制作绕中轴旋转的立方体
body{ background-color: #000; margin:; padding:; } main{ perspective: 800px; } .cube{ transform-styl ...
- spring aop,静态及动态代理例子
@Aspect@Componentpublic class AopText { @Pointcut("execution(public * com.llf.service.*Service. ...
- Loadrunner手动关联详解
Loadrunner手动关联详解 一.关联的含义: 关联(correlation):在脚本回放过程中,客户端发出请求,通过关联函数所定义的左右边界值(也就是关联规则),在服务器所响应的内容中查找,得到 ...
- LD-sketch源码阅读
目录 util.h hash.hpp/cpp mangle函数 GenHashSeed函数 AwareHash模块 LDSketch.hpp/cpp LDSketch更新函数,对一个sketch插入键 ...
- 爬虫实战:汽车之家配置页面 破解伪元素和混淆JS
本篇介绍如何破解汽车之家配置页面的伪元素和混淆的JS. ** 温馨提示:如需转载本文,请注明内容出处.** 本文链接:https://www.cnblogs.com/grom/p/9242156.ht ...
- Web前端---HTTP协议
目录 HTTP协议 一.http协议概述 二.http请求报文 1.GET请求 2.POST请求 三.http响应报文 1.响应报文内容 2.状态码(Status Code) HTTP协议 一.htt ...
- 初识shell
shell简介 在计算机科学中,Shell俗称壳(用来区别于核),Shell 是一个 C 语言编写的脚本语言,它是用户与 Linux 的桥梁,用户输入命令交给 Shell 处理, Shell 将相应的 ...
- Android环境搭建及Ionic打包(win7)
本人刚刚接触Ionic3,初步进行打包操作,将其遇到的问题和整个流程记录下载,方便以后的巩固,也为小白们提供一个参考.因本人没有appleヽ(ー_ー)ノ,而且使用的是WIN7系统,所以暂时只提供了WI ...
- ElasticSearch优化系列七:优化建议
尽量运行在Sun/Oracle JDK1.7以上环境中,低版本的jdk容易出现莫名的bug,ES性能体现在在分布式计算中,一个节点是不足以测试出其性能,一个生产系统至少在三个节点以上. ES集群节点规 ...