Redis面试篇笔记(持续更新)

一、redis主从集群

  单节点redis的并发能力是由上限的,要进一步提高redis的并发能力可以搭建主从集群,实现读写分离,一主多从,主节点写数据,从节点读数据

部署redis主从节点的docker-compose文件命令解析

version: "3.2"services:r1:image: rediscontainer_name: r1network_mode: "host"entrypoint: ["redis-server", "--port", "7001"]r2:image: rediscontainer_name: r2network_mode: "host"entrypoint: ["redis-server", "--port", "7002"]r3:image: rediscontainer_name: r3network_mode: "host"entrypoint: ["redis-server", "--port", "7003"]

①network_mode: "host",这里表示网络模式都是host,之前部署容器都没有指定网络模式,所以默认是桥接模式,桥接模式:容器由docker提供的虚拟网桥与宿主机进行连接,这样容器都有一个虚拟的IP地址,这样redis各个实例之间的交互先通过虚拟网桥再到宿主机网卡进行网络转发,这样集群之间的健康监测会出现一定问题。redis官方告诉我们在搭建集群的时候建议使用host模式,这样redis容器相当于直接暴露在宿主机里面,相当于宿主机普通进程,将来部署的时候不用做端口映射,直接使用宿主机端口就行,但是需要改默认端口(见②)

②entrypoint: ["redis-server", "--port", "7003"]:修改容器启动命令

二、redis主从同步原理

1.全量同步

基于replicationID做判断,与主节点不相同则为第一次建立主从连接,是则执行bgsave命令,生成RDB文件,将RDB文件发给slave进行数据同步(slave需要将本地数据清理完)

2.增量同步

master需要将slave缺失 的数据发送给slave,当建立同步连接后master的repl_backlog(操作越多offset值越大)会记录所有写的操作的命令,slave接收到master数同步时slave的repl_backlog(与主节点操作越一致offset值越多)也会记录写操作,当连接断开,再重新连接,两者的repl_backlog的offset值进行比较,比较出缺失的部分再将缺失的部分进行同步

总结:

1.根据什么判断是否第一次来?

当slave节点第一次和master建立主从关系,建立连接的时候或者是连接建立完了后来断开了重连的时候,slave都会去做这个同步,都会发送一个psync请求,而在发请求的同时会携带两个参数分别是replicationId和offset,那么master呢就需要去判断sleep到底是第一次来呢还是断开重连,判断的依据呢就是replicationID

2.判断原理是怎么样

因为呢在没有建立主从关系的情况下,每一个节点都认为自己是master,他们都会有自己唯一的replicationID也就是说大家id是不一样的,而一旦建立主从关系呢,master就会给大家生成一个统一的replicationID,也就是集群内的每个节点大家id都是一样的,所以你第一次来的时候你带这个id,我只需要比较一下,看看咱俩是否一样,如果你不一样,说明咱们之前没有约定过,你肯定是第一次来,他通过这个就能去判断了啊

3.第一次来全量同步

好那如果你第一次来,那说明我上面的数据你都没有嘛,我就要给你做全量同步,不同步的方式就是利用bgsave,把redis内存中的所有数据都写入RDB文件(存在磁盘中),然后把RDB文件发给slave,slave只需要把本地数据删了,然后再把RDB文件加载的内存就实现这个同步了,两者的数据是不是就完全一致了,那从此之后就简单了,后续master会不断接受新的命令,那每当master执行写操作时,就可以把这个写的命令啊传播给slave,slave也去执行

那这样来两者是不是就永远保持一致了,那这是理想情况 

4.断开重连增量同步

那万一在这个过程当中,slave突然出现了宕机或者网络故障,那master发过去的命令slave就没收到,没收到就不会执行,那于是两者之间数据就不会出现差异了,那么这个时候断开重连的时候,slave想要来恢复数据,其实就是想找到自己断开时缺失的那部分命令,那怎么找到呢,我们的master里面会有一个缓冲区(repl_backlog),它会去记录啊,两者建立同步关系之后,所有的master执行过的写命令啊,全部记在里面,并且会有一个offset(repl_backlog写入的数据长度)记录,说我当前命令写到哪里了,就是写的命令这个位置对吧,那么slave呢内部它在接收到master命令的时候,他就执行完了以后他也会有一个offset啊,记住的是我执行了哪一些命令,执行到哪个位置了,那再去做同步的时候,他就可以把offset传过去,master呢哎发现你不是第一次来叫做增量同步嘛,他就可以去比较一下自己的offset和slave,offset两者之间的差异,就是master已经执行了,而slave还没执行的命令,那我只需要把这部分命令呢发给slave,slave执行,咱们是不是又一致了,这就是增量同步

提问

三、主从同步优化

主从同步可以保证主从数据的一致性,非常重要。

可以从以下几个方面来优化Redis主从就集群:

  • 在master中配置repl-diskless-sync yes启用无磁盘复制,避免全量同步时的磁盘IO。

  • Redis单节点上的内存占用不要太大,减少RDB导致的过多磁盘IO压力过大

  • 适当提高repl_baklog的大小,发现slave宕机时尽快实现故障恢复,尽可能避免全量同步

  • 限制一个master上的slave节点数量,如果实在是太多slave,则可以采用主-从-从链式结构,减少master压力

四、搭建哨兵集群

1. 配置文件sentinel.conf内容解析

sentinel announce-ip "192.168.150.101"
sentinel monitor hmaster 192.168.150.101 7001 2
sentinel down-after-milliseconds hmaster 5000
sentinel failover-timeout hmaster 60000

第一行声明哨兵自己的IP,哨兵和之前搭建的主从集群一样在虚拟机用docker部署所有IP地址都是虚拟机的地址

  • sentinel announce-ip "192.168.150.101":声明当前sentinel(哨兵)的ip

  • sentinel monitor hmaster 192.168.150.101 7001 2:指定集群的主节点信息

    • hmaster:主节点名称,自定义,任意写

    • 192.168.150.101 7001:主节点的ip和端口

    • 2:认定master下线时的quorum值,(就是最少哨兵主观认定下线的哨兵个数,一般大于哨兵个数一半)

  • sentinel down-after-milliseconds hmaster 5000:声明master节点超时多久后被标记下线

  • sentinel failover-timeout hmaster 60000:在第一次故障转移失败后多久再次重试

2.选举主节点的依据

一旦发现master故障,sentinel需要在salve中选择一个作为新的master,选择依据是这样的:

  • 首先会判断slave节点与master节点断开时间长短,如果超过down-after-milliseconds * 10则会排除该slave节点

  • 然后判断slave节点的slave-priority值,越小优先级越高,如果是0则永不参与选举(默认都是1)。

  • 如果slave-prority一样,则判断slave节点的offset值,越大说明数据越新,优先级越高

  • 最后是判断slave节点的run_id大小,越小优先级越高(通过info server可以查看run_id)。

3.提问

五、搭建分片集群

命令解释,这些在redis配置文件里面配置

port 7000
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes

其中有3个我们没见过的参数:

  • cluster-enabled:是否开启集群模式

  • cluster-config-file:集群模式的配置文件名称,无需手动创建,由集群自动维护

  • cluster-node-timeout:集群中节点之间心跳超时时间

  • appendonly yes:数据持久化,默认就有不用理会

散列插槽:

Redis分片集群如何判断某个key应该在哪个实例?

将16384个插槽分配到不同的实例

根据key的有效部分计算哈希值,对16384取余

余数作为插槽,寻找插槽所在实例即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/61509.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML5拖拽API学习 托拽排序和可托拽课程表

文章目录 前言拖拽API核心概念拖拽式使用流程例子注意事项综合例子🌰 可拖拽课程表拖拽排序 前言 前端拖拽功能让网页元素可以通过鼠标或触摸操作移动。HTML5 提供了标准的拖拽API,简化了拖放操作的实现。以下是拖拽API的基本使用指南: 拖拽…

06 —— Webpack优化—压缩过程

css代码提取后想要压缩 —— 使用css-minimizer-webpack-plugin插件 下载 css-minimizer-webpack-plugin 本地软件包 npm install css-minimizer-webpack-plugin --save-dev 配置 webpack.config.js 让webpack拥有该功能 const CssMinimizerPlugin require(css-minimizer-…

小熊派Nano接入华为云

一、华为云IoTDA创建产品 创建如下服务,并添加对应的属性和命令。 二、小熊派接入 根据小熊派官方示例代码D6完成了小熊派接入华为云并实现属性上传命令下发。源码:小熊派开源社区/BearPi-HM_Nano 1. MQTT连接代码分析 这部分代码在oc_mqtt.c和oc_mq…

形态学图像处理(Morphological Image Processing)

形态学图像处理(Morphological Image Processing) 前言 ‍ 本博客为个人总结数字图像处理一课所写,并给出适当的扩展和相应的demo。 写博客跟做 checkpoint​ 很像,毕竟个人还不能达到那种信手拈来的境界,忘了就是从零开始训练&#xff0…

[webgis 0基础到找工作]------JavaScript--DOM事件进阶 day10

1.事件流 事件流是对事件执行过程的描述,了解事件的执行过程有助于加深对事件的理解,提升开发实践中对事件运用的灵活度。 简言之,捕获阶段是【从父到子】的传导过程,冒泡阶段是【从子向父】的传导过程。 1.1捕获和冒泡 如果事件…

MATLAB图注意力网络GAT多标签图分类预测可视化

全文链接:https://tecdat.cn/?p38321 本示例展示了如何使用图注意力网络(GATs)对具有多个独立标签的图进行分类。当数据中的观测值具有带有多个独立标签的图结构时,可以使用GAT来预测未知标签观测值的标签(点击文末“…

CSS优化file控件样式

<div class"file-box"><input type"button" class"btn" value"选择文件" /><inputtype"file"class"file"id"upimg"change"previewFiles"multiple/></div><!-- Vu…

CTF--php伪协议结合Base64绕过

Base64绕过 在ctf中&#xff0c;base64是比较常见的编码方式&#xff0c;在做题的时候发现自己对于base64的编码和解码规则不是很了解&#xff0c;并且恰好碰到了类似的题目&#xff0c;在翻阅了大佬的文章后记录一下&#xff0c;对于base64编码的学习和一个工具 base64编码是…

虚拟网卡驱动和DM9000C移植

网卡驱动程序框架 网卡驱动程序“收发功能”&#xff1a; 只要把上层的数据发给网卡&#xff0c;从网卡来的数据构造成包给上层即可。网卡只需要 “socket”编程&#xff0c;不需要打开某设备。 驱动程序都是以面向对象的思想写的&#xff0c;都有相关的结构体。 编程步骤 …

image compare pyqt 实现

默认显示image1, 鼠标滑动滚动条切换图片显示 可视化效果: image_compare.py import sys from PyQt5.QtWidgets import QApplication, QWidget, QLabel, QSlider, QVBoxLayout, QHBoxLayout from PyQt5.QtCore import Qt, QSize from PyQt5.QtGui import QPixmap, QPainte…

在自动驾驶进行大数据量因果推理实验时,如何减少无用功,提高实验效率?

在对实验结果做反事实推理时&#xff0c;通常需要对数据进行多次循环&#xff0c;然后对多次循环的结果进行处理&#xff0c;如果只在最后结果结束时&#xff0c;再进行处理&#xff0c;可能会由于反事实过程中某个参数设置错误&#xff0c;导致整个反事实实验出现错误&#xf…

浅谈软件开发中的yield关键字:从餐厅服务理解异步编程之美

在现代软件开发中&#xff0c;处理大量数据流时经常会遇到性能和内存消耗的问题。传统的编程方式往往是一次性获取所有数据&#xff0c;这就像餐厅厨师要把所有菜品做完才上菜一样&#xff0c;既不高效也不够灵活。而yield关键字的出现&#xff0c;为我们提供了一种优雅的解决方…

绕过CDN寻找真实IP

在新型涉网案件中&#xff0c;我们在搜集到目标主站之后常常需要获取对方网站的真实IP去进一步的信息搜集&#xff0c;但是现在网站大多都部署了CDN&#xff0c;将资源部署分发到边缘服务器&#xff0c;实现均衡负载&#xff0c;降低网络堵塞&#xff0c;让用户能够更快地访问自…

前后端请求响应

引入 在之前的例子中&#xff0c;我们编写了一个简单的web类&#xff0c;我们运行启动类&#xff0c;启动内嵌的tomcat后就可以在浏览器通过特定的路径访问tomcat中的应用程序。 但之前编写的程序仅仅是个简单的java类&#xff0c;其并未实现某个接口或继承某个类&…

ThreeJS入门(142):THREE.WebGLRenderTarget 知识详解,示例代码

作者&#xff1a; 还是大剑师兰特 &#xff0c;曾为美国某知名大学计算机专业研究生&#xff0c;现为国内GIS领域高级前端工程师&#xff0c;CSDN知名博主&#xff0c;深耕openlayers、leaflet、mapbox、cesium&#xff0c;webgl&#xff0c;ThreeJS&#xff0c;canvas&#xf…

Streamlit + AI大模型API实现视频字幕提取

简介 在本文中&#xff0c;我将带你探讨如何使用Streamlit和AI大模型API来实现视频字幕提取的技术。Streamlit是一个开源的Python库&#xff0c;用于快速构建数据应用的Web界面&#xff0c;而AI大模型API&#xff0c;如OpenAI&#xff0c;提供了强大的语言处理能力&#xff0c…

SpringBoot - spring.profiles.active最佳实践

文章目录 Pre概述为什么需要多环境配置多环境配置实现步骤1. 配置文件准备2. 激活特定环境方法1&#xff1a;命令行参数方法2&#xff1a;环境变量方法3&#xff1a;IDE 配置方法4&#xff1a;全局配置文件默认设置 3. 配置文件加载顺序配置生效的原理 4. 常见问题多个配置文件…

网安瞭望台第2期:零日漏洞密集爆发、2024年常见网络安全漏洞类型及分析

国内外要闻 Ubuntu 服务器 Needrestart 软件包惊现严重安全漏洞 近日&#xff0c;Ubuntu 服务器&#xff08;自 21.04 版本起默认安装&#xff09;的 Needrestart 软件包被曝存在多个可追溯至数十年前的安全漏洞。这些漏洞允许本地攻击者在无需用户交互的情况下获取根…

Java前端基础——CSS

一、CSS介绍 1.1 什么是CSS CSS(Cascading Style Sheet)&#xff0c;层叠样式表,用于控制页面的样式. CSS 能够对网页中元素位置的排版进行像素级精确控制, 实现美化页面的效果. 能够做到页面的样式和结构分离. 1.2 基本语法规范 选择器 {⼀条/N条声明} • 选择器决定针…

浅议Flink中的通讯工具: Akka

在Flink中&#xff0c;各个组件之间需要频繁交换数据和控制信息。Flink选择了基于Actor模型的Akka框架作为通信基础。 Akka是什么 Actor模型 Actor模型是用于单个进程中并发的场景。 在Actor模型中&#xff1a; ActorSystem负责管理actor生命周期 将每个实体视为独立的 Ac…