当前位置:首页 > 科技动态 > 正文

php redis分布式锁面试题 redis分布式锁面试题

php redis分布式锁面试题 redis分布式锁面试题

大数据分析师面试题:Redis的耐久化战略 Redis有两种持久化的方式,一种是RDB,另外种是AOF。RDB是将Redis内存中数据的快照存储在磁盘内,是Redis的...

大数据分析师面试题:Redis的耐久化战略

Redis有两种持久化的方式,一种是RDB,另外种是AOF。RDB是将Redis内存中数据的快照存储在磁盘内,是Redis的默认持久化方案。

RDB 可以最大化 Redis 的性能:父进程在保存 RDB 文件时唯一要做的就是 fork 出一个子进程,然后这个子进程就会处理接下来的所有保存工作,父进程无须执行任何磁盘 I/O 操作。

前言Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。有字符串,链表,集 合和有序集合。支持在服务器端计算集合的并,交和补集(difference)等,还支持多种排序功能。

存储结构: 内容是redis通讯协议(RESP )格式的命令文本存储。比较: aof文件比rdb更新频率高,优先使用aof还原数据。

因此在保证完整语义的同时,我们要尽量的缩短键值对的存储长度,必要时要对数据进行序列化和压缩再存储,以 Java 为例,序列化我们可以使用 protostuff 或 kryo,压缩我们可以使用 snappy。

RDB 持久化机制 :是对 redis 数据执行周期性的持久化。这种方式就是将内存中数据以快照的方式写入到二进制文件中,默认的文件名为 dump.rdb。客户端也可以使用save或者bgsave命令通知redis做一次快照持久化。

面试问题redis有哪些集群方案

1、Redis Cluster是Redis 0以后才正式推出,时间较晚,目前能证明在大规模生产环境下成功的案例还不是很多,需要时间检验。Redis Sharding集群Redis 3正式推出了 集群技术,解决了多Redis实例协同服务问题。

2、Redis Sharding集群Redis Sharding是一种客户端Sharding分片技术。Redis Sharding可以说是Redis Cluster出来之前,业界普遍使用的多Redis实例集群方法。

3、以Java语言为例,简单说一下,除了一些公司自主开发的集群外。

4、主机宕机,宕机前有部分数据未能及时同步到从机,切换IP后还会引入数据不一致的问题,降低了系统的可用性。Redis较难支持在线扩容,在集群容量达到上限时在线扩容会变得很复杂。

5、Proxy:现在很多主流的Redis集群都会使用Proxy方式,例如早已开源的Codis。这种方案有很多优点,因为支持原声redis协议,所以客户端不需要升级,对业务比较友好。并且升级相对平滑,可以起多个Proxy后,逐个进行升级。

使用redis实现的分布式锁原理是什么?

1、这就是所谓的分布式锁的开源Redisson框架的实现机制。一般我们在生产系统中,可以用Redisson框架提供的这个类库来基于redis进行分布式锁的加锁与释放锁。

2、Redis分布式锁可以有多种方式实现但是其核心就是通过以下三个Redis命令组合实现。SETNX SETNX key val 当且仅当key不存在时,set一个key为val的字符串,返回1;若key存在,则什么都不做,返回0。

3、所以这个就是redis cluster,或者是redis master-slave架构的主从异步复制导致的redis分布式锁的最大缺陷:在redis master实例宕机的时候,可能导致多个客户端同时完成加锁。

4、分布式锁其实可以理解为:控制分布式系统有序的去对共享资源进行操作,通过互斥来保持一致性。

5、原理很简单,set 一个 锁-key,如果成功则说明加锁成功,反之则失败。

redis分布式锁常见问题及解决方案

使用redis客户端redisson,redisson很好的解决了redis在分布式环境下的一些棘手问题,它的宗旨就是让使用者减少对Redis的关注,将更多精力用在处理业务逻辑上。

注意 rLock.tryLock(10, TimeUnit.SECONDS); 时间要设置大一点,如果等待时间太短,小于获取锁 redis 命令的时间,那么就直接返回获取锁失败了。

在传统单体应用单机部署的情况下,并发问题可以通过使用Java并发相关的锁如synchronized,但是当规模上升到分布式集群的情况下,要控制共享资源访问,就需要通过分布式锁来实现。

Redis有一系列的命令,特点是以NX结尾,NX是Not eXists的缩写,如SETNX命令就应该理解为:SET if Not eXists。这系列的命令非常有用,这里讲使用SETNX来实现分布式锁。用SETNX实现分布式锁 利用SETNX非常简单地实现分布式锁。

引子 redis作为一个强大的key/value数据库,其实还可以用来实现轻量级的分布式锁。

针对这个场景,对应的解决方案一般来说有三种。借助Redis setNX命令设置一个标志位就行。设置成功的放行,设置失败的就轮询等待。

分布式锁的一些细节问题,值得收藏

1、分析源码我们了解 Redisson 模式的分布式,解决了锁过期时间和可重入的问题。但是针对 redis 本身可能存在的单点失败问题,其实是没有解决的。

2、上面这个分布式锁的实现中,大体能够满足了一般的分布式集群竞争锁的需求。这里说的一般性场景是指集群规模不大,一般在10台机器以内。

3、基于Zookeeper:Zookeeper一般用作配置中心,其实现分布式锁的原理和Redis类似,我们在Zookeeper中创建瞬时节点,利用节点不能重复创建的特性来保证排他性。

4、分布式锁的三种实现方式 目前几乎很多大型网站及应用都是分布式部署的,分布式场景中的数据一致性问题一直是一个比较重要的话题。

5、与分布式锁对应的是【单机锁】,我们在写多线程程序时,避免同时操作一个共享变量而产生数据问题,通常会使用一把锁来实现【互斥】,其使用范围是在【同一个进程中】。(同一个进程内存是共享的,以争抢同一段内存,来判断是否抢到锁)。

6、基于ZooKeeper实现分布式锁的步骤如下:(1)redis set px nx + 唯一id + lua脚本 综上所得:没有绝对完美的实现方式,具体要选择哪一种分布式锁,需要结合每一种锁的优缺点和业务特点而定。

最新文章