简介

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. .NET知识梳理——6.lambda

    1. lambda 1.1        匿名方法lambda表达式 Lambda表达式 Lambda是一个匿名方法,实例化委托的一个参数,编译的时候会产生一个密封类,同时增加一个方法. Lambda ...

  2. java面试必问问题总结

    1. 自我介绍 2. get跟load的区别 3. 什么是重载,什么是重写 4. HashTable跟HashMap的区别 5. Jsp九大隐式对象 6. Forword和redirect 的区别 7 ...

  3. .Net 程序代码混淆加密工具 ILProtector

    我的项目中某一部分信息比较敏感,但是.Net程序反编译之后连注释都看得到.需要把exe保护起来,如:代码混淆之后再加壳. Bing到一款.Net混淆工具  ILProtector   作为资深工具党, ...

  4. Linux systemctl系统工具常用总结(详)

    systemctl是一个系统自带的服务管理工具,可以管理系统的服务的,启动.停止.重启.自启.监视.也可以对脚本程序后台运行管理. 文章以nginx.service举例 基础命令: systemctl ...

  5. centos7 升级sqlite3

    升级sqlite3 官网 点击 1.下载源码 wget https://www.sqlite.org/2019/sqlite-autoconf-3300100.tar.gz 2.解压,编译 .tar. ...

  6. 将一个Head下的Line复制到另一个Head下(ef+linq)

    今天工作中有一个需求,要求将一个Item下的Line复制到另外一个Item下面 这个需求在工作中很多,按照以往的经验肯定是先delete from,然后再一条条遍历后insert into 这两天正好 ...

  7. Lucene索引维护(添加、修改、删除)

    1. Field域属性分类 添加文档的时候,我们文档当中包含多个域,那么域的类型是我们自定义的,上个案例使用的TextField域,那么这个域他会自动分词,然后存储            我们要根据数 ...

  8. Docker 下部署hadoop集群

    一.主机规划 3台主机:1个master.2个slaver/worker ip地址使用docker默认的分配地址: master: 主机名: hadoop2.ip地址: 172.17.0.2 slav ...

  9. Jquery实现挂号平台首页源码

    带二级导航.轮播海报.二级联动.搜索功能.Tab选项卡 按照国际惯例先放图 index.html <!DOCTYPE html> <html lang="zh-cn&quo ...

  10. UVA750回溯法典例-八皇后

    文章代码选自UVA750-8 Queens Chess Problem的部分代码 vj题目链接:https://vjudge.net/problem/UVA-750 由于UVA中要求按照字典序输出,下 ...