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

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

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

首先,建立一个数据表sms,包含以下字段:

id,

phone, //手机号

content //短信内容

将需要发送的短信和手机号存入sms表中。

实现的代码如下:

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秒从数据库取一条数据发送短信。

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值