PHP使用Redis实现防止大并发下二次写入的方法
2017-10-09 10:34
946 查看
PHP调用redis进行读写操作,大并发下会出现:读取key1,没有内容则写入内容,但是大并发下会出现同时多个php进程写入的情况,这个时候需要加一个锁,即获取锁的php进程有权限写。
$lock_key = 'LOCK_PREFIX' . $redis_key; $is_lock = $redis->setnx($lock_key, 1); // 加锁 if($is_lock == true){ // 获取锁权限 $redis->setex($redis_key, $expire, $data); // 写入内容 // 释放锁 $redis->del($lock_key); }else{ return true; // 获取不到锁权限,直接返回 }
思路是:设置一个锁的key,setnx是原子操作,只能一个进程写入成功,写入成功返回true(表示获取锁权限),然后写入内容再释放锁即删除锁key。获取不到锁的进程直接返回。但是这里有种情况,获取锁权限的进程,获取锁后运行报错了,导致没有释放锁,那么一直就不能写入内容,这时就需要拿不到锁权限的进程去判断锁的剩余有效时间,如果为-1则设置锁的有效时间为5秒(预留5秒给拿到锁的进程的运行时间,足够多了)。改良后的代码:
$lock_key = 'LOCK_PREFIX' . $redis_key; $is_lock = $redis->setnx($lock_key, 1); // 加锁 if($is_lock == true){ // 获取锁权限 $redis->setex($redis_key, $expire, $data); // 写入内容 // 释放锁 $redis->del($lock_key); }else{ // 防止死锁 if($redis->ttl($lock_key) == -1){ $redis->expire($lock_key, 5); } return true; // 获取不到锁权限,直接返回 }
更多关于PHP相关内容感兴趣的读者可查看本站专题:《php+redis数据库程序设计技巧总结》、《php面向对象程序设计入门教程》、《PHP基本语法入门教程》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- PHP使用redis防止大并发下二次写入
- PHP实现Redis单据锁以及防止并发重复写入
- php结合redis高并发下发帖、发微博的实现方法
- php使用redis防止并发
- PHP使用redis实现统计缓存mysql压力的方法
- PHP使用curl_multi实现并发请求的方法示例
- php使用redis实现高并发下的抢购功能
- PHP使用redis实现统计缓存mysql压力的方法
- php结合redis高并发下发帖、发微博的实现方法
- php实现的redis缓存类定义与使用方法示例
- 使用php+apc实现上传进度条且在IE7下不显示的问题解决方法
- 使用php伪造referer的方法 利用referer防止图片盗链
- PHP中使用cURL实现Get和Post请求的方法
- phpcms关于url路由在二次开发中的使用方法介绍-实现泛解析
- PHP中使用cURL实现Get和Post请求的方法
- 实现Nginx中使用PHP-FPM时记录PHP错误日志的配置方法
- PHP使用CURL实现对带有验证码的网站进行模拟登录的方法
- 利用redis实现高并发写入
- phpredis使用方法
- java使用jsp servlet来防止csrf 攻击的实现方法