定时任务的实现

时间:2021-10-17 07:46:18

定时任务

关于定时任务有很多种实现方式,介绍一下了解过的三种,分别是mysql的事件调度器,linux的cron计划任务,以及使用php实现。


mysql

自MySQL5.1.6起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录、对数据进行汇总等等),来取代原先只能由操作系统的计划任务来执行的工作。MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务就如上面提到的cron只能精确到每分钟执行一次。

我们要先看下event_scheduler是否已经开启:
SHOW VARIABLES LIKE ‘event_scheduler’;

SELECT @@event_scheduler;

SHOW PROCESSLIST;
如果是关闭状态的话,执行以下语句开启:
SET GLOBAL event_scheduler = ON;

随后执行语句(例句):

CREATE EVENT st_to_deal ON SCHEDULE EVERY 1 DAY DO UPDATE apply set state = 1 where state = 0

php(转)

ignore_user_abort()函数搭配set_time_limit(0)和sleep($interval)即可实现以上自动更新。

<?php ignore_user_abort(); // run script. in background set_time_limit(0); // run script. forever $interval=30; // do every 15 minutes... do{ $fp = fopen('text3.txt','a'); fwrite($fp,'test'); fclose($fp); sleep($interval); // wait 15 minutes }while(true); ?>

首先运行该程序,然后关闭该页面,程序仍然运行中,test会每隔30秒的填补到text3.txt文件。

在 PHP 内部,系统维护着连接状态,其状态有三种可能的情况:

0 - NORMAL(正常)
1 - ABORTED(异常退出)
2 - TIMEOUT(超时)

当 PHP 脚本正常地运行 NORMAL 状态时,连接为有效。当远程客户端中断连接时,ABORTED 状态的标记将会被打开。远程客户端连接
的中断通常是由用户点击 STOP 按钮导致的。当连接时间超过 PHP 的时限时,TIMEOUT 状态的标记将被打开。

可以决定脚本是否需要在客户端中断连接时退出。有时候让脚本完整地运行会带来很多方便,即使没有远程浏览器接受脚本的输出。默认的情况是当远程客户端连接中断时脚本将会退出。该处理过程可由 php.ini 的 ignore_user_abort 或由 Apache .conf 设置中对应的”php_value ignore_user_abort”以及 ignore_user_abort() 函数来控制。如果没有告诉 PHP 忽略用户的中断,脚本将会被中断,除非通过 register_shutdown_function() 设置了关闭触发函数。通过该关闭触发函数,当远程用户点击 STOP 按钮后,脚本再次尝试输出数据时,PHP将会检测到连接已被中断,并调用关闭触发函数。

脚本也有可能被内置的脚本计时器中断。默认的超时限制为 30 秒。这个值可以通过设置 php.ini 的 max_execution_time 或 Apache .conf 设置中对应的”php_value max_execution_time”参数或者 set_time_limit() 函数来更改。当计数器超时的时候,脚本将会类似于以上连接中断的情况退出,先前被注册过的关闭触发函数也将在这时被执行。在该关闭触发函数中,可以通过调用 connection_status() 函数来检查超时是否导致关闭触发函数被调用。如果超时导致了关闭触发函数的调用,该函数将返回 2。

需要注意的一点是 ABORTED 和 TIMEOUT 状态可以同时有效。这在告诉 PHP 忽略用户的退出操作时是可能的。PHP 将仍然注意用户已经中断了连接但脚本仍然在运行的情况。如果到了运行的时间限制,脚本将被退出,设置过的关闭触发函数也将被执行。在这时会发现函数 connection_status() 返回 3。


cron

启动

1.在系统中有service这个命令时:
这个命令在red hat当中常用,有的linux发行版本中没有这个命令
$ service crond start //启动服务
$ service crond stop //关闭服务
$ service crond restart //重启服务

2.linux发行版本没有service这个命令时:
/etc/init.d/cron stop
/etc/init.d/cron start

编写shell脚本

执行需要执行的任务

加入计划任务

crontab -e 编辑当前用户的cron任务
格式:

0 */4 * * * /etc/myplan/cron.daily.plan/papapa.sh 1> /dev/null 2>&1

前面的

0 */4 * * *

代表每隔四小时的0分的时候执行一次,以此类推,后面三个星为日、月、星期

编辑后cron服务应该是不需要重启就生效的

顺带解释
1>/dev/null 表示标准输出重定向到空设备文件,也就是不输出任何信息到终端。
2>&1 标准错误输出重定向等同于标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件。