stringtranslate.com

Controlador de interfaz de red

Un controlador de interfaz de red ( NIC , también conocido como tarjeta de interfaz de red , [3] adaptador de red , adaptador LAN e interfaz de red física [4] ) es un componente de hardware de computadora que conecta una computadora a una red de computadoras . [5]

Los primeros controladores de interfaz de red se implementaban comúnmente en tarjetas de expansión que se conectaban a un bus de computadora . El bajo costo y la ubicuidad del estándar Ethernet significa que la mayoría de las computadoras más nuevas tienen una interfaz de red incorporada en la placa base o contenida en un dispositivo USB conectado .

Los controladores de interfaz de red modernos ofrecen características avanzadas como interfaces de interrupción y DMA a los procesadores host, soporte para múltiples colas de recepción y transmisión, partición en múltiples interfaces lógicas y procesamiento de tráfico de red en el controlador, como el motor de descarga TCP .

Objetivo

El controlador de red implementa los circuitos electrónicos necesarios para comunicarse utilizando una capa física específica y un estándar de capa de enlace de datos como Ethernet o Wi-Fi . [a] Esto proporciona una base para una pila de protocolos de red completa , lo que permite la comunicación entre computadoras en la misma red de área local (LAN) y comunicaciones de red a gran escala a través de protocolos enrutables, como el Protocolo de Internet (IP).

La NIC permite que las computadoras se comuniquen a través de una red informática, ya sea mediante cables o de forma inalámbrica. La NIC es un dispositivo de capa física y de capa de enlace de datos, ya que proporciona acceso físico a un medio de red y, para redes IEEE 802 y similares, proporciona un sistema de direccionamiento de bajo nivel mediante el uso de direcciones MAC que se asignan de forma exclusiva a las interfaces de red.

Implementación

12 tarjetas de red para PC de 8 y 16 bits de ISA. La tarjeta que se encuentra más abajo a la derecha es una de las primeras tarjetas de red inalámbrica y la tarjeta central con una cubierta de plástico beige parcial es un módem PSTN .
Controlador Ethernet Gigabit de dos puertos Intel Ophir 82571

Los controladores de red se implementaron originalmente como tarjetas de expansión que se conectaban a un bus de computadora. El bajo costo y la ubicuidad del estándar Ethernet significa que la mayoría de las computadoras nuevas tienen un controlador de interfaz de red integrado en la placa base. Las placas base de servidor más nuevas pueden tener múltiples interfaces de red integradas. Las capacidades de Ethernet están integradas en el chipset de la placa base o se implementan a través de un chip Ethernet dedicado de bajo costo. Por lo general, ya no se requiere una tarjeta de red separada a menos que se necesiten conexiones de red independientes adicionales o se use algún tipo de red que no sea Ethernet. Una tendencia general en el hardware de computadoras es integrar los diversos componentes de los sistemas en un chip , y esto también se aplica a las tarjetas de interfaz de red.

Un controlador de red Ethernet normalmente tiene un conector 8P8C donde se conecta el cable de red. Las NIC más antiguas también suministraban conexiones  BNC o AUI . Los controladores de red Ethernet normalmente admiten variedades Ethernet de 10 Mbit/s , Ethernet de 100 Mbit/s y Ethernet de 1000 Mbit/s . Dichos controladores se designan como 10/100/1000 , lo que significa que pueden admitir velocidades de datos de 10, 100 o 1000 Mbit/s. Las NIC Ethernet de 10 Gigabit también están disponibles y, a partir de noviembre de 2014 , están comenzando a estar disponibles en las placas base de las computadoras . [6] [7]

Una NIC de doble puerto SFP+ Qlogic QLE3442-CU

Los diseños modulares como SFP y SFP+ son muy populares, especialmente para la comunicación por fibra óptica . Estos definen un receptáculo estándar para transceptores dependientes del medio, de modo que los usuarios puedan adaptar fácilmente la interfaz de red a sus necesidades.

Los LED adyacentes o integrados al conector de red informan al usuario si la red está conectada y cuándo hay actividad de datos.

La NIC puede incluir ROM para almacenar su dirección MAC asignada de fábrica . [8]

La NIC puede utilizar una o más de las siguientes técnicas para indicar la disponibilidad de paquetes para transferir:

Las NIC pueden utilizar una o más de las siguientes técnicas para transferir paquetes de datos:

Rendimiento y funcionalidad avanzada

Una interfaz de red de modo de transferencia asíncrono (ATM)
NIC Intel 82574L Gigabit Ethernet , una tarjeta PCI Express ×1, que proporciona dos colas de recepción de hardware [9]

Las NIC multicola proporcionan múltiples colas de transmisión y recepción , lo que permite que los paquetes recibidos por la NIC se asignen a una de sus colas de recepción. La NIC puede distribuir el tráfico entrante entre las colas de recepción utilizando una función hash . Cada cola de recepción se asigna a una interrupción separada ; al enrutar cada una de esas interrupciones a diferentes CPU o núcleos de CPU , el procesamiento de las solicitudes de interrupción activadas por el tráfico de red recibido por una única NIC se puede distribuir, mejorando el rendimiento. [10] [11]

La distribución basada en hardware de las interrupciones, descrita anteriormente, se conoce como escalamiento del lado de recepción (RSS). [12] : 82  También existen implementaciones puramente de software, como la dirección de paquetes de recepción (RPS), la dirección de flujo de recepción (RFS), [10] e Intel Flow Director . [12] : 98, 99  [13] [14] [15] Se pueden lograr mejoras de rendimiento adicionales al enrutar las solicitudes de interrupción a las CPU o núcleos que ejecutan las aplicaciones que son los destinos finales de los paquetes de red que generaron las interrupciones. Esta técnica mejora la localidad de referencia y da como resultado un mayor rendimiento general, una latencia reducida y una mejor utilización del hardware debido a la mayor utilización de las cachés de la CPU y menos cambios de contexto necesarios .

Con NIC de cola múltiple, se pueden lograr mejoras de rendimiento adicionales al distribuir el tráfico saliente entre diferentes colas de transmisión. Al asignar diferentes colas de transmisión a diferentes CPU o núcleos de CPU, se pueden evitar conflictos internos en el sistema operativo. Este enfoque se conoce generalmente como direccionamiento de paquetes de transmisión (XPS). [10]

Algunos productos cuentan con particionamiento de NIC ( NPAR , también conocido como particionamiento de puertos ) que utiliza la virtualización SR-IOV para dividir una única NIC Ethernet de 10 Gigabit en múltiples NIC virtuales discretas con ancho de banda dedicado, que se presentan al firmware y al sistema operativo como funciones de dispositivo PCI independientes . [3] [16]

Algunas NIC proporcionan un motor de descarga TCP para descargar el procesamiento de toda la pila TCP/IP al controlador de red. Se utiliza principalmente con interfaces de red de alta velocidad, como Gigabit Ethernet y 10 Gigabit Ethernet, para las que la sobrecarga de procesamiento de la pila de red se vuelve significativa. [17]

Algunas NIC ofrecen matrices de puertas programables en campo (FPGAs) integradas para el procesamiento programable por el usuario del tráfico de red antes de que llegue al ordenador anfitrión, lo que permite latencias significativamente reducidas en cargas de trabajo sensibles al tiempo. [18] Además, algunas NIC ofrecen pilas TCP/IP completas de baja latencia que se ejecutan en FPGAs integradas en combinación con bibliotecas de espacio de usuario que interceptan operaciones de red que normalmente realiza el núcleo del sistema operativo ; la pila de red OpenOnload de código abierto de Solarflare que se ejecuta en Linux es un ejemplo. Este tipo de funcionalidad suele denominarse redes a nivel de usuario . [19] [20] [21]

Véase también

Notas

  1. ^ Aunque existen otras tecnologías de red, Ethernet ( IEEE 802.3 ) y Wi-Fi ( IEEE 802.11 ) han alcanzado una ubicuidad casi total como tecnologías LAN desde mediados de la década de 1990.

Referencias

  1. ^ "Configuración de la velocidad del puerto y el modo dúplex". docs.ruckuswireless.com . Consultado el 25 de septiembre de 2020 .
  2. ^ Admin, Arista (23 de abril de 2020). "Sección 11.2: Estándares de Ethernet - Arista". Arista Networks . Consultado el 28 de septiembre de 2020 .
  3. ^ ab "Mejora de la escalabilidad mediante particionamiento de tarjetas de interfaz de red" (PDF) . Dell . Abril de 2011 . Consultado el 12 de mayo de 2014 .
  4. ^ "Interfaz de red física". Microsoft . 7 de enero de 2009.
  5. ^ Posey, Brien M. (2006). "Conceptos básicos de redes: Parte 1 - Hardware de redes". Windowsnetworking.com . TechGenix Ltd . Consultado el 9 de junio de 2012 .
  6. ^ Jim O'Reilly (22 de enero de 2014). "¿Será 2014 el año de Ethernet de 10 gigabits?". Computación en red . Consultado el 29 de abril de 2015 .
  7. ^ "Rompiendo los límites de velocidad con ASRock X99 WS-E/10G y redes LAN Intel 10G BASE-T". asrock.com . 24 de noviembre de 2014 . Consultado el 19 de mayo de 2015 .
  8. ^ John Savill (12 de noviembre de 2000). "¿Cómo puedo cambiar la dirección MAC de una tarjeta adaptadora de red?" . Consultado el 6 de noviembre de 2023 .
  9. ^ "Hoja de datos de la familia de controladores Ethernet Gigabit Intel 82574" (PDF) . Intel . Junio ​​de 2014. p. 1 . Consultado el 16 de noviembre de 2014 .
  10. ^ a B C Tom Herbert; Willem de Bruijn (9 de mayo de 2014). "Documentación del kernel de Linux: Documentación/networking/scaling.txt". kernel.org . Consultado el 16 de noviembre de 2014 .
  11. ^ "Descripción del producto de la familia Intel Ethernet Controller i210" (PDF) . Intel . 2012 . Consultado el 16 de noviembre de 2014 .
  12. ^ ab "Intel Look Inside: Intel Ethernet" (PDF) . Lanzamiento de Xeon E5 v3 (Grantley) . Intel . 27 de noviembre de 2014. Archivado desde el original (PDF) el 26 de marzo de 2015 . Consultado el 26 de marzo de 2015 .
  13. ^ "Documentación del kernel de Linux: Documentation/networking/ixgbe.txt". kernel.org . 15 de diciembre de 2014 . Consultado el 26 de marzo de 2015 .
  14. ^ "Intel Ethernet Flow Director". Intel . 16 de febrero de 2015 . Consultado el 26 de marzo de 2015 .
  15. ^ "Introducción a Intel Ethernet Flow Director y al rendimiento de Memcached" (PDF) . Intel . 14 de octubre de 2014 . Consultado el 11 de octubre de 2015 .
  16. ^ Patrick Kutch; Brian Johnson; Greg Rose (septiembre de 2011). "Introducción al particionamiento de puertos flexibles de Intel mediante tecnología SR-IOV" (PDF) . Intel . Consultado el 24 de septiembre de 2015 .
  17. ^ Jonathan Corbet (1 de agosto de 2007). «Gran descarga de recepción». LWN.net . Consultado el 2 de mayo de 2015 .
  18. ^ "Soluciones de alto rendimiento para la ciberseguridad". New Wave Design & Verification . New Wave DV.
  19. ^ Timothy Prickett Morgan (8 de febrero de 2012). "Solarflare convierte adaptadores de red en servidores: cuando una CPU no es lo suficientemente rápida". The Register . Consultado el 8 de mayo de 2014 .
  20. ^ "OpenOnload". openonload.org . 2013-12-03 . Consultado el 2014-05-08 .
  21. ^ Steve Pope; David Riddoch (21 de marzo de 2008). "OpenOnload: una pila de red a nivel de usuario" (PDF) . openonload.org . Consultado el 8 de mayo de 2014 .

Enlaces externos