当前位置: 首页 > news >正文

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但只有少部分活跃)

http://www.gsyq.cn/news/132099.html

相关文章:

  • 【学习笔记】后量子密码迁移科技研究
  • 大模型微调完整学习路线,附20天到4个月详细规划_零基础入门人工智能(AI)大模型微调!
  • python作业4
  • 从高频政策热词看经济“新风口”与资本流向
  • 边缘AI与端云协同架构
  • Flutter 实现一个容器内部元素可平移、缩放和旋转等功能(六)
  • 2025年度开发趋势有感
  • 链动2+1模式、AI智能名片与S2B2C商城小程序在直播营销中的规范化应用研究
  • 华为OD机试(机考) - 机器人搬砖 (C++ Python JAVA JS GO)
  • 人工智能之数学基础 微积分:第三章 基本法则
  • 好写作AI:AI写论文越用越“笨”?你可能需要一套“思维防沉迷系统”
  • 货币汇率换算免费API接口(每日更新汇率)
  • 国产操作系统 KylinOS 学习心得:从基础操作到实战部署
  • Spring AI Alibaba 【四】 - 指南
  • Windows系统文件GdiPlus.dll丢失或损坏 下载修复方法
  • Elasticsearch IK分词插件安装指南
  • 发哥存储站点----防止发卡网链接失效----请务必收藏本链接----看到这个页面第一件事先进Q群:633403801(里面每天发稳定图,根据稳定图购买)
  • cesium126,240311,Ce for Ue 加载天地图P3-加载天地图的各种底图和注记:
  • RFSOC学习记录(四)MTS时序分析
  • 《深度测评:从 GPT-5.1 到 GPT-5.2,OpenAI 到底在 Pro 模型里藏了什么黑科技?》
  • 做人
  • 0-1 从零开始到实现arp 断网
  • python:报错:ModuleNotFoundError: No module named langgraph
  • AT_agc061_c [AGC061C] First Come First Serve
  • Springboot文档管理系统 yb510(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • Thinkphp和Laravel奇思妙享博客文章新闻分享系统echart-vue
  • Thinkphp和Laravel人才求职招聘网站系统4b152
  • Thinkphp和Laravel企业防爆安全设备信息系统
  • 深入解析:爬虫学习 01 Web Scraper的使用
  • PHM数据集轴承寿命预测!Transformer-LSTM组合模型轴承寿命预测MATLAB代码实现!