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

 简单两种方法实现每秒执行

 



 

Logo

更多推荐