首页 > 数据库 >redis设计学习

redis设计学习

时间:2023-06-03 17:34:41浏览次数:56  
标签:存储 Redis redis 哨兵 学习 命令 RDB 设计

redis数据类型

redis自定义字符串(SDS)

redis自定义一种字符串SDS(Simple Dynamic String),该字符串数据结构大概定义了字符编码,char []数组存储字节,达到了我们存储字符串和二进制数据的需求,也实现了我们存储不同编码的字符串和二进制图片等数据。区别于C语言中的String,这种字符串起到了一定的优化作用,可以使用C中的一些字符串函数,和自定义SDS的API。

List

由于C中没有双向链表,Redis自己实现了一种双向链表,并做了一定的优化。数据结构如同学习的java中的LinkedList,两个引用类型指向链表的前后存储元素,然后就是一个存储变量存储当前节点的存储值。此种结构也对应了Redis中的相关Api,例如RPUSH,LPUSH,RPOP,LPOP等。Redis做的优化其中一种就是,当存储数据较小,双向链表查询的效率可能就不太理想,将这种List改为ZipList,将物理存储结构连在一起,猜测为类似与数据的概念。

Map

由于C中没有hashtable,Redis自己实现了一种hashtable,hashtable类似与java中的hashMap,内部为hash表,通过数据hash存入hash表中,因为hash存在重复的可能性,在hash表中的子单元通过链表连接起来。

Set

Redis通过hashtable来存储无序数组。Redis其中做的优化是当数据存的全是数值类型,且数量较小时,使用IntSet,实质上内部就是个数值数组。

ZSet

Zset来做有序数组,Redis通过两种数据结构来完成,一种是hashTable,另一种则是跳表。使用过zset的都知道,所谓的有序,是通过设置score来给存入的值排序。Zset的两种存储结构,hashtable负责通过存储的redis值,查询到对应的score。跳表为二叉树的一种变种,感兴趣的可以搜一搜,既然是二叉树,子节点存储的是score,我就可以通过score,完成区域score查询,通过score也可以查询到对应的redis存储的值。

Redis设计结构

事件驱动

redis事件主要分为时间事件和文件时间

  1. 时间时间

    当被监听的套接字准备好执行连接应答、读取、写入、关闭等操作时,与操作相对应的文件事件就会产生,这时文件事件处理器就会调用套接字之前关联好的事件处理器来处理这些事件

  2. 文件时间

    时间事件分两类第一类是定时事件(指定时间清除过期字典数据);一类是周期性事件(例如redis周期刷新RDB)

redis程序设计

redisServer粗略的可以分为以下几种功能组成

  1. Socket套接字
  2. I/O多路复用程序
  3. 各种命令处理适配执行程序

设计优点:

  • 单线程的I/O程序
    多线程的I/O就难避免线程切换的开销和I/O资源的竞争,单线程完全避免了这些问题。当执行完命令操作的时候,可能会AOF或RDB持久化,涉及磁盘I/O,会造成中断线程切换,造成开销。多线程I/O会有资源竞争,产生锁。
  • 事件监听机制
    事件机制方便管理,提高执行效率

socket套接字

该功能负责处理RedisClient与RedisServer的链接,将命令传给I/O多路复用程序,然后响应给RedisClient

I/O多路复用程序

i/o多路复用程序会将socket套接字接受到的命令处理后放入到I/O多路复用的命令队列中,命令依次执行,根据不同类型的命令发给不同的命令处理器,等待执行完成后返回给socket套接字,重复执行。

各种命令处理适配执行程序

由于命令处理的程序比较多,我也没看多少,只能说有东西处理吧,然后通过事件回调通过I/O多路复用程序。

redis主从

主要谈谈实现流程吧,有两台无关联的Redis服务器,有一台B向A发起slaveof主从同步命令后,A会将此时的数据写成一个RDB文件(RDB后有描述),然后将此刻以后得所有执行的命令都写入AOF(AOF后又描述),最后将文件传给B,b将RDB和Aof解析,此后每次A数据修改,都会同步给B,主从同步就完成了。

redis哨兵

启动三台redis哨兵,每个哨兵程序会创建两条线程,一条连接单台RedisServer发送命令,一条负责RedisServer订阅哨兵信息,发送命令线程定时向redisServer发送命令监听心跳,一条订阅哨兵消息,会将自身ip端口等信息发给redisServer,并且redisServer会储存下来。当三台redis哨兵都启动成功后,redisServer中也会存储了三台哨兵信息,哨兵在获得其他哨兵信息的时候也会建立一个命令连接线程。自此整个系统也就圈起来了。

当redisserver主挂掉的时候,哨兵就开始发挥作用了,哨兵之间会相互通信以下,每台选举自己做头,然后算出一台相应最快的做头,然后与从redis通信,选从为主。当主断线重连后,作为从连接现在的主。

redis集群

redis集群主要就是针对数据量大,做的一种数据分区,通过对数据分片(槽),将数据分开存储。总共是2的14次方,分别分与不同的redis主服务器中,当redisClient数据请求时,会通过redis的hash算法计算key是否在本服务器中,如果存在就执行操作,不存在则返回重定向给client重行请求到指定服务器。

redis数据备份

redis备份主要分为AOF和RDB两大类

AOF

当数据持久化的时候,将内存中的数据转成对应的redis命令持久化到硬盘中。在下次启动恢复的时候redis会自动检测文件,放入内存。

RDB

当数据持久化的时候,将内存中对的数据直接转成对应的数据格式持久化到硬盘中。在下次启动恢复的时候redis会自动检测文件,放入内存。

标签:存储,Redis,redis,哨兵,学习,命令,RDB,设计
From: https://www.cnblogs.com/theStone/p/17454284.html

相关文章

  • Java实战(第2版)学习笔记
    基本知识函数式编程:Java8里将代码传递给方法的功能(同时也能够返回代码并将其包含在数据结构中)还让我们能够使用一整套新技巧,通常称为函数式编程。没有共享的可变数据,以及将方法和函数(即代码)传递给其他方法的能力,这两个要点是函数式编程范式的基石。行为参数化:将方法(你的代码)作......
  • 3月25日邓老师设计模式面试资料02
    Spring面试专题1.Spring应该很熟悉吧?来介绍下你的Spring的理解  有些同学可能会抢答,不熟悉!!!  好了,不开玩笑,面对这个问题我们应该怎么来回答呢?我们给大家梳理这个几个维度来回答1.1Spring的发展历程  先介绍Spring是怎么来的,发展中有哪些核心的节点,当前的最新版本是......
  • Java8之Stream的学习
    一、概念理解Stream可以由数组或集合创建,对流的操作分为两种:中间操作,每次返回一个新的流,可以有多个。终端操作,每个流只能进行一次终端操作,终端操作结束后流无法再次使用。终端操作会产生一个新的集合或值。二、Stream的创建publicclassStreamDemo{publicstaticvoidmain(......
  • 10课程设计收尾及优秀作品展示答辩【FPGA模型机课程设计】
    10课程设计收尾及优秀作品展示答辩【FPGA模型机课程设计】前言说明推荐10课程设计收尾及优秀作品展示答辩安排目录一、单周期CPU的设计过程1、基本的20条指令固定指令格式设计I型指令设计J型指令设计lwsw指令设计2、扩展的20条指令J型扩展指令设计乘法除法指令格式3、实现中断异......
  • 6设计指令流水线-1【FPGA模型机课程设计】
    6设计指令流水线【FPGA模型机课程设计】前言推荐修改6设计指令流水线安排测试与结果指令流水线理论MIPS的一种简单实现基本的MIPS流水线指令流水线实现MIPS五段流水CPU设计视频中的测试代码基于单周期CPU的流水线设计代码设计流水寄存器的引脚设计IF_IDID_EXEX_MEMMEM_WB流水寄存......
  • 6设计指令流水线-3【FPGA模型机课程设计】
    6设计指令流水线-3【FPGA模型机课程设计】前言推荐6设计指令流水线-3安排测试与结果指令流水线理论MIPS的一种简单实现基本的MIPS流水线指令流水线实现MIPS五段流水CPU设计基于单周期CPU的流水线设计乘除流水线的设计原子流水线的设计代码设计EX_Mem附录0框架最后前言2023-5-25......
  • 单周期CPU模型机下载【FPGA模型机课程设计】
    模型机下载【FPGA模型机课程设计】前言推荐单周期CPU模型机下载安排测试与结果5.7.2模型机下载FPGA设计代码设计MIOCIOIO1SoCInstMem附录0框架EMIOC接口FIO外设IO1测试MIOC分流9InstMem指令存储器10SoC顶层最后前言2023-5-2707:55:09周六早上睡不着了起来学习推荐5模......
  • 机器学习入门基础:机器学习实践
    目录7.1数据集划分7.1.1训练集、验证集和测试集划分7.1.2交叉验证7.1.3不平衡数据处理7.2评价指标7.2.1回归的评价指标7.2.2分类的评价指标7.2.3评价指标案例7.3正则化、偏差和方差7.3.1欠拟合和过拟合7.3.2正则化7.3.3偏差和方差参考文献7.1数据集划分7.1.1训练集......
  • 大话设计模式之单例,策略,简单工厂
    基于实际面试题实现importjava.util.HashMap;importjava.util.Map;importjava.util.Random;/***用java设计一个机房环境监测系统的代码框架,机房有多种传感器,可以实时检测机房的温度、湿度、噪音等数据,*并把数据实时发送到监控中心,其中某项数据超过不健康阈值立即上......
  • redis主从数据同步的原理
    redis主从数据同步的原理数据同步原理主从第一次同步是全量同步,但是如果slave重启后同步,则执行增量同步。第一阶段slave和master建立第一次同步的时候,需要执行replicaof命令,并且指定了master的ip和端口,slave和master连接一旦建立成功,slave就会向master发出请求来数据同步,然后......