# Linux 设置定时任务crontab命令
网址: https://www.cnblogs.com/zoulongbin/p/6187238.html
## 1、 crontab命令概念
`crontab`命令用于设置周期性被执行的指令。该命令从标准输入设备读取指令,并将其存放于`crontab`文件中,以供之后读取和执行。
`cron` 系统调度进程。 可以使用它在每天的非高峰负荷时间段运行作业,或在一周或一月中的不同时段运行。cron是系统主要的调度进程,可以在无需人工干预的情况下运行作业。
`crontab` 命令允许用户提交、编辑或删除相应的作业。每一个用户都可以有一个`crontab`文件来保存调度信息。系统管理员可以通过 `/etc/cron.deny` 和 `/etc/cron.allow` 这两个文件来禁止或允许
用户拥有自己的`crontab`文件。
## 2、检查是否安装了crontab
如果提示未安装请自行安装,crontab安装包在系统光盘里面的`pacekage`文件夹`crontabs`安装包。
![mark](http://qiniu.newthink.cc/blog/20181213/z4l3k5X79tbx.png)
```
rpm -qa | grep crontab
```
## 3、 crontab服务启动与关闭。
![mark](http://qiniu.newthink.cc/blog/20181213/bG6Qpw1lrVSX.png)
```
/etc/init.d/crond stop 关闭服务
/etc/init.d/crond start 开启服务
/etc/init.d/crond restart 重启服务
/etc/init.d/crond reload 重新载入配置
```
## 4、 全局配置文件:
`crontab` 在 `/etc` 目录下面存在 `cron.hourly,cron.daily,cron.weekly,cron.monthly,cron.d` 五个目录和`crontab,cron.deny` 二个文件。
![mark](http://qiniu.newthink.cc/blog/20181213/6WsyvFR9hLv2.png)
`cron.daily`是每天执行一次的job
`cron.weekly`是每个星期执行一次的job
`cron.monthly`是每月执行一次的job
`cron.hourly`是每个小时执行一次的job
`cron.d`是系统自动定期需要做的任务
`crontab`是设定定时任务执行文件
`cron.deny`文件就是用于控制不让哪些用户使用Crontab的功能
## 5、 用户配置文件:
![mark](http://qiniu.newthink.cc/blog/20181213/Snmn3AY4WwLQ.png)
每个用户都有自己的cron配置文件,通过`crontab -e` 就可以编辑,一般情况下我们编辑好用户的`cron`配置文件保存退出后,系统会自动就存放于`/var/spool/cron/`目录中,文件以用户名命名.linux的cron服务是每隔一分钟去读取一次/var/spool/cron,/etc/crontab,/etc/cron.d下面所有的内容.
## 6、 crontab文件格式:
![mark](http://qiniu.newthink.cc/blog/20181213/gHnUW9YcjxsD.png)
```
* * * * * command
minute hour day month week command
分 时 天 月 星期 命令
```
`minute`: 表示分钟,可以是从0到59之间的任何整数。
`hour`:表示小时,可以是从0到23之间的任何整数。
`day`:表示日期,可以是从1到31之间的任何整数。
`month`:表示月份,可以是从1到12之间的任何整数。
`week`:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日。
`command`:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件。
## 7、 特殊字符:
星号(*):代表每的意思,例如month字段如果是星号,则表示每月都执行该命令操作。
逗号(,):表示分隔时段的意思,例如,“1,3,5,7,9”。
中杠(-):表示一个时间范围,例如“2-6”表示“2,3,4,5,6”。
正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。
## 8、在home目录下编写一个test.sh脚本,脚本功能是把/home下ifcfg-eth0这个文本复制到/mnt目录下。
![mark](http://qiniu.newthink.cc/blog/20181213/3cFLqLjzaVnp.png)
## 9、运行crontab –e 编写一条定时任务 */5 * * * * /home/test.sh 在每5分钟执行一次test.sh脚本。
![mark](http://qiniu.newthink.cc/blog/20181213/LPFVWYS8CVsB.png)
![mark](http://qiniu.newthink.cc/blog/20181213/ElEGgHfWeOTI.png)
## 10、查询当前用户定时任务或删除当前用户定时任务。
![mark](http://qiniu.newthink.cc/blog/20181213/bW66msqaaaB9.png)
## 11、设置crond开机自动启动。
![mark](http://qiniu.newthink.cc/blog/20181213/Y9B10UqTMirX.png)
## 12、实例:
![mark](http://qiniu.newthink.cc/blog/20181213/XqRb9qQLJGqo.png)
>每月每天凌晨3点30分和中午12点20分执行test.sh脚本
```
30 3,12 * * * /home/test.sh
```
>每月每天每隔6小时的每30分钟执行test.sh脚本
```
30 */6 * * * /home/test.sh
```
>每月每天早上8点到下午18点每隔2小时的每30分钟执行test.sh脚本
```
30 8-18/2 * * * /etc/init.d/network restart
```
>每月每天晚上21点30分执行test.sh脚本
```
30 21 * * * /etc/init.d/network restart
```
>每月1号、10号、22号凌晨4点45分执行test.sh脚本
```
45 4 1,10,22 * * /etc/init.d/network restart
```
>8月份周一、周日凌晨1点10分执行test.sh脚本
```
10 1 * 8 6,0 /etc/init.d/network restart
```
>每月每天每小时整点执行test.sh脚本
```
00 */1 * * * /etc/init.d/network restart
```
注意:
>写法不规范,分钟应该写成 00
```
* 23,00-07/1 * * * /etc/init.d/network restart
```
>强调,周和日尽量不要同时使用,否则达不到想要的效果
```
00 11 * 4 1-3 /etc/init.d/network restart
```
- centos
- 安装工具
- 安装nginx
- 安装PHP5
- 安装PHP7.0.1
- 安装PHP7.0.8
- 安装redis
- redis允许远程访问
- 安装php之redis扩展
- 安装mysql
- 配置nginx虚拟机绑定域名
- xdebug下载配置
- phpStorm远程调试配置
- 报错解决:安装PHP7解决问题方法
- 报错解决:xdebug-解决问题
- yum丢失的解决办法
- CentOS下安装JDK的四种方法
- workman
- 某服务器配置情况
- 安装PHP7.2.17
- 安装PHP7.1.27
- 安装MongoDB
- ubuntu
- mac
- window
- phpstrom+wamp+xdebug
- mysql
- MySql创建本地用户和远程用户 并赋予权限
- 自建主从复制-mycat
- 数据库优化
- 阿里云mysql主从复制
- 报错解决
- SQL分析
- group by
- Mysql定时备份数据脚本
- MySQL数据库远程连接开启方法
- 启动报错systemctl status
- 日志导出
- mysq进程
- mysql查询正在执行的进程
- 命令
- nginx
- 安装GIT
- access.log
- error.log分析
- 500 Internal Server Error错误
- 502解决方案
- 405 Not Allowed,nginx静态文件响应post请求
- Linux基本操作
- 创建用户
- chmod命令详细用法设置文件的权限
- chown命令
- chgrp命令:改变文件的群组
- Linux 设置定时任务crontab命令
- 其他问题
- Win10 Subsystem Linux : Ubuntu 的root密码
- 安全问题
- PHP安全设置
- redis
- 安装
- 安装2.8.17
- 问题
- 日志分析
- an upstream response is buffered to a temporary file
- too many open files
- worker_connections are not enough
- recv() failed
- 日志
- 系统日志
- apache访问日志与错误日志
- nginx访问日志与错误日志
- php错误日志
- php-fpm慢日志
- mysql慢日志
- 服务器优化
- php-fpm进程数优化
- 服务器安全
- RHSA-2018:2748: kernel security and bug fix update
- RHSA-2018:3408: git security update
- RHSA-2018:2570: bind security update
- RHSA-2018:3052: wget security and bug fix update
- RHSA-2018:3221: openssl security, bug fix, and enhancement update
- RHSA-2018:2384: kernel security and bug fix update
- RHSA-2018:3032: binutils security, bug fix, and enhancement update
- RHSA-2018:3157: curl and nss-pem security and bug fix update
- RHSA-2018:2285: yum-utils security update
- RHSA-2018:3092: glibc security, bug fix, and enhancement update
- CVE-2018-17182 on Ubuntu 14.04 LTS (trusty)
- CVE-2018-9415 on Ubuntu 14.04 LTS (trusty)
- CVE-2018-8043 on Ubuntu 14.04 LTS (trusty)
- CVE-2018-3620 on Ubuntu 14.04 LTS (trusty)
- CVE-2018-14634 on Ubuntu 14.04 LTS (trusty)
- CVE-2018-14609 on Ubuntu 14.04 LTS (trusty)
- CentOS Linux 7安全基线检查
- Redis安全基线检查
- RHSA-2019:1168-重要: 内核 安全更新
- RHSA-2019:1481-重要: 内核 安全更新
- RHSA-2019:0512-重要: 内核 安全和BUG修复更新
- ThinkPHP漏洞
- ThinkPHP 5.1.X <= 5.1.30 远程代码执行漏洞
- ThinkPHP 5 <=5.0.22 远程代码执行高危漏洞
- ThinkPHP <5.0.24 Request.php 远程代码执行漏洞
- PHP
- 怎样获取PHP各种版本
- 攻击
- SSH暴力破解
- RDP暴力破解
- SQLSERVER暴力破解
- MYSQL暴力破解
- FTP暴力破解
- SQL注入
- 代码执行
- XSS攻击
- 本地文件包含
- 远程文件包含
- 脚本木马
- 上传漏洞
- 路径遍历
- 越权访问
- CSRF
- CRLF
- 其他