加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

phpredis提高消息队列的实时性方法(推荐)

发布时间:2020-12-12 08:10:59 所属栏目:MsSql教程 来源:网络整理
导读:数据库存贮都用list形式 要存2个队列 1个用作消息队列保存到数据 还有个 就是用来实时读取数据在redis $redis-lpush($queenkey,json_encode($array)); $redis-lpush($listkey,json_encode($array)); /*消息队列实例*/ public function insertinfo() { $infos

数据库存贮都用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 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',-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,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提高消息队列的实时性方法(推荐)全部内容了,希望大家多多支持编程小技巧~

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读