热门标签 | 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倍。

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


推荐阅读
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
  • PHP 5.5.0rc1 发布:深入解析 Zend OPcache
    2013年5月9日,PHP官方发布了PHP 5.5.0rc1和PHP 5.4.15正式版,这两个版本均支持64位环境。本文将详细介绍Zend OPcache的功能及其在Windows环境下的配置与测试。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 深入解析TCP/IP五层协议
    本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • ASP.NET MVC中Area机制的实现与优化
    本文探讨了在ASP.NET MVC框架中,如何通过Area机制有效地组织和管理大规模应用程序的不同功能模块。通过合理的文件夹结构和命名规则,开发人员可以更高效地管理和扩展项目。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 配置Windows操作系统以确保DAW(数字音频工作站)硬件和软件的高效运行可能是一个复杂且令人沮丧的过程。本文提供了一系列专业建议,帮助你优化Windows系统,确保录音和音频处理的流畅性。 ... [详细]
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社区 版权所有