2026-03-23 11:03:11
大家好,今天小编关注到一个比较有意思的话题,就是关于php连接redis的问题,于是小编就整理了4个相关介绍php连接redis的解答,让我们一起看看吧。
正常情况下是没有问题的,

但是有人用恶意脚本进行刷奖,也就是同一个人发起大量请求,1秒可能一两百的请求甚至更多,而且不只一个人刷奖。
问题出在1这一步
举个例子,假设每人只能抽一次奖,因为请求太快,同一人的a,b两个请求几乎同时来,a走完抽奖逻辑了,并且在抽奖表中插入记录的过程时,因为mysql的性能的问题,b去走1这一步是读不到表中的记录的,因为a的插入根本没有完成。所以b请求会再走一次抽奖逻辑。造成同一人抽奖两次,然后再插入抽奖表。
我关心的是能否a插入抽奖表的瞬间,b就能判断出抽奖表有数据。
所以我觉得问题是mysql写入的不够快,读取的不够快,所以我要采用redis做一层快速缓存。
我们做的抽奖是单一奖品百分之百中奖,只限制奖品数量,所以必须保证每人只能抽一次,而且尽量在程序层面去解决。
协程间可共享全局变量,同时要维护各自的调用栈结构;这两个要求目前在PHP的架构下较难实现。当然,非阻塞IO是可以通过libevent扩展实现,比如使用laruence的YAR。
//删除单个实体
$redis->hDel('hashkey', 'key1');
//删除整个hash
$redis->del('hashkey');
删除一个redis的key都是用del方法, 不管是string,hash,list,set等类型, 都一样
redis是内存型数据库,mysql是硬盘型数据库,需要长久保存的就存mysql,不需要长期保存切频繁更新的就存redis,他们之间不需要同步!不然就是多此一举,性能反而更差!
到此,以上就是小编对于php连接redis的问题就介绍到这了,希望介绍关于php连接redis的4点解答对大家有用。
上一篇:php5 php7,
下一篇:没有了
Copyright © 2005-2026 代潇瑞博客 www.daixiaorui.com All Rights Reserved.
免责声明: 1、本站部分内容系互联网收集或编辑转载,并不代表本网赞同其观点和对其真实性负责。 2、本页面内容里面包含的图片、视频、音频等文件均为外部引用,本站一律不提供存储。 3、如涉及作品内容、版权和其它问题,请在30日内与本网联系,我们将在第一时间删除或断开链接! 4、本站如遇以版权恶意诈骗,我们必奉陪到底,抵制恶意行为。 ※ 有关作品版权事宜请联系客服邮箱:478923*qq.com(*换成@)
渝ICP备2023009091号-21