热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

存储器层次结构全景:数据存储的大金字塔长什么样

文章目录理解存储器的层次结构SRAMDRAM存储器的层次结构如何权衡存储器的价格和性能存储器是计算的重要组成部分,内存和硬盘都是存储设备,硬盘这种持久化


文章目录

    • 理解存储器的层次结构
        • SRAM
        • DRAM
        • 存储器的层次结构
    • 如何权衡存储器的价格和性能



存储器是计算的重要组成部分,内存和硬盘都是存储设备,硬盘这种持久化存储设备也是一个IO设备。

软件开发中,当遇到服务端的请求响应时间长,吞吐率不够的情况下,在分析对应问题的时候,很多时候发现主要瓶颈不在CPU,而在IO。


理解存储器的层次结构

通常我们把信息和数据存储在书、文件这样的物理介质里面,有了计算机之后,通常把数据存储在计算机的存储器里面。

存储器系统是一个通过各种不同的方法和设备,一层一层集合起来的系统。


  • CPU可以比喻为计算机的大脑,思考的东西好比CPU中的寄存器。寄存器是CPU本身的一部分,只能存放极其有限的信息,但是速度非常快,和CPU同步。
  • 大脑中的记忆,好比CPU Cache(CPU 高速缓存)。CPU Cache用的是一种叫SRAM(Static Random-Access Memory 静态随机存取存储器)的芯片。

SRAM

之所以称为"静态"存储器,是因为只要处在通电状态,里面的数据就可以保持存在,一旦断电,里面的数据就丢失了。

在SRAM里,一个比特的数据,需要6-8个晶体管,所以SRAM存储密度不高,同样的物理空间下,能存储的数据有限,不过因为SRAM电路简单,所以访问速度非常快。
在这里插入图片描述
CPU里,通常会有L1、L2、L3这样的三层高速缓存。


  • 每个CPU核心有一块属于自己的L1高速缓存,通常分为指令缓存和数据缓存,分别存放CPU使用的指令和数据。L1的cache往往就嵌入在CPU核心的内部。
  • L2的Cache同样是每个CPU核心都有的,不过它往往不在CPU核心的内部,所以L2 Cache的访问速度会比L1稍微慢一些。
  • L3 Cache,通常是多个CPU核心共用的,尺寸会更大一些,访问速度自然也就更慢一些。

可以做以下类比


  • CPU中的L1 Cache是我们的短期记忆,L2/L3是长期记忆,内存是我们的书架。
  • 当我们自己的记忆里没有资料的时候,可以从书架上拿书来看,这个过程相当于数据从内存中加载到CPU寄存器和Cache中,通过大脑,也就是CPU通过处理和运算。

DRAM


  • 内存用的芯片和Cache不同,是一种叫DRAM(Dynamic Random Access Memory,动态随机存取存储器)的芯片,比起SRAM,它的密度更高,有更大的容量,比SRAM芯片便宜不少。
  • DRAM被称为动态存储器,是因为DRAM需要靠不断的刷新,才能保持数据被存储起来。
  • DRAM的一个比特,只需要一个晶体管和一个电容就能存储,所以DRAM再同样的物理空间下,能够存储更多的数据,存储密度更大。
  • 因为数据是存储在电容里的,电容会不断漏电,所需需要定时刷新充电,才能保证数据不丢失。
  • DRAM的数据访问电路和刷新电路都比SRAM复杂,所以延时也就更长。
    在这里插入图片描述

存储器的层次结构

整个存储器的层次结构,其实都类似于SRAM和DRAM在性能和价格上的差异。


  • SRAM更贵,速度更快。DRAM更便宜,容量更大。
  • 大脑CPU中的记忆 L1 Cache,不仅受到成本的限制,还收到物理层面的限制。
    • L1不仅昂贵,其访问速度和它到CPU的距离有关
    • 芯片越大,总有部分离CPU会变远。
    • 电信号传输速度受物理原理的限制,没法超过光速
  • 内存的空间一般都是有限的,想扩大空间的话,成本就会很高,于是,想要放下更多的书,就要寻找更加廉价的解决方案。
  • 通过公共图书馆来解决,对于内存来说,SSD(Solid-state drive 或 Solid-state disk,固态硬盘) ,HDD(Hard Disk Drive,硬盘),这些被称为硬盘的外部存储设备,就是公共图书馆。
    在这里插入图片描述

CPU Cache是从内存里加载而来的,或者写回内存,不会直接写回数据到磁盘,也不会直接从硬盘加载数据到CPU Cache中,而是先加载到内存,再从内存加载到Cache中。

各个存储器只和相邻的一层存储器打交道,并且随着一层层向下,存储器的容量逐层增大,访问速度逐层变慢,而单位存储成本也逐层下降,这就构成了我们的存储器层次结构。


如何权衡存储器的价格和性能

存储器不同层级之间的性能差异和价格差异,都至少在一个数量级以上。

L1 Cache的访问延时是1纳秒,内存的访问是100纳秒。两者价格上差了400倍。

各个存储器成本对比表格
在这里插入图片描述


推荐阅读
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • 上图是InnoDB存储引擎的结构。1、缓冲池InnoDB存储引擎是基于磁盘存储的,并将其中的记录按照页的方式进行管理。因此可以看作是基于磁盘的数据库系统。在数据库系统中,由于CPU速度 ... [详细]
  • 全面介绍Windows内存管理机制及C++内存分配实例(四):内存映射文件
    本文旨在全面介绍Windows内存管理机制及C++内存分配实例中的内存映射文件。通过对内存映射文件的使用场合和与虚拟内存的区别进行解析,帮助读者更好地理解操作系统的内存管理机制。同时,本文还提供了相关章节的链接,方便读者深入学习Windows内存管理及C++内存分配实例的其他内容。 ... [详细]
  • 本文介绍了在Android开发中使用软引用和弱引用的应用。如果一个对象只具有软引用,那么只有在内存不够的情况下才会被回收,可以用来实现内存敏感的高速缓存;而如果一个对象只具有弱引用,不管内存是否足够,都会被垃圾回收器回收。软引用和弱引用还可以与引用队列联合使用,当被引用的对象被回收时,会将引用加入到关联的引用队列中。软引用和弱引用的根本区别在于生命周期的长短,弱引用的对象可能随时被回收,而软引用的对象只有在内存不够时才会被回收。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • C++字符字符串处理及字符集编码方案
    本文介绍了C++中字符字符串处理的问题,并详细解释了字符集编码方案,包括UNICODE、Windows apps采用的UTF-16编码、ASCII、SBCS和DBCS编码方案。同时说明了ANSI C标准和Windows中的字符/字符串数据类型实现。文章还提到了在编译时需要定义UNICODE宏以支持unicode编码,否则将使用windows code page编译。最后,给出了相关的头文件和数据类型定义。 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • Python中sys模块的功能及用法详解
    本文详细介绍了Python中sys模块的功能及用法,包括对解释器参数和功能的访问、命令行参数列表、字节顺序指示符、编译模块名称等。同时还介绍了sys模块中的新功能和call_tracing函数的用法。推荐学习《Python教程》以深入了解。 ... [详细]
author-avatar
ekuuu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有