mysql排它锁索引生效_mysql排它锁碰到的问题

问题描述

通过定时任务发送微信消息推送,每分钟执行一次php脚本

为了避免重复发送,加入了排它锁,发现添加的索引未生效,mysql返回报错,期间新的数据插入也未成功

添加的索引未生效,是否导致行锁升级为了表锁?

9d04f085292451431d353ac1fb78dfc6.png

相关代码

// 请把代码文本粘贴到下方(请勿用图片代替代码)

public function send_test()

{

M()->startTrans();

try{

$sql = "select * from wh_wechat_notification where status = 0 for update";

$wechat_info = M()->query($sql);

foreach ($wechat_info as $key => $val) {

$fp = fsockopen('api.weixin.qq.com', 80, $error, $errorstr, 1);

$http = "POST /cgi-bin/message/template/send?access_token={$this->access_token} HTTP/1.1\r\nHost: api.weixin.qq.com\r\nContent-type: application/x-www-form-urlencoded\r\nContent-Length: " . strlen($val['data']) . "\r\nConnection:close\r\n\r\n{$val['data']}\r\n\r\n";

fwrite($fp, $http);

while (!feof($fp))

{

$content = fgets($fp);

}

fclose($fp);

$res = json_decode($content,true);

if($res['errcode'] == 0 || $res['errcode'] == 43004) {

$save['status'] =1;

$save['send_at'] =date('Y-m-d H:i:s');

M('wechat_notification')->where("id ={$val['id']}")->save($save);

}else{

F('wx_token',['value' => null,'time' => time() - 1]);

\Think\Log::write("模板消息推送失败,返回结果:\r\n".implode(',',$res) ,'WARN');

//break;

}

}

M()->commit();

}catch (\Exception $e){

M()->rollback();

}

}

769adbc36fef5c6e74559e705e60d1c6.png

在此过程中,用户反馈收到三条重复推送,分别对应上面红框中的两次任务推送和mysql恢复正常之后的第一次推送。

希望大佬解答一下原因和解决方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值