计算机存储体系

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

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(缓冲池)就是内存中的一块区域,它模拟了计算机的存储体系,将热数据放在内存中,冷数据放在磁盘上。

相关推荐
工作log2 小时前
AI点餐助手架构全流程解析
java·开发语言·微服务·架构
SelectDB技术团队2 小时前
PostgreSQL + Apache Doris:构建用于实时分析的 HTAP 架构
数据库·postgresql·架构·实时数仓·湖仓一体·apache doris·selectdb
九河云2 小时前
云供应链安全:第三方 SaaS 服务的风险评估与管控
大数据·运维·安全·架构·数字化转型
Volunteer Technology10 小时前
架构面试题(一)
开发语言·架构·php
张张123y11 小时前
RAG从0到1学习:技术架构、项目实践与面试指南
人工智能·python·学习·面试·架构·langchain·transformer
sg_knight11 小时前
如何用 Claude Code 做大型项目重构与架构优化
java·重构·架构·llm·claude·code·claude-code
老鱼说AI12 小时前
CUDA架构与高性能程序设计:异构数据并行计算
开发语言·c++·人工智能·算法·架构·cuda
Traced back12 小时前
三层架构 + MVP 到底怎么结合?如何体现?
架构·mvp
renhongxia114 小时前
PostTrainBench:LLM 代理能否自动化 LLM 后培训?
运维·人工智能·深度学习·机器学习·架构·自动化·transformer