解读:在什么业务场景适合使用Redis?

Posted 程序员的小傲娇

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解读:在什么业务场景适合使用Redis?相关的知识,希望对你有一定的参考价值。

Redis(Remote Dictionary Server ),即远程字典服务,是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。

那么在什么业务场景适合使用Redis?来看看下面的详细介绍:

(1)会话缓存(Session Cache)

常用的一种使用Redis的情景是会话缓存(session cache)。用Redis缓存会话比其他存储(如Mem cached)的优势在于:Redis提供持久化。当维护一个不是严格要求一致性的缓存时,如果用户的购物车信息全部丢失,大部分人都会不高兴的,现在,他们还会这样吗?

幸运的是,随着Redis这些年的改进,很容易找到怎么恰当的使用Redis来缓存会话的文档。甚至广为人知的商业平台Magento也提供Redis的插件。

(2)全页缓存(FPC)

除基本的会话token之外,Redis 还提供很简便的FPC平台。回到一致性问题,即使重启了Redis实例,因为有磁盘的持久化,用户也不会看到页面加载速度的下降,这是一个极大改进,类似php本地FPC。

再次以Magento为例,Magento 提供一个插件来使用Redis 作为全页缓存后端。

此外,对WordPress的用户来说,Pantheon 有一个非常好的插件wp redis,这个插件能帮助你以快速度加载你曾浏览过的页面。

(3)队列

Reids在内存存储引擎领域的一-大优点是提供list和set操作,这使得Redis能作为一个很好的消息队列平台来使用。Redis作为队列使用的操作,就类似于本地程序语言(如Python)对list 的push/pop操作。

如果你快速的在Google中搜索“Redis queues",你马上就能找到大量的开源项目,这些项目的目的就是利用Redis创建非常好的后端工具,以满足各种队列需求。例如,Celery 有一个后台就是使用Redis作为broker,你可以从这里去查看。

(4)排行榜/计数器

Redis在内存中对数字进行递增或递减的操作实现的非常好。集合(Set)和有序集合(Sorted Set)也使得我们在执行这些操作的时候变的非常简单,Redis 只是正好提供了这

两种数据结构。所以,我们要从排序集合中获取到排名靠前的10个用户-我们称之为“user_scores", 我们只需要像下面一样执行即可:

当然,这是假定你是根据你用户的分数做递增的排序。如果你想返回用户及用户的分数,你需要这样执行:

ZRANGE user scores 0 10 WITHSCORES

Agora Games就是一个很好的例子,用Ruby实现的,它的排行榜就是使用Redis来存储数据的,你可以在这里看到。

(5)发布/订阅

后(但肯定不是不重要的)是Redis的发布/订阅功能。发布/订阅的使用场景确实非常多。我已看见人们在社交网络连接中使用,还可作为基于发布/订阅的脚本触发器,甚至用Redis的发布/订阅功能来建立聊天系统!

什么业务场景适合使用Redis?通过上面的详细介绍大家都了解了吗?希望可以给大家带来帮助,如果大家正在学习Java知识或者是对Java知识比较感兴趣的话,可以关注小千,后期分享更多Java知识。

​本文来自千锋教育,转载请注明出处。

以上是关于解读:在什么业务场景适合使用Redis?的主要内容,如果未能解决你的问题,请参考以下文章

redis常用数据结构介绍和业务应用场景分析

解读高斯Redis的技术架构与应用场景

redis常见应用场景

使用redis,怎么解决并发问题?

一线大厂Redis使用21条军规及详细解读

React Hooks简单业务场景实战(非源码解读)