4.常用数据结构和单线程模型理解

Redis目前10种value类型,string,list,set,hash,sorted set,stream,geospatial,hyperloglog,bitmaps,bitfields。

redis针对数据结构底层实现的特化

在源码层面,redis对数据结构实现与常见实现方式有差异,目的是为了节省内存/提高效率。它依旧保证容器的特性不变,只不过实现有差异(数据结构形不变,编码方式变)。

1.常见数据结构及其内部编码

string:

raw:最基本的字符串,底层实现持有一个char数组。

int:8字节整型存储(可用来实现计数功能)

embstr:针对短字符串的特殊优化(只读字符串,进行修改了编码变为raw

hash:

hashtable:最基本的哈希表

ziplist:当哈希表内元素个数比较少,节省内存

为什么要压缩?

redis上有很多key,可能某些key的value是hash,hash本身是很浪费内存的(有空位置),在数据量不大时,使用ziplist可以在不影响效率的情况下节省内存。

list:

linkedlist:传统链表

ziplist:压缩列表

自redis3.2之后,引入了quicklist,兼顾了上述两者的优点。

set:

hashtable

intset:集合中存的都是整数(升序存放数字,查找时二分查找

zset:

skiplist:跳表(5.跳表(skiplist)_跳表(skiplist) + 哈希表-CSDN博客

ziplist

查看编码命令:object encoding key

不需要记住数字,只记思想;因为数字是可配置的,为什么用这个数字才是重要的。

2.redis单线程模型理解

redis只使用一个线程处理所有的命令;不是说redis服务器内部就只有一个线程;redis6.0及以上,网络IO是多线程的。

2.1 命令处理没有线程安全问题

两个客户端即便同时请求redis服务器,但因为redis处理命令是单线程的;两个命令一定是串行执行的,没有线程安全问题。

2.2 命令处理用单线程原因和弊端

redis核心业务逻辑都是短平快的,不是很吃CPU资源。

弊端:redis命令操作过长会阻塞其他命令的执行。

2.3 redis单线程模型为什么效率高?(面试题)

核心:参照物是数据库(MySQL,Oracle,sql server等)

1)内存访问速度比访问硬盘快

2)核心功能比数据库更简单(数据库增删改查都有权限概念,复杂很多)

3)单线程模型,避免了一些不必要的线程竞争
4)网络采用的是IO多路复用技术(epoll,有大量socket但只有少部分活跃)

相关推荐
一路向北⁢2 分钟前
短信登录安全防护方案(Spring Boot)
spring boot·redis·后端·安全·sms·短信登录
黯叶31 分钟前
基于 Docker+Docker-Compose 的 SpringBoot 项目标准化部署(外置 application-prod.yml 配置方案)
java·spring boot·redis·docker
Codeking__1 小时前
Redis——value的数据类型与单线程工作模型
java·数据库·redis
短剑重铸之日1 小时前
《7天学会Redis》Day 1 - Redis核心架构与线程模型
java·redis·后端·架构·i/o多路复用·7天学会redis
yumgpkpm2 小时前
华为 GaussDB 商业版(本地部署)部署方案及相关步骤
hive·hadoop·redis·elasticsearch·华为·kafka·gaussdb
Codeking__2 小时前
Redis的value类型及编码方式介绍——hash
redis·算法·哈希算法
想摆烂的不会研究的研究生10 小时前
每日八股——Redis(1)
数据库·经验分享·redis·后端·缓存
至善迎风15 小时前
Redis完全指南:从诞生到实战
数据库·redis·缓存
QQ_43766431417 小时前
Redis协议与异步方式
数据库·redis·bootstrap
oMcLin18 小时前
如何在 Debian 10 上配置并优化 Redis 集群,确保低延迟高并发的实时数据缓存与查询
redis·缓存·debian