ClickCease Revelar iptables vs nftables en Linux

Únase a nuestro popular boletín

Únase a más de 4.500 profesionales de Linux y el código abierto.

2 veces al mes. Sin spam.

iptables vs nftables en Linux: ¿Cuál es la diferencia?

por Artem Karasev

15 de febrero de 2024 - Director de marketing de productos

  • nftables ofrece una alternativa más sencilla y eficaz a iptables, con gestión unificada de IPv4/IPv6.
  • Funciones como la trazabilidad de reglas y las reglas multiacción de nftables mejoran la gestión de la red.
  • La transición a nftables ofrece un mejor rendimiento y simplicidad, con el apoyo de herramientas como iptables-translate.

La evolución en curso en el filtrado de paquetes de red y la gestión de cortafuegos en Linux, especialmente destacada en el debate iptables vs nftables, representa un cambio fundamental en la seguridad de la red. Tanto iptables como nftables ofrecen enfoques únicos para controlar y proteger el tráfico de red. Esta entrada de blog analizará en profundidad iptables vs nftables, destacando sus características distintivas, diferencias y aplicaciones prácticas en varios entornos de red.

 

Entender lo básico

 

Desde su introducción a finales de los años 90 iptables ha sido un componente esencial de soluciones Linux de cortafuegosofreciendo flexibilidad y un control robusto sobre el tráfico de red. Sin embargo, su compleja sintaxis puede resultar intimidante. Por el contrario nftablesintroducido con el kernel Linux 3.13 en 2014, fue diseñado para abordar algunas de las limitaciones observadas en iptables. Al examinar iptables frente a nftables, se observa que nftables agiliza el filtrado y la clasificación de paquetes, ofreciendo una sintaxis más fácil de usar, un rendimiento mejorado y una mejor compatibilidad con los protocolos de red modernos.

 

iptables vs nftables

 

La sintaxis y usabilidad de iptables, conocida por su complejidad y verbosidad, suele plantear una curva de aprendizaje pronunciada, sobre todo para los recién llegados. La sintaxis de las opciones de iptables puede ser bastante frágil en ciertos lugares. En algunos casos, se puede colocar un espacio después de una coma, mientras que en otros, no. A veces, el intercambio de dos opciones se puede hacer sin problemas, pero otras veces, puede dar lugar a un error. Esta complejidad complica especialmente las pruebas cuando las reglas son generadas por scripts.

Nftables aborda este reto con una sintaxis fácil de usar que simplifica la escritura de reglas y reduce la probabilidad de errores, lo que se traduce en una mejor manejabilidad.

Por ejemplo, una regla iptables típica podría tener este aspecto:

iptables -A INPUT -p tcp --dport 22 -j ACCEPT

Esta regla permite el tráfico SSH entrante en el puerto 22. 

En cambio, nftables, ofrece una sintaxis más sencilla, como se ve en esta regla nftables equivalente:

nft add rule ip filter input tcp dport 22 accept

 

Otro punto en la discusión iptables vs nftables es el manejo de IPv4 e IPv6. Con la prevalencia de configuraciones de doble pila en los servidores, los administradores a menudo tienen que duplicar las reglas en dos archivos de configuración diferentes. nftables supera esto mediante la integración de funcionalidades como IPv4, IPv6arp e inet en un único marco, lo que mejora el rendimiento y elimina la redundancia.

Además, nftables permite que una sola regla realice múltiples acciones. Por ejemplo, puede registrar y bloquear paquetes de una red específica como 10.10.1.0/24 simultáneamente, agilizando las configuraciones de reglas y acelerando su procesamiento.

 

Rastreo de reglas en nftables

 

Un reto común en la gestión de redes es identificar qué regla está bloqueando tráfico inesperadamente. nftables aborda esto con una función de rastreo incorporada, una funcionalidad de la que iptables carece. Por ejemplo, si hay una regla que bloquea el tráfico SSH desde un rango como 10.10.1.0/24: 

$ sudo nft insert rule inet filter input ip saddr 10.10.1.0/24 tcp dport 22 drop

 

Y estás solucionando problemas de conexiones bloqueadas desde 10.10.1.15, habilitar el rastreo para esta IP puede localizar la regla problemática:

 

$ sudo nft insert rule inet filter input ip saddr 10.10.1.15 tcp dport 22 meta nftrace set 1

 

Ejecutando nft monitor trace, puedes ver la regla exacta que causa el bloqueo.

La introducción de esta función de rastreo en nftables mejora significativamente la capacidad de depuración de conjuntos de reglas complejos, proporcionando a los administradores de red una potente herramienta para gestionar y solucionar problemas de tráfico de red.

 

Transición de iptables a nftables

 

El paso de iptables a nftables supone un cambio hacia una gestión más eficaz de la red. Herramientas como iptables-translate ayudan a convertir las reglas iptables al formato nftables, aportando ventajas como un mayor rendimiento y simplicidad. Por ejemplo, la transición de las reglas del cortafuegos de un servidor web de iptables a nftables podría implicar la conversión de las reglas iptables que permiten el tráfico HTTP y HTTPS:

iptables -P INPUT DROP

iptables -P FORWARD DROP

iptables -P OUTPUT ACCEPT

iptables -A INPUT -p tcp --dport 80 -m conntrack --ctstate NEW,ESTABLISHED -j ACCEPT

iptables -A INPUT -p tcp --dport 443 -m conntrack --ctstate NEW,ESTABLISHED -j ACCEPT

iptables -A INPUT -i lo -j ACCEPT

iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT

 

a las reglas de nftables:

nft add rule ip filter input tcp dport 80 ct state new,established accept

nft add rule ip filter input tcp dport 443 ct state new,established accept

Tras convertir todas las reglas, la nueva configuración de nftables garantizaría el mismo nivel de seguridad y gestión del tráfico que la anterior configuración de iptables, pero con las ventajas añadidas de la eficacia y sencillez de nftables.

 

Elegir la herramienta adecuada

 

Aunque iptables ha sido durante mucho tiempo una herramienta fiable, nftables emerge como una solución más eficiente y preparada para el futuro. En la decisión iptables vs nftables, la elección depende de las necesidades y entornos específicos. iptables puede seguir siendo favorecido en sistemas con configuraciones heredadas, mientras que nftables es a menudo la opción preferida en los nuevos despliegues por su rendimiento y escalabilidad. 

En ambos casos, la integración de TuxCare Linux de TuxCare garantizará que sus soluciones de cortafuegos se ejecuten en un núcleo Linux seguro, compatible y conforme.

Resumen
Revelar iptables vs nftables en Linux
Nombre del artículo
Revelar iptables vs nftables en Linux
Descripción
Descubra iptables vs nftables en Linux. Nuestra guía cubre sus características, eficiencia y por qué nftables es clave para la gestión de la seguridad de la red.
Autor
Nombre del editor
TuxCare
Logotipo de la editorial

¿Desea automatizar la aplicación de parches de vulnerabilidad sin reiniciar el núcleo, dejar el sistema fuera de servicio o programar ventanas de mantenimiento?

Conviértete en escritor invitado de TuxCare

Correo

Únete a

4,500

Profesionales de Linux y código abierto

Suscríbase a
nuestro boletín