1、最近在做定时任务,业务逻辑就是需要每秒都需要去数据库增加一个数据 这个数据然后通过接口 显示在阿里的datav的大屏上
现在有两种方法实现这个功能 大家也可以权衡一下 根据自己的业务 进行选择
一,crontab -e (这个例子是延时10s执行的任务,当然你也可以写59个sleep进行每秒执行)
* * * * * php /www/web/wx.php
* * * * * sleep 10; php /www/web/wx.php
* * * * * sleep 20; php /www/web/wx.php
* * * * * sleep 30; php /www/web/wx.php
* * * * * sleep 40; php /www/web/wx.php
* * * * * sleep 50; php /www/web/wx.php
wx.php 打上日志 可以查看执行情况
file_put_contents('/www/web/wx.log', date('Y-m-d H:i:s')."\r\n", FILE_APPEND);
2019-06-12 21:47:01
2019-06-12 21:47:11
2019-06-121 21:47:21
2019-06-12 21:47:31
2019-06-12 21:47:41
2019-06-12 21:47:51
2019-06-12 21:48:01
二、第二个方法shell脚本实现 然后再用crontab 定时执行
wx.sh
#!/bin/bash
step=1 #间隔的秒数,不能大于60
for (( i = 0; i < 60; i=(i+step) )); do
$(php '/www/web/wx.php')
sleep $step
done
exit 0
crontab -e 输入以下语句,然后:wq 保存退出。
然后crontab -e 插入
* * * * * /www/web/wx.sh
简单两种方法实现每秒执行