时间:2021-05-24
数据库存贮都用list形式 要存2个队列 1个用作消息队列保存到数据 还有个 就是用来实时读取数据在redis
$redis->lpush($queenkey, json_encode($array)); $redis->lpush($listkey, json_encode($array));public function insertinfo() { $infos = array('info1' => mt_rand(10,100), 'info2' => mt_rand(10,100)); $this->insertinfos($infos, 'tutorial-list','tutoriallist'); } public function insertinfos($array, $queenkey,$listkey) { //连接本地的 Redis 服务 $redis = new \Redis(); $redis->connect('127.0.0.1', 6379); //存储数据到列表中 $redis->lpush($queenkey, json_encode($array)); $redis->lpush($listkey, json_encode($array)); }读取 逻辑当redis key没有了 就读取数据库 然后重新写入list 有的话就读取redis数据
public function getinfo() { $sql = 'select * from mobantestinfo'; $result = $this->getinfos('tutoriallist', $sql); //redis key不为空 直接读取redis if(empty($result)){ //连接本地的 Redis 服务 $redis = new \Redis(); $redis->connect('127.0.0.1', 6379); // 获取存储的数据并输出 $result = $redis->lrange('tutoriallist', 0, -1); foreach ($result as $k=>$v){ $result[$k]=json_decode($v,true); } print_r($result); exit(); } } function getinfos($key, $sql) { //连接本地的 Redis 服务 $redis = new \Redis(); $redis->connect('127.0.0.1', 6379); // 获取存储的数据 $result = $redis->lrange($key, 0, 1); if (empty($result)) { $VModel = new HuanShanVoteModel(); $result = $VModel->query($sql); //重新将缓存队列的形式放入数据库 foreach ($result as $k=>$v){ //这个地方要从右边插入 来保证跟数据库顺序一样 $redis->rpush($key,json_encode($v)); } } else { $result=0; } return $result; }以上就是小编为大家带来的phpredis提高消息队列的实时性方法(推荐)全部内容了,希望大家多多支持~
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.简介celery(芹菜)是一个异步任务队列/基于分布式消息传递的作业队列。它侧重于实时操作,但对调度支持也很好。celery用于生产系统每天处理数以百万计的
本文实例讲述了PHP高级编程之消息队列原理与实现方法。分享给大家供大家参考,具体如下:1.什么是消息队列消息队列(英语:Messagequeue)是一种进程间通
前言java操作rediscluster集群可使用jredisphp要操作rediscluster集群有两种方式:1、使用phpredis扩展,这是个c扩展,性
本文实例讲述了PHP5.5安装PHPRedis扩展及连接测试方法。分享给大家供大家参考,具体如下:phpredis是个人觉得最好的一个php-redis客户端,
celery简介celery是一个基于分布式消息传输的异步任务队列,它专注于实时处理,同时也支持任务调度。它的执行单元为任务(task),利用多线程,如Even