`

Redis作者谈Redis应用场景

 
阅读更多

 

Redis作者谈Redis应用场景

 

毫无疑问,Redis开创了一种新的数据存储思路,使用Redis,我们不用在面对功能单调的数据库时,把精力放在如何把大象放进冰箱这样的问题上,而是利用Redis灵活多变的数据结构和数据操作,为不同的大象构建不同的冰箱。希望你喜欢这个比喻。

 

下面是一篇新鲜出炉的文章,其作者是Redis作者@antirez,他描述了Redis比较适合的一些应用场景,NoSQLFan简单列举在这里,供大家一览:

 

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

 

比如典型的取你网站的最新文章,通过下面方式,我们可以将最新的5000条评论的ID放在Redis的List集合中,并将超出集合部分从数据库获取

 

  • 使用LPUSH latest.comments<ID>命令,向list集合中插入数据
  • 插入完成后再用LTRIM latest.comments 0 5000命令使其永远只保存最近5000个ID
  • 然后我们在客户端获取某一页评论时可以用下面的逻辑(伪代码)

 

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 set的score,将具体的数据设置成相应的value,每次只需要执行一条ZADD命令即可。

 

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

 

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

 

4.计数器应用

 

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

 

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

 

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

 

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

 

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

 

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

 

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

 

8.构建队列系统

 

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

 

9.缓存

 

这个不必说了,性能优于Memcached,数据结构更多样化。

 

来源:antirez.com

分享到:
评论

相关推荐

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

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

    redis应用场景简介

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

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

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

    redis基本使用已经应用场景

    redis基本使用已经应用场景

    若依前后端分离版去redis版/无redis版本

    基于前后端分离的应用,无论是否使用Redis,都需要考虑如何进行数据的存储和缓存。下面我将分别介绍基于Redis和无Redis的两种版本的特点。 基于Redis的版本 特点 缓存处理:Redis作为内存数据库可以用来缓存频繁访问...

    redis的使用场景.doc

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

    Redis特性和应用场景.doc

    Redis特性和应用场景

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

    本书作者在掌阅维护着上千个 Redis 实例的集群; 他在 Redis 持久化,缓存,消息队列的各类实战经验,都毫无保留的凝聚到了这本小册子里,阅读后会对redis有更深入的认识; 本书在介绍原理性的知识时使用图来进行...

    Redis数据类型及应用场景

    除此之外,Redis 主要是作为内存数据库来使用,也就是说,数据是存储在内存中的。尽管它经常被用作内存数据库,但是,它也支持将数据持久化到硬盘中。 2、Redis的每个数据类型是处理不同业务场景而诞生,基本数据...

    Redis集群以及应用场景

    Redis集群以及应用场景

    redis常见应用场景.pdf

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

    C#操作Redis明细内容 C#调用redis c#使用redis业务 C# Redis操作类 C#中Redis封装的类 C#

    4)应用场景广泛:常作为缓存使用,分布式锁、数据共享等 Redis 支持的数据类型有哪些?1)String(字符类型) 2)Hash(散列类型) 3)List(列表类型) 4)Set(集合类型) 5)SortedSet(有序集合类型,简称zset) 6)...

    Redis面试必备知识点:使用场景及应用示例详解

    Redis是一个高性能的内存数据库,被广泛应用于...最后,Redis应用示例有很多,以下是一些常见的示例: 缓存示例:将热点数据缓存到Redis中,如网站的首页数据、商品信息等。 计算结果缓存示例:将一些计算结果缓存到Red

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

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

    redis应用场景,如何应用

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

    spring boot redis配置及使用+redis

    Redis介绍 NoSQL介绍 Redis介绍 Redis安装:Docker-Compose安装 使用redis-cli连接Redis 使用图形化界面连接Redis Redis常用命令 5种常用数据类型应有场景 5种常用数据类型命令 ...验证码+redis应用 Redis常见问题

    Redis特性和应用场景

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

    Redis面试题50道(含答案)_.pdf

    13、Redis 有哪些适合的场景? 14、Redis 支持的 Java 客户端都有哪些?官方推荐用哪个? 15、Redis 和 Redisson 有什么关系? 16、Jedis 与 Redisson 对比有什么优缺点? 17、Redis 如何设置密码及验证密码? 18、...

    尚硅谷_Redis.docx

    在本课程中,你将了解Redis是什么、能干什么、如何用,了解NoSQL的使用场景和概念,快速掌握Redis的安装配置、五大数据类型、常用操作命令、Redis持久化、主从复制、事务控制以及用Jedis操作进行Java开发等知识。...

    Redis 常用命令和场景使用.docx

    redis 常用命令、场景使用整理

Global site tag (gtag.js) - Google Analytics