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

LSM树与B+树优缺点分析

1. LSM树优化了顺序写,因此写性能很好,但在查询上: 需要从Level 0到Level n一直顺序查下去。极端情况是LSM树中不存在该数据,则需要遍历L0->Ln,最后返回空集。

解决方法是用布隆过滤器优化查询。

2. B+树范围查询性能很好,缺点包括:

  1. 随机写的性能差‌:B+树每次插入或更新操作可能需要访问不同的叶子节点,导致每次写操作都需要随机读写。
  2. 更新操作的代价高‌:每次更新操作都需要修改索引树,可能会触发写锁,阻塞数据查询操作,尤其是在并发写的情况下,性能会更差‌。
  3. 占用空间大‌:B+树索引结构会占用较多的存储空间,尤其是在数据库增大时,这种占用会更加显著‌

     以下几种情况可能表现不佳:

  1. 高并发下的分裂合并  2.更新  3.树比较深的时候 4. 数据分布不均匀:可能会导致某些分支的节点过于密集,而其他分支则比较稀疏。

总结:B+树读快写慢, LSM树写快读慢(所以HBase用布隆过滤器弥补读问题),两者适用场景互补。

参考: https://zhuanlan.zhihu.com/p/415799237

http://www.xdnf.cn/news/14104.html

相关文章:

  • C primer plus (第六版)第七章 编程练习第9题
  • uniapp中vue3 ,uview-plus使用!
  • 阿里云OSS
  • 使用 Higress AI 网关代理 vLLM 推理服务
  • el-tree-select 多选树形下拉框,实现当选中时,根据当前选择的对象,动态生成表单数据。
  • Go并发编程中的内存同步与竞态:从理论到实践
  • 使用Stone 3D免编码快速创建带AI数字人的数字空间
  • Day30 模块和库的导入
  • 安科瑞 ADW600 多回路电力计量模块:安装、通信与使用指南
  • 流编辑器sed
  • 深入理解 C++ const:九大用法解析 + 八大高频考点
  • android mvI架构梳理
  • M - 中位数
  • Android 实体键盘 设置默认布局
  • 【舞蹈】FineDance
  • 新一代python管理工具--uv
  • Rust 学习笔记1
  • 数字孪生系统汽车工厂生产异常监控的智能利器
  • 快速解决软件测试的逻辑方法运用
  • 数字孪生之KTV洗脚城白皮书:娱乐产业的虚实融合革命
  • LX-YST-1
  • Qt背景平铺
  • Java-45 深入浅出 Tomcat 核心架构与处理流程全解析Coyote IO模型与协议
  • java集合(十) ---- LinkedList 类
  • 基于CT图像的硬参数共享多任务分析:肝脏肿瘤分割与良恶性分类
  • ELK 日志分析系统
  • transformer demo
  • 深入剖析Redis Cluster集群,Redis持久化机制,Redis数据类型及其数据结构
  • DeepSeek与呼叫中心系统结合提升效率
  • ELK日志文件分析系统——1