redis如何回滚 redis哪些操作返回旧值

脑裂以及Redis主从同步中的坑1、所谓的脑裂,就是指在主从集群中,同时有两个主节点,它们都能接收写请求 。而脑裂最直接的影响 , 就是客户端不知道应该往哪个主节点写入数据,结果就是不同的客户端会往不同的主节点上写入数据 。
【redis如何回滚 redis哪些操作返回旧值】2、因为 master - slave的复制是异步 的(客户端发送给redis,主节点数据同步到内存中后就返回成功了) 所以可能有部分数据还没复制到slave,master就宕机了 , 此时master内存中的数据也没了,这些部分数据就丢失了 。
3、redis的集群脑裂是指因为网络问题,导致redis master节点跟redis slave节点和sentinel集群处于不同的网络分区,此时因为sentinel集群无法感知到master的存在,所以将slave节点提升为master节点 。
4、redis集群没有过半机制会有脑裂问题,网络分区导致脑裂后多个主节点对外提供写服务 , 一旦网络分区恢复,会将其中一个主节点变为从节点 , 这时会有大量数据丢失 。
5、主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器 。前者称为主节点(master),后者称为从节点(slave),数据的复制是单向的,只能由主节点到从节点 。
6、部分的重同步过程:主服务器通过向从服务器传播命令来更新从服务器的状态,保持主从服务器一致,而从服务器通过向主服务器发送命令来进行心跳检测,以及命令丢失检测 。
redis的AOF持久化的配置以及工作流程1、以下是AOF工作流程图:Redis中默认不开启AOF ,  appendonly yes,是开启的配置 。文件的名字默认为appendonly.aof,可以通过参数 appendfilename 来设置 。目录也是通过 dir 来设置 。所有写入命令会追加到 aof_buf(缓冲区) 中 。
2、开启AOF功能需要设置配置:appendonly yes,默认不开启 。AOF文件名通过appendfilename配置设置 , 默认文件名是appendonly.aof 。保存路径同RDB持久化方式一致,通过dir配置指定 。
3、在redis的配置里有着这样的一段配置:save 900 1save 300 10save 60 10000很关键的一段配置,这时RDB持久化的核心 。
4、要把redis作为一个系统的daemon进程去运行的 , 每次系统启动,redis进程一起启动,操作不走如下:RDB和AOF是redis的一种数据持久化的机制 。持久化 是为了避免系统在发生灾难性的系统故障时导致的系统数据丢失 。
5、混合 在 Redis 0 就推出了混合持久化的功能 。
redis基本操作命令1、在 Redis 中查看数据可以使用以下命令:keys pattern 命令可以列出匹配给定模式的所有键名 。例如 , 执行 keys * 可以列出所有的键名 。type key 命令可以查看指定键的数据类型 。
2、连接操作相关命令:quit:关闭连接(connection) 。auth:简单密码认证 。value操作命令:exists(key):确认key否存 。del(key):删除key 。type(key):返值类型 。
3、执行如图是命令,查看redis服务是否启动 。执行命令“redis-cli”进入redis命令行界面 。执行命令“dbsize” 。执行命令“flushall”刷新清除 。执行命令“ keys * ”进行验证redis是否为空 , 可以看到redi数据 。
4、set 命令除了基本的用法外,还有几个参数,先来说一下 nx 和 xx 两个参数 。

    推荐阅读