x
1

NVM Express



NVM Express (NVMe) o la especificación de interfaz de controlador de host de memoria no volátil (NVMHCIS) es una especificación abierta de interfaz de dispositivo lógico para acceder a medios de almacenamiento no volátiles conectados a través de un bus PCI Express (PCIe). El acrónimo NVM significa memoria no volátil, que a menudo es memoria flash NAND que viene en varios factores de forma física, incluidas unidades de estado sólido (SSD), tarjetas adicionales PCI Express (PCIe), tarjetas M.2 y otras formas NVM Express, como interfaz de dispositivo lógico, ha sido diseñado para aprovechar la baja latencia y el paralelismo interno de los dispositivos de almacenamiento de estado sólido.[1]

Por su diseño, NVM Express permite que el hardware y el software del host exploten por completo los niveles de paralelismo posibles en los SSD modernos. Como resultado, NVM Express reduce la sobrecarga de E/S y ofrece varias mejoras de rendimiento en relación con las interfaces de dispositivos lógicos anteriores, incluidas múltiples colas de comandos largas y latencia reducida. (Los protocolos de interfaz anteriores se desarrollaron para su uso con unidades de disco duro (HDD) mucho más lentas donde existe un retraso muy largo (en relación con las operaciones de la CPU) entre una solicitud y transferencia de datos, donde las velocidades de datos son mucho más lentas que las velocidades de RAM, y donde el disco, la rotación y el tiempo de búsqueda dan lugar a nuevos requisitos de optimización.

Los dispositivos NVM Express están disponibles principalmente en forma de tarjetas de expansión PCI Express de tamaño estándar[2]​ y como dispositivos de factor de forma de 2.5 pulgadas que proporcionan una interfaz PCI Express de cuatro carriles a través del conector U.2 (anteriormente conocido como SFF- 8639).[3][4]​ Sin embargo, también hay dispositivos de almacenamiento que utilizan SATA Express y la especificación M.2 que admiten NVM Express como interfaz de dispositivo lógico. Estos se han convertido recientemente en un caso de uso popular para NVMe y se están convirtiendo rápidamente en la forma dominante de almacenamiento de estado sólido para computadoras de escritorio y portátiles.[5][6]

Las especificaciones para NVMe lanzadas hasta la fecha incluyen:[7]

El cambio principal entre 1.2 y 1.3 y las nuevas características son:[8]

Se han agregado una serie de diferencias y características opcionales, que incluyen: autocomprobación del dispositivo, desinfección, directivas, partición de arranque, telemetría, mejoras de virtualización, mejoras de administración de NVMe-MI, administración térmica controlada por el host, marca de tiempo, mejora del rendimiento del controlador emulado, junto con ver una serie de cambios con respecto al comportamiento anterior.

Históricamente, la mayoría de los SSD usaban buses como SATA, SAS o Fibre Channel para interactuar con el resto de un sistema informático. Desde que los SSD estuvieron disponibles en los mercados masivos, SATA se ha convertido en la forma más típica de conectar SSD en computadoras personales; sin embargo, SATA fue diseñado principalmente para interactuar con unidades de disco duro mecánicas (HDD), y se volvió cada vez más inadecuado para SSD, lo que mejoró en velocidad con el tiempo.[9]​ Por ejemplo, dentro de aproximadamente 5 años de la adopción generalizada del mercado masivo (2005–2010) muchos SSD ya se vieron retenidos por las velocidades de datos comparativamente lentas disponibles para los discos duros, a diferencia de los discos duros, algunos SSD están limitados por el rendimiento máximo de SATA.

Las SSD de gama alta se habían creado utilizando el bus PCI Express antes de NVMe, pero utilizando interfaces de especificación no estándar. Al estandarizar la interfaz de los SSD, los sistemas operativos solo necesitan un controlador para funcionar con todos los SSD que cumplan con la especificación. También significa que cada fabricante de SSD no tiene que usar recursos adicionales para diseñar controladores de interfaz específicos. Esto es similar a cómo los dispositivos de almacenamiento masivo USB están diseñados para seguir la especificación de clase de dispositivo de almacenamiento masivo USB y funcionan con todas las computadoras, sin necesidad de controladores por dispositivo.[10]

Los primeros detalles de un nuevo estándar para acceder a la memoria no volátil surgieron en el Intel Developer Forum 2007, cuando se mostró NVMHCI como el protocolo del lado del host de un diseño arquitectónico propuesto que tenía el Open NAND Flash Interface Working Group (ONFI) en el lado de los chips de memoria flash.[11]​ Ese año se formó un grupo de trabajo NVMHCI dirigido por Intel. La especificación NVMHCI 1.0 se completó en abril de 2008 y se lanzó en el sitio web de Intel.[12][13][14]

El trabajo técnico en NVMe comenzó en la segunda mitad de 2009.[15]​ Las especificaciones NVMe fueron desarrolladas por NVM Express Workgroup, que consta de más de 90 compañías; Amber Huffman de Intel fue la presidenta del grupo de trabajo. La versión 1.0 de la especificación se lanzó el 01 de marzo de 2011,[16]​ mientras que la versión 1.1 de la especificación se lanzó el 11 de octubre de 2012.[17]​ Las principales características agregadas en la versión 1.1 son E/S de múltiples rutas (con espacio de nombres compartido) y E/S de dispersión de longitud arbitraria. Se espera que las futuras revisiones mejoren significativamente la gestión del espacio de nombres. Debido a su enfoque de características, NVMe 1.1 inicialmente se llamó "Enterprise NVMHCI".[18]​ En enero de 2013 se lanzó una actualización para la especificación básica de NVMe, llamada versión 1.0e.[19]​ En junio de 2011, se formó un Grupo Promotor liderado por siete compañías.

Los primeros chipsets NVMe disponibles comercialmente fueron lanzados por Integrated Device Technology (89HF16P04AG3 y 89HF32P08AG3) en agosto de 2012.[20][21]​ La primera unidad NVMe, la unidad empresarial XS1715 de Samsung, se anunció en julio de 2013; Según Samsung, esta unidad admite una velocidad de lectura de 3 GB/s, seis veces más rápidas que sus ofertas empresariales anteriores.[22]​ La familia de controladores LSI SandForce SF3700, lanzada en noviembre de 2013, también es compatible con NVMe.[23][24]​ En el Consumer Electronics Show 2014 se presentó un producto "prosumidor" de Kingston HyperX que utilizaba este controlador y prometía un rendimiento similar.[25][26]​ En junio de 2014, Intel anunció sus primeros productos NVM Express, la familia de SSD para centros de datos que interactúa con el host a través del bus PCI Express, que incluye la serie DC P3700, la serie DC P3600 y la serie DC P3500.[27]​ A noviembre de 2014, las unidades NVMe están disponibles comercialmente.

En marzo de 2014, el grupo se incorporó para convertirse en NVM Express, Inc., que a noviembre de 2014 consta de más de 65 empresas de toda la industria. Las especificaciones de NVM Express son propiedad y están mantenidas por NVM Express, Inc., que también promueve el conocimiento de la industria de NVM Express como un estándar de toda la industria. NVM Express, Inc. está dirigido por una junta directiva de trece miembros seleccionados del Grupo de Promotores, que incluye a Cisco, Dell, EMC, HGST, Intel, Micron, Microsoft, NetApp, Oracle, PMC, Samsung, SanDisk y Seagate.[28]

En septiembre de 2016, la Asociación CompactFlash anunció que lanzaría una nueva especificación de tarjeta de memoria, CFexpress, que usa NVMe.  

Hay muchos factores de forma de la unidad de estado sólido NVMe, como AIC, U.2, U.3, M.2, etc.

Casi todas las primeras unidades de estado sólido NVMe son HHHL o FHHL AIC, con una interfaz PCIe 2.0 o 3.0. Una unidad de estado sólido HHHL AIC NVMe es fácil de adaptar para insertar en el zócalo PCIe de un servidor.

U.2 anteriormente conocido como SFF-8639, es una interfaz de computadora para conectar unidades de estado sólido a una computadora. Utiliza hasta cuatro carriles PCI Express. Un servidor Dell PowerEdge R730xd puede combinar hasta 4 unidades de estado sólido NVMe U.2.[29]​ Otros proveedores de servidores como HPE, IBM, Inspur y Supermicro tienen el mismo tipo de soporte de producto para unidades de estado sólido U.2 NVMe.

U.3 se basa en la especificación U.2 y utiliza el mismo conector SFF-8639. Es un estándar 'Tri-modo', que combina el soporte SAS, SATA y NVMe en un solo controlador. U.3 también puede admitir el intercambio en caliente entre las diferentes unidades donde el soporte de firmware está disponible. Las unidades U.3 siguen siendo compatibles con versiones anteriores de U.2, pero las unidades U.2 no son compatibles con hosts U.3.

M.2, anteriormente conocido como Factor de forma de próxima generación ( NGFF ), utiliza un bus de computadora con unidad de estado sólido M.2 NVMe. Las interfaces proporcionadas a través del conector M.2 son PCI Express 3.0 o PCI Express 4.0 (hasta cuatro carriles ).

NVM Express over Fabrics (NVMe-oF) es el concepto de utilizar un protocolo de transporte a través de una red para conectar dispositivos remotos, a diferencia de NVMe, donde los dispositivos están conectados directamente al bus PCIe (o a través de un conmutador PCIe a un bus PCIe) en septiembre de 2014, se propuso un estándar para usar NVMe sobre Fibre Channel (FC) y esta combinación a menudo se denomina FC-NVMe (o, a veces, NVMe/FC). NVMe-oF es un protocolo de comunicación que permite que una computadora acceda a dispositivos de almacenamiento de nivel de bloque conectados a otra computadora a través del acceso directo a memoria remota a través de varios protocolos de transporte:

El estándar para NVMe sobre Fabrics fue publicado por NVM Express, Inc. en 2016.[30][31]

Los siguientes controladores implementan el protocolo NVMe-oF:

Comenzando con Linux Kernel 5.0, se agregó soporte nativo para NVMe / TCP.

La interfaz de controlador de host avanzado (AHCI) tiene el beneficio de una amplia compatibilidad de software, pero tiene la desventaja de no ofrecer un rendimiento óptimo cuando se usa con SSD conectados a través del bus PCI Express. Como interfaz lógica, AHCI se desarrolló cuando el propósito de un adaptador de bus host (HBA) en un sistema era conectar el subsistema de CPU/memoria con un subsistema de almacenamiento mucho más lento basado en medios magnéticos giratorios. Como resultado, AHCI introduce ciertas ineficiencias cuando se usa con dispositivos SSD, que se comportan mucho más como DRAM que como medios giratorios.[5]

La interfaz del dispositivo NVMe se ha diseñado desde cero, aprovechando la baja latencia y el paralelismo de los SSD PCI Express y complementando el paralelismo de las CPU, plataformas y aplicaciones contemporáneas. En un alto nivel, las ventajas básicas de NVMe sobre AHCI se relacionan con su capacidad para explotar el paralelismo en el hardware y software del host, que se manifiesta por las diferencias en las profundidades de la cola de comandos, la eficiencia del procesamiento de interrupciones, la cantidad de accesos de registro que no se pueden almacenar en caché, etc. en varias mejoras de rendimiento.[5][35]:17–18

La siguiente tabla resume las diferencias de alto nivel entre las interfaces de dispositivo lógico NVMe y AHCI.

La herramienta nvmecontrol se usa para controlar un disco NVMe desde la línea de comandos en FreeBSD. Fue agregado en FreeBSD 9.2.

Herramientas de espacio de usuario NVM-Express para Linux.[68]



Escribe un comentario o lo que quieras sobre NVM Express (directo, no tienes que registrarte)


Comentarios
(de más nuevos a más antiguos)


Aún no hay comentarios, ¡deja el primero!