首页  >  问答  >  正文

linux - 模拟crontab定时器,用PHP和MySQL实现消息队列的问题??

比如说需要做一个批量发送手机短信的功能,如果是用for循坏这样的来做的话,当短信数量很大时,不仅耗时,而且成功率很低。

于是想到,用PHP和MySQL实现一个消息队列,一条一条的发送短信。

首先,建立一个数据表sms,包含以下字段:
id,
phone, //手机号
content //短信内容
将需要发送的短信和手机号存入sms表中。

实现的代码如下:
<?php
while(true){

 $item = $db->getFirstRecord(); //获取数据表第一条记录
 if(!$item){//如果队列中没有数据,则结束定时器
 break;
 }
$res = $sms->send($item['phone'],$item['content']); //发送短信
if($res){
    $db->deleteFristRecord(); //删除发送成功的记录
    echo $item['phone'].'发送成功';
}else{
    echo $item['phone'].'发送失败,稍后继续尝试';
}
sleep(10); //每隔十秒循环一次            

}

echo '发送完毕!';
?>

比如说,后台有一个发送按钮,点击触发上面的程序执行,假设每隔10秒从数据库取一条数据发送短信。

问题:如果我点击发送按钮后就直接点击其他页面做其他的去了,而不是一直在点击页面等待直到发送完毕才离开的话,上面的程序还会执行下去了。还是说我去到其他页面内了,就会跳出循坏不会执行发送短信了

巴扎黑巴扎黑2680 天前656

全部回复(4)我来回复

  • 淡淡烟草味

    淡淡烟草味2017-05-19 10:09:28

    PHP是单线程,也就是你一开始执行,要么等它全部执行完毕,要么提前中断,不能同时进行两个访问。如果说需要点击按钮之后异步处理,直接跳过去干别的事情,那就需要swoole这个服务来处理你要异步处理的事情。

    回复
    0
  • 给我你的怀抱

    给我你的怀抱2017-05-19 10:09:28

    这种情况,直接在命令行模式运行就好了,不用放在后台网页上。然后最上面没有数据就退出的代码,改为sleep一段时间。

    回复
    0
  • 世界只因有你

    世界只因有你2017-05-19 10:09:28

    PHP-Cli模式你可以看一下。慕课网有视频,mysql模拟队列发送邮件,和题主要的效果类似。

    回复
    0
  • 给我你的怀抱

    给我你的怀抱2017-05-19 10:09:28

    我觉的楼主的php+mysql没错,但是cron job还是要用上的。cron job就是设置间隔XX秒执行一下脚本。

    如果非要放弃crontab。那么推荐下面代码

    ignore_user_abort() //关掉浏览器,php脚本可以继续执行
    set_time_limit(0)   // 一直执行下去
    
    $item = $db->getFirstRecord(); //获取数据表第一条记录
     if(!$item){//如果队列中没有数据,则结束定时器
     break;
     }
    $res = $sms->send($item['phone'],$item['content']); //发送短信
    if($res){
        $db->deleteFristRecord(); //删除发送成功的记录
        echo $item['phone'].'发送成功';
    }else{
        echo $item['phone'].'发送失败,稍后继续尝试';
    }
    sleep(10); //每隔十秒循环一次  

    回复
    0
  • 取消回复