`

redis的应用场景

 
阅读更多

1.取最新N个数据的操作

比如典型的取你网站的最新文章,通过下面方式,我们可以将最新的5000条评论的ID放在RedisList集合中,并将超出集合部分从数据库获取
使用LPUSH latest.comments<ID>命令,向list集合中插入数据
插入完成后再用LTRIM latest.comments 0 5000命令使其永远只保存最近5000ID
然后我们在客户端获取某一页评论时可以用下面的逻辑(伪代码)
FUNCTION get_latest_comments(start,num_items):

   id_list = redis.lrange("latest.comments",start,start+num_items-1)

   IF id_list.length < num_items

   id_list = SQL_DB("SELECT ... ORDER BY time LIMIT ...")

   END

RETURN id_list

END

如果你还有不同的筛选维度,比如某个分类的最新N条,那么你可以再建一个按此分类的List,只存ID的话,Redis是非常高效的。

2.排行榜应用,取TOP N操作

这个需求与上面需求的不同之处在于,前面操作以时间为权重,这个是以某个条件为权重,比如按顶的次数排序,这时候就需要我们的sorted set出马了,将你要排序的值设置成sorted setscore,将具体的数据设置成相应的value,每次只需要执行一条ZADD命令即可。

3.需要精准设定过期时间的应用

比如你可以把上面说到的sorted setscore值设置成过期时间的时间戳,那么就可以简单地通过过期时间排序,定时清除过期数据了,不仅是清除Redis中的过期数据,你完全可以把Redis里这个过期时间当成是对数据库中数据的索引,用Redis来找出哪些数据需要过期删除,然后再精准地从数据库中删除相应的记录。

4.计数器应用

Redis的命令都是原子性的,你可以轻松地利用INCRDECR命令来构建计数器系统。

5.Uniq操作,获取某段时间所有数据排重值

这个使用Redisset数据结构最合适了,只需要不断地将数据往set中扔就行了,set意为集合,所以会自动排重。

6.实时系统,反垃圾系统

通过上面说到的set功能,你可以知道一个终端用户是否进行了某个操作,可以找到其操作的集合并进行分析统计对比等。没有做不到,只有想不到。

7.Pub/Sub构建实时消息系统

RedisPub/Sub系统可以构建实时的消息系统,比如很多用Pub/Sub构建的实时聊天系统的例子。

8.构建队列系统

使用list可以构建队列系统,使用sorted set甚至可以构建有优先级的队列系统。

9.缓存

这个不必说了,性能优于Memcached,数据结构更多样化。
 
总结
Redis使用最佳方式是全部数据in-memory
Redis更多场景是作为Memcached的替代者来使用。
当需要除key/value之外的更多数据类型支持时,使用Redis更合适。
当存储的数据不能被剔除时,使用Redis更合适。(持久化)
分享到:
评论

相关推荐

    Redis应用场景--Redis作者谈Redis应用场景

    Redis应用场景--Redis作者谈Redis应用场景

    redis应用场景简介

    去年我写的培训用教材,redis应用场景简介,简单列举了一些Redis的使用场景。 发现下载积分居然无法调整……

    redis使用场景及数据结构.docx

    redis使用场景及数据结构.docx

    redis应用场景,如何应用

    Redis作为一个典型的非关系型数据库,目前来说在企业级应用中使用广泛。它十分适合存储少、访问量巨大的场景,所有数据全部in-memory保证了数据的高速访问。

    redis常见应用场景.pdf

    redis常见应用场景, 帮我们设计系统架构时排查redis使用场景

    redis的使用场景.doc

    redis的使用场景.doc 处理高并发的缓存技术 什么时候需要使用到此技术

    基于SSM+Redis的餐厅收银管理系统

    基于Spring+SpringMVC+Mybatis+Redis框架,这个只有前台页面,实打实的模仿现实中餐厅所做的,里面的功能都是真实存在的,功能完善的还不错,这个地方使用了Redis来做缓存,Redis我已经给大家放到文件夹里面了 ...

    Redis特性和应用场景.doc

    Redis特性和应用场景

    深入解析Redis中常见的应用场景

    Redis是一个key-value存储系统,现在在各种系统中的使用越来越多,大部分情况下是因为其高性能的特性,被当做缓存使用,这里介绍下Redis经常遇到的使用场景。下面话不多说了,来一起看看详细的介绍吧。 Redis特性 ...

    redis基本使用已经应用场景

    redis基本使用已经应用场景

    77.redis的使用场景?.avi

    redis的使用场景?

    redis五种数据类型的使用场景

    介绍redis的五种数据类型的使用场景,更便于学习redis的操作,了解使用!

    2022最新Redis命令使用场景及案例

    非常完整全面的redis命令手册,详细介绍每个命令使用场景及案例。

    Redis集群以及应用场景

    Redis集群以及应用场景

    1.redis课程介绍.mp4

    1.3.redis使用场景 1.4.下载与安装 1.5.启动与连接 2.redis数据类型 2.1.String 2.1.1.String操作 2.1.2.应用场景 2.2.hash 2.2.1.hash操作 2.2.3.应用场景 2.3.list 2.3.1list基本操作 2.3.3.应用场景 ...

    Redis特性和应用场景

    Redis使用标准C编写实现,而且将所有数据加载到内存中,所以速度非常快。官方提供的数据表明,在一个普通的Linux机器上,Redis读写速度分别达到81000/s和110000/s。 数据结构 可以将Redis看做“数据结构服务器”。...

    redis思维导图.docx

    redis思维导图,文档中另附链接,让你快速应对redis面试复习,对redis使用场景,以及redis存储原理,查询原理,RDB,AOF等进行汇总,一图快速记忆redis,面试BAT轻松搞定

    《Redis深度历险 核心原理与应用实践》_钱文品.pdf

    位图的介绍,通过签到场景的应用逐步介绍; 应用的示例非常多,例如: 线程可重入的分布式锁;heperloglog用于统计uv;bloomfilter用于过滤老数据;geohash用于计算地理位置信息; 我能列举的只是九牛一毛,其内容...

    Redis高性能缓存使用指南

    主要内容  Redis 简介  Redis 特性  其他缓存对比  Redis 集群( 主从复制,Sentinel,Cluster)  Redis 应用场景  Redis 常用客户端  Redis 功能演示  Redis

    Redis数据库的应用场景介绍

    主要介绍了Redis数据库的应用场景介绍,本文讲解了MySql+Memcached架构的问题、Redis常用数据类型、Redis数据类型应用和实现方式、Redis实际应用场景等内容,需要的朋友可以参考下

Global site tag (gtag.js) - Google Analytics