Redis的数据类型和内部编码详解

 更新时间:2024年04月18日 11:22:04   作者:机智的土拨鼠  
Redis是通过Key-Value的形式来组织数据的,而Key的类型都是String,而Value的类型可以有很多,在Redis中最通用的数据类型大致有这几种:String、List、Set、Hash、Sorted Set,下面通过本文介绍Redis数据类型和内部编码,感兴趣的朋友一起看看吧

前言

为了后续能更好的讲解Redis的各种数据类型,我们需要学习一点前置知识。

数据类型

Redis是通过Key-Value的形式来组织数据的,而Key的类型都是String,而Value的类型可以有很多。

在Redis中最通用的数据类型大致有这几种:String、List、Set、Hash、Sorted Set。

不过,Redis底层在实现这些数据结构(类型)的时候,会在源码层面进行优化,以达到节省时间/节省空间的效果,而对于内部数据结构也称之为内部编码。

Ps:有点指鹿为马的感觉。Redis告诉你,我的类型就是一个字符串,但自己背后却给优化成了整形,指着整形说是字符串,然后咱也只能老老实实用~

String

在String类型中有三种内部编码方式:raw、int、embstr。

raw:最基本的字符串,底层就类似是Java中的byte数组。

int:在特定场景下,会优化成整数,方便进行数值计算。

embstr:针对短字符串进行的优化。

Hash

在Hash类型中有两种内部编码方式:hashtable、ziplist。

hashtable:最基本的哈希表(不同于Java标准库中的HashTable)。

ziplist:压缩列表,当哈希表中的元素比较少的时候,就进行了优化,节省空间。

List

在List类型中有两种内部编码方式:linkedlist、ziplist。

linkedlist:链表的形式

ziplist:压缩列表

不过从redis3.2开始,就引入了新的实现方式:quicklist。

quicklist:集成了链表和压缩列表的优势。本质上就是一个链表,而每个元素又是一个压缩列表。当元素很多的时候,如果全是链表,就会出现很多节点,而每个节点都需要使用指针域,这也会大大增加开销。

Set

在Set类型中有两种内部编码方式:hashtable、intset。

intset:存储的都是整数的集合。

Zset

在Set类型中有两种内部编码方式:skiplist、ziplist。

skiplist:跳表,跳表也是链表,不同于普通链表的是,跳表的每个节点上有很多指针域,巧妙利用这个特性,查询速度能调高到O(logn).

查询内部编码方式指令

#基本语法
object encoding key
#查询key的内部编码

Redis会自动根据当前的实际情况选择内部的编码方式~~真香!

Redis的单线程模型

此处的单线程模型并非是真的说在Redis内部只有一个线程在工作,说的是Redis只用一个线程来处理命令请求,在Redis内部还有其他一些线程是用来处理网络IO的,毕竟是作为一个服务器来使用的~~

正是由于Redis的单线程模型,以至于当多个客户端并发的对Redis服务器进行操作的时候,不会有线程安全的问题,多个请求来的时候就使用放到一个队列里,串行的去处理里面的命令。而且Redis的主要核心业务逻辑也都是一些“短频快”的操作,不太消耗CPU,所以单线程模型才能很好的工作,但也有弊端:当一个指令执行的时间太长,就会阻塞其他指令!!!

面试题:

Redis虽然是单线程模型,为啥效率这么高呢?

1.Redis访问的是内存中的数据,相较于数据库访问的是硬盘数据,会快很多。

2.Redis的核心功能,比数据库简单(数据库支持各种各样的约束,功能很强大,势必会带来更多开销)。

3.单线程模型避免了一些不必要的线程竞争开销。

4.处理网络IO的时候,使用了epoll这样的IO多路复用机制。

到此这篇关于Redis的数据类型和内部编码的文章就介绍到这了,更多相关Redis数据类型和内部编码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Redisson实现Redis分布式锁的几种方式

    Redisson实现Redis分布式锁的几种方式

    本文在讲解如何使用Redisson实现Redis普通分布式锁,以及Redlock算法分布式锁的几种方式的同时,也附带解答这些同学的一些疑问,感兴趣的可以了解一下
    2021-08-08
  • 搭建Redis服务器步骤详细介绍

    搭建Redis服务器步骤详细介绍

    大家好,本篇文章主要讲的是搭建Redis服务器步骤详细介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • 浅谈Redis分布式锁的正确实现方式

    浅谈Redis分布式锁的正确实现方式

    这篇文章主要介绍了浅谈Redis分布式锁的正确实现方式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-05-05
  • 从零搭建SpringBoot2.X整合Redis框架的详细教程

    从零搭建SpringBoot2.X整合Redis框架的详细教程

    这篇文章主要介绍了从零搭建SpringBoot2.X整合Redis框架的详细教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • 解决Redis分布式锁的误删问题和原子性问题

    解决Redis分布式锁的误删问题和原子性问题

    Redis的分布式锁是通过利用Redis的原子操作和特性来实现的,为了保证数据的一致性和避免冲突,可以使用分布式锁来进行同步控制,本文给大家介绍了如何解决Redis分布式锁的误删问题和原子性问题,需要的朋友可以参考下
    2024-02-02
  • Redis设置database不生效的解决方案

    Redis设置database不生效的解决方案

    最近在做redis缓存设置的时候,发现即使已经设置了database, 但是存数据的时候还是用的默认0数据库,所以本文就给大家介绍了Redis设置database不生效的解决方案,需要的朋友可以参考下
    2023-08-08
  • CentOS7.5使用mysql_multi方式安装MySQL5.7.28多实例(详解)

    CentOS7.5使用mysql_multi方式安装MySQL5.7.28多实例(详解)

    这篇文章主要介绍了CentOS7.5使用mysql_multi方式安装MySQL5.7.28多实例,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • 基于redis实现token验证用户是否登陆

    基于redis实现token验证用户是否登陆

    这篇文章主要为大家详细介绍了基于redis实现token验证用户是否登陆,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • Redis定时任务原理的实现

    Redis定时任务原理的实现

    本文主要是基于 redis 6.2 源码进行分析定时事件的数据结构和常见操作,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 在Redis集群中使用pipeline批量插入的实现方法

    在Redis集群中使用pipeline批量插入的实现方法

    这篇文章主要介绍了在Redis集群中使用pipeline批量插入的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05

最新评论