当前位置: 首页 > news >正文

PHP 实现 redis 分布式锁

分布式锁

如果是强一致性保证,在获取锁或者失败后引入数据库存储扫表、mq 等方式进行补偿

如果可以容忍少量异常就不需要考虑了

像这里的代码,没吃建立一个链接铺货,性能损耗时间延迟也是很大的,也可在一块代码中进行服务,这里是临时修复一个 bug,问题不大

基于 Redis 实现

// 加锁
function acquireLock($lockKey, $lockValue, $expireTime)
{return $this->getRedisConnection()->set($lockKey, $lockValue, array('nx', 'ex' => $expireTime));
}// 释放锁
function releaseLock($lockKey, $lockValue) 
{// 使用 Lua 脚本原子性地释放锁$script = 'if redis.call("get", KEYS[1]) == ARGV[1] thenreturn redis.call("del", KEYS[1])elsereturn 0end';return $this->getRedisConnection()->eval($script, array($lockKey, $lockValue), 1);
}// 重试加锁
function retryAcquireLock($lockKey, $lockValue, $expireTime, $maxRetries, $retryInterval)
{for ($i = 0; $i < $maxRetries; $i++) {if ($this->acquireLock($lockKey, $lockValue, $expireTime)) {return true;}sleep($retryInterval);}return false;
} 

使用示例

// 使用示例
$lockKey = 'my_lock_key'; // key 名称
$lockValue = uniqid(); // 值 保证不释放错
$expireTime = 10; // 总体过期时间
$maxRetries =  4; // 最大重试次数
$retryInterval = 2; // 重试间隔
// 重试间隔 * 次数 不能大于整体过期时间
if ($lockManager->retryAcquireLock($lockKey, $lockValue, $expireTime, $maxRetries, $retryInterval)) {echo "成功获取锁。\n";// 模拟临界区代码执行sleep(5);$lockManager->releaseLock($lockKey, $lockValue);echo "释放锁。\n";
} else {echo "无法获取锁。\n";
}

[PHP 实现 redis 分布式锁 |

    Laiyong Wang](http://laiyong.wang/2024/06/15/PHP-实现-redis-分布式加锁/)
http://www.lryc.cn/news/440120.html

相关文章:

  • vue3 自定义el-tree树形结构样式
  • 【网络安全】分享4个高危业务逻辑漏洞
  • 【装机教程】Visual Studio Community 2019离线安装
  • NumPy 线性代数
  • 家装材料之水泥,最容易被忽视的基础材料!
  • openstack之keystone介绍
  • 【图像拼接】基于SIFT/SURF特征算法的图像拼接,matlab实现
  • 《微信小程序实战(2) · 组件封装》
  • LaTex2024 下载安装运行HelloWorld—全流程笔记
  • Golang | Leetcode Golang题解之第404题左叶子之和
  • 基于yolov8+lprnet的中文车牌识别系统python源码+pytorch模型+精美GUI界面
  • 电信创维光猫DT741超级密码
  • PostgreSQL的流复制断点续传
  • 【bug】通过lora方式微调sdxl inpainting踩坑
  • [Python可视化]数据可视化在医疗领域应用:提高诊断准确性和治疗效果
  • css <样式一>
  • Linux 文件 IO 管理(第一讲)
  • Uniapp + Vue3 + Vite +Uview + Pinia 实现购物车功能(最新附源码保姆级)
  • 人工智能和大模型的简介
  • java -- JDBC
  • supermap iclient3d for cesium模型沿路径移动
  • 基于AlexNet实现猫狗大战
  • 1.接口测试基础
  • 使用mlp算法对Digits数据集进行分类
  • 滑动窗口(2)_无重复字符的最长字串
  • c语言 —— 结构变量
  • 一个py脚本,提供处理 GET 请求返回网站数据,处理 POST 请求接收并打印数据。支持跨域访问。
  • 【Elasticsearch系列六】系统命令API
  • c++概念
  • Makefile 学习笔记(一)gcc编译过程