计算机存储体系

计算机存储体系是一个金字塔结构 ,它按照速度、容量、成本进行分级,目的是用最低的成本实现最快的平均访问速度。

1. 核心逻辑:局部性原理

计算机程序通常遵循局部性原理

  • 时间局部性:刚被访问的数据很可能再次被访问。

  • 空间局部性:访问某个数据时,其附近的数据也很可能被访问。

基于这个原理,系统将最热的数据 放在最快但最贵 的存储中,将冷数据 放在最慢但最便宜的存储中。

2. 存储金字塔(从快到慢)

下图清晰地展示了计算机存储体系的层级结构:

3. 各层级详细对比

层级 典型容量 访问速度 成本 物理位置 用途
寄存器 ~1KB 0.3 ns 极高 CPU内部 存放当前指令和操作数
L1缓存 32-512 KB 0.5-1 ns 极高 CPU内部 存放最热指令和数据
L2缓存 256K-4 MB 3-10 ns CPU内部/外部 存放次热数据
L3缓存 8-64 MB 10-20 ns 中高 CPU外部 共享缓存,减少内存访问
主内存 8-256 GB 50-100 ns 中等 内存条 运行程序和临时数据
SSD 256 GB-4 TB 50-150 μs 硬盘位 持久化存储,系统盘
HDD 1-20 TB 1-10 ms 极低 硬盘位 大容量冷数据存储
网络/磁带 无限 10-100 ms 极低 远程/离线 备份、归档

4. 关键概念解析

缓存(Cache)
  • 定义:位于CPU和主内存之间的高速缓冲存储器(L1/L2/L3)。

  • 作用 :解决CPU和内存之间的速度鸿沟。CPU速度极快,而内存相对较慢,缓存通过预测和预取数据,让CPU"感觉"内存很快。

  • 命中率 :如果CPU要的数据在缓存中,称为命中 ;否则需要去内存取,称为未命中。现代CPU的缓存命中率通常在90%以上。

内存(RAM)
  • 特性易失性(断电数据丢失)。

  • 作用:存放当前正在运行的程序和数据。它是CPU的"工作台"。

外存(硬盘)
  • 特性非易失性(断电数据不丢失)。

  • 作用:长期保存数据。当内存不够用时,操作系统会将不常用的内存数据"交换"到硬盘(虚拟内存机制)。

5. 性能优化启示

  • 写代码时要考虑缓存友好性:尽量让数据连续访问(空间局部性),避免在内存中"跳来跳去",这样可以提高缓存命中率,大幅提升程序速度。

  • 数据库设计:数据库的Buffer Pool(缓冲池)就是内存中的一块区域,它模拟了计算机的存储体系,将热数据放在内存中,冷数据放在磁盘上。

相关推荐
只会cv的前端攻城狮2 小时前
DSL 领域模型架构设计:消灭 CRUD 重复工作
前端·架构
禅思院7 小时前
路由性能优化终极指南:从懒加载漏洞到边缘渲染的架构跃迁
前端·架构·前端框架
怕浪猫7 小时前
Electron 系列文章封面图
算法·架构·前端框架
王二端茶倒水8 小时前
从千兆到万兆:小区、园区、酒店网络运营该怎么升级?
架构
喵个咪8 小时前
技术复盘:基于 go-wind-cms 的官网+商城双业务渐进拆分实战
后端·架构·go
ZengLiangYi8 小时前
批量导入 1000 条对话的性能优化实战
javascript·后端·架构
东方佑1 天前
FRSM 规模效应与架构对比补充报告
架构
隔窗听雨眠1 天前
大模型加爬虫上篇:技术融合与架构革新
爬虫·架构
Vergelight1 天前
实战拆解|三类RAG架构差异:朴素、进阶、多轮RAG落地选型指南
架构·大模型·aigc·agent·ai产品经理·转行·ai后台设计
Database_Cool_1 天前
大规模数据分析降本指南:AnalyticDB Serverless 弹性架构实战
数据仓库·阿里云·架构·数据分析·serverless