zoukankan      html  css  js  c++  java
  • PHP+Redis有序集合(zset)实现博客园阅读排行榜功能

    许多网站都有排行榜的功能,比如球员人气榜单、阅读排行榜,对于一些小网站,通过查数据库就能实现排行榜的功能,但是对于稍微有点用户量而且还是实时排名的网站,使用一些关系型数据库如(MySQL、Oracle)等来实现就有点力不从心了,而且对数据库的压力也很大,体验也不好,更好的选择是使用Redis就是来做排行榜功能,因为Redis提供的有序集合(zset)非常适合做实时排行榜这个业务。

    示例:今天我们就来使用PHP+Redis的zset来实现博客园网站的阅读排行榜功能,博客园的文章阅读排行榜页面如下

    假设现在有8篇文章,文章ID分别是1101、1102、1103、1104、1105、1106、1107、1108,我们使用redis的有序集合(zset)的score作为阅读次数来记录每篇文章的阅读量,view_nums作为记录阅读量的key

    现在,文章ID为1101、1102、1103、1104、1105、1106、1107、1108的文章分别被读者阅读了12次、245次、6次、99次、1267次、23次,456次,9999次

    我们使用PHP代码来实现记录阅读次数,使用的是zIncrBy()方法

    $redis = new Redis();
    if (!$redis->connect('127.0.0.1', 6379)) {
        trigger_error('Redis连接出错!!!', E_USER_ERROR);
    } else {
        echo '连接正常<br>';
    }
    //参数1: key(键)
    //参数2: score(分数,本示例表示阅读量)
    //参数3: member(成员,本示例表示文章ID)
    $redis->zIncrBy('view_nums', 12, 1101);
    $redis->zIncrBy('view_nums', 245, 1102);
    $redis->zIncrBy('view_nums', 6, 1103);
    $redis->zIncrBy('view_nums', 99, 1104);
    $redis->zIncrBy('view_nums', 1267, 1105);
    $redis->zIncrBy('view_nums', 23, 1106);
    $redis->zIncrBy('view_nums', 456, 1107);
    $redis->zIncrBy('view_nums', 9999, 1108);
    
    $redis->close();
    

    上面的这串代码应该放到文章详情页接口里,正常来说每次点击详情页score都应该加1,这里为了演示,一次就增加了很多数。

    我们通过Redis Desktop Manager软件来查看目前的阅读量情况

    可以发现在redis的view_nums有序集合中,已经按照score的大小默认升序排序了。

    现在我们要写一个阅读量前五的文章列表,这里需要使用zRevRange()方法

    //1.初始化Redis连接
    $redis = new Redis();
    if (!$redis->connect('127.0.0.1', 6379)) {
        trigger_error('Redis连接出错!!!', E_USER_ERROR);
    } else {
        echo '连接正常<br>';
    }
    
    //2.获取倒序的view_nums的前5个,下标从0开始,所以是[0~4],第四个参数表示是否使用score排名
    $list = $redis->zRevRange('view_nums', 0, 4, true);
    
    //3.关闭redis连接
    $redis->close();
    
    var_dump($list);
    

    通过打印的结果可以看到,输出结果是以文章ID为key,值为阅读量的一个数组,并且是按照阅读量降序排序的。

    拿到结果之后,我们就可以提取出文章ID,然后从数据库中取出这个几个文章的标题

    //获取文章ID
    $ids = array_keys($list);
    
    //将文章ID转成字符串,以逗号分隔
    $idStr = implode(',', $ids);
    
    //拼接SQL
    $sql = "select id, title from article where id in($idStr)";
    //使用PDO连接MySQL查询出结果,并将结果返回给客户端
    

    这里写的是伪代码,具体留给你们自己实现吧

  • 相关阅读:
    数据库部署
    css常见问题
    extjs记录
    C#相关问题
    window疑难问题解决
    常用linq
    不同数据库之间的相互链接
    聊天数据库
    无线路由接入
    [转]如何才能让你的简历被谷歌相中
  • 原文地址:https://www.cnblogs.com/myJuly/p/13644615.html
Copyright © 2011-2022 走看看