简介

NVMe是为满足企业和客户系统需求,利用基于PCIe的固态存储,而精心设计的一个优化的,高效的,可伸缩主机控制器接口。NVMe是为非易失性内存(NVM)技术从头开始全新构建的,目的在于超越硬盘驱动器技术的黑暗时代。从今天的NAND闪存技术到未来高性能、持久的内存技术,用这些非易失存储构建存储设备,NVMe的设计为这些非易失存储(NVM)构建的存储设备提供高效访问。

有几个NVMe设法解决的性能指标,包括带宽,IOPs,时延。例如,串行ATA最大可能的IOPs是200000【20万】,而NVMe设备已经被证明可以超过1000000【100万】IOPs。通过支持PCIe和网络(例如RDMA,FC)NVMe能够支持比SATA或SAS高很多的带宽(例如PCIe Gen3 x4达到4GB/s)。下一代内存技术可能使读访问时延低于一个微秒,要求新的协议包括软件栈在内能够低于10微秒的端到端时延。

对存储来说,从软件栈到硬件设备和系统,NVMe是一个全新的架构。

历史和路标

NVMe协议优势

NVMe作为一种存储协议,被从头开始设计用于非易失性内存(NVM),包括当前的NAND flash技术和下一代NVM技术。因此,它没有像为硬盘驱动器设计的存储协议那样做相同的限制。

NVMe协议支持多个深度队列,这是对传统SAS和SATA协议的改进。典型的SAS设备在一个队列中最多支持256条命令,而SATA设备最多支持32条命令。这些对于硬盘驱动器技术来说已经足够了,但是不能充分利用当前和下一代NVM技术。

与此相反,NVMe支持每个队列64K命令,最多支持64K队列。这些队列的设计使得I/O命令和对这些命令的响应操作在相同的处理器内核上,并且可以利用多核处理器的并行处理能力。每个应用程序或线程都可以有自己独立的队列,因此不需要I/O锁定。NVMe还支持MSI-X和中断控制,这可以防止CPU级别的瓶颈,并在系统扩展时支持大规模的可伸缩性。

此外,NVMe有一个精简而简单的命令集,它使用不到SAS或SATA一半的CPU指令来处理I/O请求,在主机软件堆栈中提供更高的每CPU指令周期IOPS和更低的I/O延迟。NVMe还支持企业特性(如预订)和客户端特性(如电源管理),将改进的效率扩展到I/O之外。

接口形式和功耗

NVMe专注于存储协议,可以处理各种形式的接口。这些包括:

  • M.2形式
  • U.2 2.5-inch驱动器形式(以前称为SFF-8639)
  • Add-in PCIe卡(AIC)

NVMe功率范围从全功率企业设备到低功率移动设备。NVMe还利用处理器电源状态的优势。

操作系统支持

在一下环境中已经支持NVMe。

存储安全

NVMe通过支持隧道协议解决当前的数据隐私问题,该协议提供可信计算组(TCG)和其他相关社区生成的安全特性。

计划为NVMe设备和系统提供的功能包括简单的访问控制、静态数据保护、密码擦除、清除级擦除和其他功能。

有关NVMe存储安全性的其他信息,请参阅可信计算组和NVM Express联合白皮书:TCG storage, Opal和NVMe,网址为http://www.nvmexpress.org/white-papers/

总结

NVMe正在迅速获得消费者和供应商的认可。一些行业分析师预测,NVMe将在未来几年成为主流的存储接口。由于其高性能和低延迟特性,以及几乎所有平台的可用性,NVMe是一个行业进程的改变者。

与以往任何存储协议不同,存储设备和存储子系统第一次有了与主机操作的根本不同的方式。精简的指令、较低的延迟软件堆栈、队列的并行性和较大的队列深度,以及非易失性内存的设计,提供了以前从未听说过的I/O和吞吐率,以及有史以来最低的存储延迟。

NVMe概况的更多相关文章

  1. NVMe over Fabrics 概况

    NVMe over Fabrics 技术特征 跨网络传输NVMe命令需要特殊的考虑,而不仅仅是针对本地存储内存.例如,为了远距离传输NVMe协议,理想的底层网络或fabric技术将具有以下特性: 可靠 ...

  2. 文章汇总(包括NVMe SPDK vSAN Ceph xfs等)

    基础部分 NVMe驱动解析-前言 NVMe驱动解析-注册设备 NVMe驱动解析-关键的BAR空间 NVMe驱动解析-DMA传输(热门) NVMe驱动解析-响应I/O请求 用一个简单的例子窥探NVMe的 ...

  3. NVMe over Fabrics:概念、应用和实现

    对于大部分人来说,NVMe over Fabrics(简称NVMf)还是个新东西,因为其第一个正式版本的协议在今年6月份才发布.但是这并不影响人们对NVMf的关注,因为这项依托于NVMe的技术很可能继 ...

  4. NVMe over Fabrics又让RDMA技术火了一把

    RDMA是个什么鬼?相信大部分不关心高性能网络的童鞋都不太了解.但是NVMe over Fabrics的出现让搞存储的不得不抽出时间来看看这个东西,这篇文章就来介绍下我所了解的RDMA. RDMA(R ...

  5. JavaScript 2016年的概况

    国外的网站stateofjs.com根据超过九千位开发人员的问卷调查,发布了2016年JavaScript的年度概况报名. 注:本文翻译的部分可能存在不准确的情况,请以原文为准. 调查结果的报告目录结 ...

  6. [置顶] 我的设计模式学习笔记------>Java设计模式总概况

    设计模式的概念最早起源于建筑设计大师Alexander的<建筑的永恒方法>一书,尽管Alexander的著作是针对建筑领域的,但是他的观点实际上用用于所有的工程设计领域,其中也包括软件设计 ...

  7. AHCI vs NVMe

    http://www.hkepc.com/13139 儘管現時有不少高階 SSD 產品改用 PCIe 接口,以突破 SATA 接口的頻寬瓶頸,但控制器設計與 SATA  接口 SSD 一樣,採用老舊的 ...

  8. NVMe 与 AHCI

    http://elf8848.iteye.com/blog/1731274 AHCI: NCQ技术,600MB/S,一个队列,每个队列32个指令 NVME:65000个队列,每个队列65000指令,3 ...

  9. NServiceBus 概况

    NServiceBus 概况 NServiceBus 概况 NServiceBus 被设计用来组合面向业务的服务,它并不是用来替代诸如 WCF 一类的RPC技术. NServiceBus 不只包含通信 ...

随机推荐

  1. redis学习三连奏,绝对让你彻底吃透分布式架构精髓

    2020年初,远程办公与直播授课成为国民刚需,腾讯因此免费开放可支持300人同时在线会议的“腾讯会议”.一时之间,这款软件的用户呈爆发性增长,据统计,腾讯会议一天就有近较100倍日常的会议数量. 谈及 ...

  2. PHP程序员福利“看免费直播,学MySQL索引优化”

    六星教育了解到,MySQL是目前所知PHP最流行的关系型数据库管理系统之一,它将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性.之所以它会成为主流使用数据库,这 ...

  3. navicate premium连接sqlserver时报08001错误的解决方法

    ---恢复内容开始--- navicate premium连接sqlserver时报08001错误的解决方法 1.自己一直使用navicate连接sqlserver,但是自从自己的电脑安装了sqlse ...

  4. (办公)记事本_linux压缩命令

    参考谷粒学院的linux视频教程:http://www.gulixueyuan.com/course/300/task/7091/show 在Linux中可以识别的常见的压缩格式有十几种,比如&quo ...

  5. pip 配置国内源

      网上已经有很多人介绍了,我写在这儿就是为了找起来方便. https://www.cnblogs.com/schut/p/10410087.html 这篇博客还是很有意思的,他介绍了两种方法.可以一 ...

  6. 修改Linux中ssh协议中的默认端口号22

    说明:最近的一台服务器老是提示异常登录.主要原因是你的账户和密码可能太简单了,别人用默认的端口22进行登录. 打开SSH端口所在文件 vim /etc/ssh/sshd_config 进入编辑模式,将 ...

  7. react+dva+antd+umi项目建立操作流程及知识点总结

    0.1 引用 0.1.1 react官网 0.1.2 dva官网 0.1.3 antd-mobile官网 0.1.4 umijs官网 0.1.5 转载文章-umi操作手册 一.what are the ...

  8. 使用 Hyper-V 替代 VMware

    目前我又用回了vmware,原因是,Hyper-V性能不如vmware,而且导出的虚拟机文件,再导入会出现奇怪的问题.不省心. Hyper-V是什么 Hyper-V硬件要求为Windows 10 企业 ...

  9. js 数据类型的转换

    1. 字符串转化为数字 Number(1) parseInt(1) parseFloat(1) 区别: number 参数只要含有非数字,结果就是NaN,

  10. 题解【洛谷P1596】[USACO10OCT]Lake Counting

    题面 \(\text{Flood Fill}\) 模板题. \(\text{Flood Fill}\) 可以快速求出一个图中连通块的个数. 大概就是遍历每一个点,如果它没有被遍历过且是一个新连通块,那 ...