redis 数据类型详解 以及 redis适用场景场合( 四 )
END
这里我们做的很简单 。 在Redis中我们的最新ID使用了常驻缓存 , 这是一直更新的 。 但是我们做了限制不能超过5000个ID , 因此我们的获取ID函数会一直询问Redis 。 只有在start/count参数超出了这个范围的时候 , 才需要去访问数据库 。我们的系统不会像传统方式那样“刷新”缓存 , Redis实例中的信息永远是一致的 。 SQL数据库(或是硬盘上的其他类型数据库)只是在用户需要获取“很远”的数据时才会被触发 , 而主页或第一个评论页是不会麻烦到硬盘上的数据库了 。
2、删除与过滤我们可以使用LREM来删除评论 。 如果删除操作非常少 , 另一个选择是直接跳过评论条目的入口 , 报告说该评论已经不存在 。 有些时候你想要给不同的列表附加上不同的过滤器 。 如果过滤器的数量受到限制 , 你可以简单的为每个不同的过滤器使用不同的Redis列表 。 毕竟每个列表只有5000条项目 , 但Redis却能够使用非常少的内存来处理几百万条项目 。 3、排行榜相关另一个很普遍的需求是各种数据库的数据并非存储在内存中 , 因此在按得分排序以及实时更新这些几乎每秒钟都需要更新的功能上数据库的性能不够理想 。 典型的比如那些在线游戏的排行榜 , 比如一个Facebook的游戏 , 根据得分你通常想要:- 列出前100名高分选手- 列出某用户当前的全球排名这些操作对于Redis来说小菜一碟 , 即使你有几百万个用户 , 每分钟都会有几百万个新的得分 。 模式是这样的 , 每次获得新得分时 , 我们用这样的代码:ZADD leaderboard
4、按照用户投票和时间排序排行榜的一种常见变体模式就像Reddit或Hacker News用的那样 , 新闻按照类似下面的公式根据得分来排序:score = points / time^alpha因此用户的投票会相应的把新闻挖出来 , 但时间会按照一定的指数将新闻埋下去 。 下面是我们的模式 , 当然算法由你决定 。 模式是这样的 , 开始时先观察那些可能是最新的项目 , 例如首页上的1000条新闻都是候选者 , 因此我们先忽视掉其他的 , 这实现起来很简单 。 每次新的新闻贴上来后 , 我们将ID添加到列表中 , 使用LPUSH + LTRIM , 确保只取出最新的1000条项目 。 有一项后台任务获取这个列表 , 并且持续的计算这1000条新闻中每条新闻的最终得分 。 计算结果由ZADD命令按照新的顺序填充生成列表 , 老新闻则被清除 。 这里的关键思路是排序工作是由后台任务来完成的 。
5、处理过期项目另一种常用的项目排序是按照时间排序 。 我们使用unix时间作为得分即可 。 模式如下:- 每次有新项目添加到我们的非Redis数据库时 , 我们把它加入到排序集合中 。 这时我们用的是时间属性 , current_time和time_to_live 。 - 另一项后台任务使用ZRANGE…SCORES查询排序集合 , 取出最新的10个项目 。 如果发现unix时间已经过期 , 则在数据库中删除条目 。
6、计数Redis是一个很好的计数器 , 这要感谢INCRBY和其他相似命令 。 我相信你曾许多次想要给数据库加上新的计数器 , 用来获取统计或显示新信息 , 但是最后却由于写入敏感而不得不放弃它们 。 好了 , 现在使用Redis就不需要再担心了 。 有了原子递增(atomic increment) , 你可以放心的加上各种计数 , 用GETSET重置 , 或者是让它们过期 。 例如这样操作:INCR user:
8、实时分析正在发生的情况 , 用于数据统计与防止垃圾邮件等我们只做了几个例子 , 但如果你研究Redis的命令集 , 并且组合一下 , 就能获得大量的实时分析方法 , 有效而且非常省力 。 使用Redis原语命令 , 更容易实施垃圾邮件过滤系统或其他实时跟踪系统 。
- 查询|数据太多容易搞混?掌握这几个Excel小技巧,办公思路更清晰
- 黑莓(BB.US)盘前涨逾32%,将与亚马逊开发智能汽车数据平台|美股异动 | US
- 健身房|乐刻韩伟:产业互联网中只做单环节很难让数据发挥大作用
- V2X|V2X:确保未来道路交通数据交换的安全性
- 短视频平台|大数据佐证,抖音带动三千万就业,视频手机将成生产力工具?
- 权属|从数据悖论到权属确认,数据共享进路所在
- 介绍|5分钟介绍各种类型的人工智能技术
- 统计|多久才能换一次手机?统计机构数据有点意外
- 发展|大数据解读世界互联网大会·互联网发展论坛!
- 网购|黑色星期五及网购星期一大数据出炉 全球第三方卖家销售额超48亿美元