Redis、Guava、Memcached,我为什么选择了 Redis?-LMLPHP

简单来说,Redis 就是一个数据库。


不同于传统数据库将数据保存在磁盘中,Redis 将数据存在内存中,所以它也经常被叫做内存数据库;同时 Redis 存储也被叫做  NoSQL 数据库、非关系型数据库。


因为 Redis 将数据保存在内存中,所以读写速度会非常快,因此 Redis 被广泛应用做缓存或其他需要高速读写的场景。





软件架构中引入 Redis ,是因为它“又快又强”。


1. 快,是指性能高


计算机硬件的速度由低到高:硬盘-网络-内存-CPU;


在传统的数据库中,如果第一次访问数据库中的某条数据,通常是比较慢的,因为数据库需要从硬盘上读取数据;而 Redis 中的数据保存在了内存中,所以速度会比从磁盘中读取数据快得多。


所以我们经常把 Redis 当做缓存:第一次从数据库中读取数据,并放入 Redis ,后面直接访问 Redis 就可以了。


2. 强,是指高并发场景下的稳定性(高可用)


在高并发的场景下,Redis 能够承受的访问极限,是远远大于数据库的,所以我们可以考虑把需要高并发读的数据放到 Redis 中;


比如秒杀功能,短短几秒内可能就会有数十万笔的访问,如果直接操作数据库的话,数据库可能瞬间就被击垮了。





当然,也不是说所有的场景、所有的数据都适合放进 Redis 中,通常我们需要考虑以下几点:








  • Redis 支持更丰富的数据类型,Memcache 支持简单的数据类型String;

  • Redis 支持数据的持久化,可以将内存中的数据保存到硬盘中,重启之后把数据加载到内存中,而 Memcache  只是把数据保存在内存中 ;

  • Redis 目前支持集群模式,而 Memcached 没有原生的集群模式,需要使用方自己实现;

  • Redis 使用单线程的多路 IO 复用模型(Redis 在最新的 6.0 版本中开始支持多线程);Memcached 使用的是多非阻塞IO复用的网络模型。


Redis、Guava、Memcached,我为什么选择了 Redis?-LMLPHP


最后再强调一点,是否要引入 Redis?使用本地缓存还是分布式缓存?都需从项目的实际情况出发;Redis 丰富的数据类型对持久化的支持,会更加适合我们的项目。


Redis、Guava、Memcached,我为什么选择了 Redis?-LMLPHP

本文分享自微信公众号 - 会点代码的大叔(CodeDaShu)。
如有侵权,请联系 [email protected] 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

05-15 03:38