NVMe概况
简介
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概况的更多相关文章
- NVMe over Fabrics 概况
NVMe over Fabrics 技术特征 跨网络传输NVMe命令需要特殊的考虑,而不仅仅是针对本地存储内存.例如,为了远距离传输NVMe协议,理想的底层网络或fabric技术将具有以下特性: 可靠 ...
- 文章汇总(包括NVMe SPDK vSAN Ceph xfs等)
基础部分 NVMe驱动解析-前言 NVMe驱动解析-注册设备 NVMe驱动解析-关键的BAR空间 NVMe驱动解析-DMA传输(热门) NVMe驱动解析-响应I/O请求 用一个简单的例子窥探NVMe的 ...
- NVMe over Fabrics:概念、应用和实现
对于大部分人来说,NVMe over Fabrics(简称NVMf)还是个新东西,因为其第一个正式版本的协议在今年6月份才发布.但是这并不影响人们对NVMf的关注,因为这项依托于NVMe的技术很可能继 ...
- NVMe over Fabrics又让RDMA技术火了一把
RDMA是个什么鬼?相信大部分不关心高性能网络的童鞋都不太了解.但是NVMe over Fabrics的出现让搞存储的不得不抽出时间来看看这个东西,这篇文章就来介绍下我所了解的RDMA. RDMA(R ...
- JavaScript 2016年的概况
国外的网站stateofjs.com根据超过九千位开发人员的问卷调查,发布了2016年JavaScript的年度概况报名. 注:本文翻译的部分可能存在不准确的情况,请以原文为准. 调查结果的报告目录结 ...
- [置顶] 我的设计模式学习笔记------>Java设计模式总概况
设计模式的概念最早起源于建筑设计大师Alexander的<建筑的永恒方法>一书,尽管Alexander的著作是针对建筑领域的,但是他的观点实际上用用于所有的工程设计领域,其中也包括软件设计 ...
- AHCI vs NVMe
http://www.hkepc.com/13139 儘管現時有不少高階 SSD 產品改用 PCIe 接口,以突破 SATA 接口的頻寬瓶頸,但控制器設計與 SATA 接口 SSD 一樣,採用老舊的 ...
- NVMe 与 AHCI
http://elf8848.iteye.com/blog/1731274 AHCI: NCQ技术,600MB/S,一个队列,每个队列32个指令 NVME:65000个队列,每个队列65000指令,3 ...
- NServiceBus 概况
NServiceBus 概况 NServiceBus 概况 NServiceBus 被设计用来组合面向业务的服务,它并不是用来替代诸如 WCF 一类的RPC技术. NServiceBus 不只包含通信 ...
随机推荐
- 静态库&动态库&导入库
我遇到的问题 先贴一个StackOverflow上的问题 上面的问题让我知道了更多动态库的知识. 我需要使用一个声音库(irrKlang)为2d游戏提供声音,我使用的编译器是mingw-w64,但是i ...
- vsto 学习
Object到String类型转换的四种方式 通常object到string有四种方式:(假设有object obj) obj.ToString, Convert.ToString, (string) ...
- @Autowired、@Resource、@Qualifier区别
@Autowired 1.属于spring的注解,如果不想和Spring耦合的太紧,就不推荐使用. 2.默认情况下,要求依赖对象必须存在,不能为null.如果允许为空,那么设置属性值required为 ...
- Java中WEAK_PASSWORD_HASH的修改策略
在采用SHA-256对数据进行加密时,我们可以直接采用下面的方式进行处理: public static String encodeBySha256(String content) { String e ...
- windows下web端测试环境搭建(tomcat+oracle)
一.安装oracle数据库 1.关闭防火墙.360安全卫士,运行安装程序:Setup.exe,然后下一步...... 2.安装完成后,检查服务是否已启动 3.cmd输入验证登录成功:sqlplus s ...
- Java开学测试-学生成绩管理系统
题目: 1.定义 ScoreInformation 类,其中包括七个私有变量(stunumber, name, mathematicsscore, englishiscore,networkscore ...
- 真·从零开始的Ubuntu+Apache+MySQL+PHP+phpstorm+xdebug下的debug环境搭建(纯小白向)
费了好几天劲,终于把Linux下的开发环境如何设置搞的有点明白了,在此写篇博客庆祝一下,让大家以后少踩坑(缓慢更新中) 关键词 win10双系统装Ubuntu 下载U盘烧录工具 下载UbuntuLTS ...
- PTA 1003 Emergency
问题描述 As an emergency rescue team leader of a city, you are given a special map of your country. The ...
- js数据类型1
1. 分类(2大类) 基本(值)类型--5种 Number: 任意数值 String: 任意文本 Boolean: true/false undefined: undefined null: null ...
- Sentence by defender
也许,人在旅途,不是你看清了多少事,而是你看轻了多少事.