什么是 Redis

1.什么是 Redis?

redis是非关系型数据库,key-value结构,可设置key的过期时间通过过期策略删除数据、遵守 BSD 协议并开源免费。它将数据持久化在磁盘中,并加载到内存,通过直接访问内存获取数据所以访问速度快但被内存大小所限制不能保存大量的数据,它有2种持久化的方式将数据保存到磁盘,当存放的磁盘满掉时支持多种回收策略,删除部分数据后持久化新的数据,默认无回收策略如果磁盘满后进行保存数据会直接报错。它的单线程的,redis 利用队列技术将并发访问变为串行访问,消除了传统数据库串行控制的开销、所有操作都是原子性的。

2.什么是redis集群?

redis支持集群的方式:主从复制、Sentinel模式(哨兵模式)、Cluster模式。3台redis才能称为集群。
​
主从复制:
 (1)主数据库可以进行读写操作,当读写操作导致数据变化时会自动将数据同步给从数据库
 (2)从数据库一般都是只读的,并且接收主数据库同步过来的数据
 (3)一个master可以拥有多个slave,但是一个slave只能对应一个master
 (4)slave挂了不影响其他slave的读和master的读和写,重新启动后会将数据从master同步过来
 (5)master挂了以后,不影响slave的读,但redis不再提供写服务,master重启后redis将重新对外提      供写服务
 (6)master挂了以后,就不能再提供写操作
 
Sentinel模式(哨兵模式):
 (1)sentinel模式是建立在主从模式的基础上,如果只有一个Redis节点,sentinel就没有任何意义
 (2)当master挂了以后,sentinel会在slave中选择一个做为master,并修改它们的配置文件,其他slave的配置文件也会被修改,比如slaveof属性会指向新的master。当master重新启动后,它将不再是master而是做为slave接收新的master的同步数据
 (3)sentinel因为也是一个进程有挂掉的可能,所以sentinel也会启动多个形成一个sentinel集群,多sentinel配置的时候,sentinel之间也会自动监控
 (4)当主从模式配置密码时,sentinel也会同步将配置信息修改到配置文件中,不需要担心,一个sentinel或sentinel集群可以管理多个主从Redis,多个sentinel也可以监控同一个redis。
 (5)sentinel最好不要和Redis部署在同一台机器,不然Redis的服务器挂了以后,sentinel也挂了
 
Cluster模式
  (1)sentinel模式基本可以满足一般生产的需求,具备高可用性。但是当数据量过大到一台服务器存放不下的情况时,主从模式或sentinel模式就不能满足需求了,这个时候需要对存储的数据进行分片,将数据存储到多个Redis实例中。cluster模式的出现就是为了解决单机Redis容量有限的问题,将Redis的数据根据一定的规则分配到多台机器。redis cluster,主要是针对海量数据+高并发+高可用的场景,海量数据,如果你的数据量很大,那么建议就用redis cluster。
  (2)多个redis节点网络互联,数据共享,所有的节点都是一主一从(也可以是一主多从),其中从不提供服务,仅作为备用。
 不支持同时处理多个key(如MSET/MGET),因为redis需要把key均匀分布在各个节点上,
  并发量很高的情况下同时创建key-value会降低性能并导致不可预测的行为 
  (3)支持在线增加、删除节点,客户端可以连接任何一个主节点进行读写
​
​

3.使用场景

36、Redis 最适合的场景?
1、会话缓存(Session Cache)
​
最常用的一种使用 Redis 的情景是会话缓存(session cache)。用 Redis 缓存会话比其他存储(如 Memcached)的优势在于: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 的发布/订阅功能来建立聊天系统!
​
​

来源博客: https://blog.csdn.net/Design407/article/details/103242874

来源博客:https://blog.csdn.net/miss1181248983/article/details/90056960

你可能感兴趣的:(什么是 Redis)