Linux_计划任务理论概述
一、计划任务概述
1、计划任务概述:
- 计划任务分为:
- 一次性任务
- 周期性任务
- 在Linux系统的计划任务服务crond 可以满足周期性执行任务的需求。
- crond进程每分钟会处璇一次计划任务,计划任务主要是做一些周期性的任务目前最主要的用途是定时备份数据。
2、计划任务示例:
- Schedule one-time tasks With at.一 次性调度执行at
- Schedule recurring jobs with cron.循环调度执行cron
- Schedule recurring system jobs. 所有计划任务执行中的输出都会以邮件的方式发送给指定用户,除非重定向
3、计划任务分为以下两种情况:
- 系统级别的定时任务:(由系统管理)
- 清理系统缓存
- 临时文件清理
- 系统信息采集
- 日志文件切割
- 用户级别的定时任务:(用户管理)
- 定时同步互联网时间
- 定时备份系统配置文件
- 定时备份数据库文件
二、crond配置文件详解
1、总览配置文件详解
文件 说明
/etc/crontab //crontab配置文件
/etc/cron.deny //该文件中所列用户不允许使用c rontab命令
/var/spool/cron/* //所有用户定时文件都存放此目录,文件以用户名命名
/var/log/cron //定时任务执行后的日志文件,可用来回溯
2、/etc/crontab文件详解
SHELL=/bin/bash //当前登陆的shell,执行脚本的就是用/bin/bash来执行
PATH=/sbin:/bin:/usr/sbin:/usr/bin //命令的路径,执行的命令必须用绝对路径
MAILTO=root //邮件,发送到root的邮件 # For details see man 4 crontabs # Example of job definition:
# .---------------- minute (0 - 59) //分钟
# | .------------- hour (0 - 23) //小时
# | | .---------- day of month (1 - 31) //天
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ... //月
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat //周
# | | | | |
# * * * * * user-name command to be executed //执行的命令
2、/etc/cron.deny
计划任务默认是root用户,并且root用户不受该文件的约束,写入该文件的用户将无法写计划任务
3、/var/spool/cron/*
该文件下的是以用户名命名的计划任务文件,文件写的是计划任务的所执行的
4、/var/log/cron
计划任务执行后的日志文件,在该日志文件里面所记录的日志可以恢复误删的计划任务文件
三、计划任务管理
1、计划任务管理
参数 含义 指定示例
[root@wangqing ~]# crontab --help
-e 编辑crontab文件内容 crontab -e
-1 编辑crontab文件内容 crontab -e
-r 删除crontab文件内容 crontab -r
-u 管理其他用户的计划任务 rontab -u wangqing -l
注意: crontab {-l -e}实际上就是在操作/var/spool/cron/username
2、计划任务书写规范
//1.为计划任务增加必要的注释
[root@wangqing ~]# crontab -l
##time sync
*/5 * ***/usr/sbin/ntpdate t ime1.aliyun. com &>/dev/null //2.规范计划任务执行脚本存放的路径/scripts/
[root@wangqing ~]# crontab -1
##backup wwW to / backup
30 01 * * * /bin/sh /scripts/www_ backup.sh &>/dev/null //3.执行shell脚本任务前加/ bin/sh,脚本结尾加&>/dev/null
//调试好后应屏蔽debug输出信息,避免产生系统垃圾占用过多inode,如需输出日志,可重定向至 日志文件
[root@wangqing ~]# crontab -l
####backup wwW to /backup
30 01 * * */bin/sh /scripts/www_ backup.sh &>/ tmp/ WWW_ backup. log
四、计划任务编写实例
1、计划任务编写实例
[rootwangqing ~]# crontab -e
#每天凌晨切割nginx日志
05 00***/bin/bash -x /scripts/cut_ _nginx.sh &> /scripts/log/nginxI log #每天5点备份数据库
00 05 * * * /bin/bash -x /scripts/dump_ sql.sh &>/scripts/ log/mysql.log
2、注意事项
//注意:
1.我们所有的crond服务是运行的程序。而crontab命令用户用来设置定时规则的命令。
2. crond服务是企业生产工作中常用的重要服务,at很少使用,可以忽略。
3.几乎每个服务器都会用到crond服务。
五、计划任务调试
1、计划任务调试准则
调整任务每分钟执行,检测是否是否正常,有些任务不要频繁执行.
调整系统时间然后在检测任务,生产不建议直接使用此方式
执行脚本,将脚本执行输出写入指定日志文件,观察日志内容是否正常
注意- -些任务命令带来的问题echo“wangqing" >>/tmp/test.log &>/dev/null
命令使用绝对路径,防止无法找到命令导致定时任务执行故障
查看/var/log/cron日志进行调试
2、计划任务调试建议
//建议:
将需要定期执行的任务写入脚本中,建立/scripts目录统- -存 放脚本,脚本中命令必须使用绝对路径,手动执行脚本检测输出是否正常,然后将脚本加入计划任务测试,测试后无问题将脚本输出写入对应的日志文件中即可。
3、计划任务添加步骤:
- 手动执行保留执行命令的正确结果;
- 编写脚本:
- 脚本需要统一路径/scripts
- 脚本开头建议填写注释信息,包括执行时间、周期、任务
- 脚本内容复制执行成功的命令至脚本文件中(减少每个环节出错几率)
- 脚本内容尽可能的优化,使用- -些变量或使用简单的判断语句
- 脚本执行的输出信息不要随意打印,可以重定向至其他位置保留或丢入黑洞
- 执行脚本:
- 使用bash执行,防止脚本没有增加执行权限(/bin/bash)
- 执行命令以及脚本成功后并复制该命令
- 编写计划任务:
- 加上必要的注释信息,人、时间、任务
- 设定计划任务执行的周期
- 加入执行脚本的命令
- 调试计划任务
- 增加任务频率测试、调整系统时间测试(不能用于生产)
- 检查环境变量问题、检查crond服务产生日志进行排查
Linux_计划任务理论概述的更多相关文章
- mamcached+(magent+keepalived高可用)搭建及理论概述
目录 一.理论概述 工作流程 二.部署 环境 环境概述 部署 三.测试 四.总结 一.理论概述 Memcached服务器端与PHP-Memcache客户端安装配置_服务器应用_Linux公社-Linu ...
- CAP理论概述
CAP理论 CAP原则,指在一个分布式系统中,Consistency(一致性).Availability(可用性).Partitiontolerance(分区容错性),三者不可同时拥有. 一致性(C) ...
- Linux_计划任务
[Centos7.4] !!!测试环境我们首关闭防火墙和selinux:免得后面的测试会出现问题 [root@localhost ~]# systemctl stop firewalld [root@ ...
- Linux_软件包管理基本概述
一.回去软件包的途径 1.系统发行版的光盘或官方的服务器镜像站 http://mirrors.aliyun.com //阿里云镜像站 http://mirrors.sohu.com ...
- Oracle RAC学习笔记01-集群理论
Oracle RAC学习笔记01-集群理论 1.集群相关理论概述 2.Oracle Clusterware 3.Oracle RAC 原理 写在前面: 最近一直在看张晓明的大话Oracle RAC,真 ...
- 转载:分布式系统的CAP理论
原文转载Hollis原创文章:http://www.hollischuang.com/archives/666 2000年7月,加州大学伯克利分校的Eric Brewer教授在ACM PODC会议上提 ...
- 理论经典:TCP协议的3次握手与4次挥手过程详解
1.前言 尽管TCP和UDP都使用相同的网络层(IP),TCP却向应用层提供与UDP完全不同的服务.TCP提供一种面向连接的.可靠的字节流服务. 面向连接意味着两个使用TCP的应用(通常是一个客户和一 ...
- “ML学分计划”说明书
计划的由来 我们是一群对机器学习感兴趣的小伙伴,对于神奇的机器学习经常有"一探究竟"的冲动,却因为孤身一人学习的寂寞.亦或繁忙考试工作之余的小小拖延症,而没有持续这份对知识的渴求和 ...
- 分布式系统的CAP理论
一.CAP理论概述 一个分布式系统最多只能同时满足一致性(Consistency).可用性(Availability)和分区容错性(Partition tolerance)这三项中的两项. 二.CAP ...
随机推荐
- Python数据分析入门(十七):绘制条形图
条形图的绘制方式跟折线图非常的类似,只不过是换成了plt.bar方法.plt.bar方法有以下常用参数: x:一个数组或者列表,代表需要绘制的条形图的x轴的坐标点. height:一个数组或者列表,代 ...
- 【Prometheus学习笔记】主机监控 -node_exporter
Exporter for machine metrics prometheus/node_exporter 安装 Prometheus sudo tar -zxvf prometheus-*.tar. ...
- 迷宫问题(BFS)
给定一个n* m大小的迷宫,其中* 代表不可通过的墙壁,而"."代表平地,S表示起点,T代表终点.移动过程中,如果当前位置是(x, y)(下标从0开始),且每次只能前往上下左右.( ...
- 自动化kolla-ansible部署ubuntu20.04+openstack-victoria之创建实例-12
自动化kolla-ansible部署ubuntu20.04+openstack-victoria之创建实例-12 欢迎加QQ群:1026880196 进行交流学习 实例创建 1. 创建 2. 查 ...
- Maven相关知识总结
目录 认识Maven Maven下载安装 Maven能用来做什么 Maven核心概念 开发目录 坐标和仓库 POM文件 POM文件内容 Maven依赖管理 构建生命周期 构建多模块系统 聚合 继承 聚 ...
- Score UVA - 1585
There is an objective test result such as "OOXXOXXOOO". An 'O' means a correct answer of ...
- 深度解析Django REST Framework 批量操作
我们都知道Django rest framework这个库,默认只支持批量查看,不支持批量更新(局部或整体)和批量删除. 下面我们来讨论这个问题,看看如何实现批量更新和删除操作. DRF基本情况 我们 ...
- hdu1839 二分最短路
题意: 给你n个城市,m条双向边,每条边有自己的长度和最大运输量,让你找到一条时间小于等于T的运输能力最大的那条路... 思路: 刚开始以为是费用流呢,后来发现根本不是,因为根 ...
- 使用DirectX截屏
网上有很多关于DirectX截屏的文章,但大都是屏幕截图,很少有窗口截图,本文则两者都涉及到,先讲如何截取整个屏幕,再讲如何截取某个窗口,其实二者的区别不大,只是某个参数的设置不同而已,最后我们还将扩 ...
- 码农飞升记-03-OpenJDK是什么?
目录 1.OpenJDK 概述 2.OpenJDK 的发展史 3.OpenJDK Community 1.角色定义 Participant(参与者) Contributor(贡献者) OpenJDK ...