Uso de FirewallD para administrar su firewall en CentOS 7

FirewallD es un firewall administrado dinámicamente que brinda soporte para las reglas y zonas de firewall de IPv4 e IPv6 que está disponible en los servidores basados ​​en RHEL 7. Es un reemplazo directo iptablesy funciona con el código del núcleo netfilter.

En este artículo, veremos brevemente cómo administrar el firewall en CentOS 7 usando el firewall-cmdcomando.

Comprobando si FirewallD se está ejecutando

El primer paso es verificar si FirewallD está instalado y ejecutándose. Esto se puede hacer systemdejecutando lo siguiente:

$ systemctl status firewalld
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)
   Active: active (running) since Thu 2016-03-10 15:07:00 UTC; 1min 30s ago
   ...

Alternativamente, puede verificar usando la firewall-cmdherramienta:

$ firewall-cmd --state
running

Administrar zonas

FirewallD funciona utilizando el concepto de zonesdónde una zona definió el nivel de confianza utilizado para una conexión. Puede dividir diferentes interfaces de red en diferentes zonas para aplicar reglas de firewall específicas por interfaz o puede usar una zona para todas las interfaces.

Fuera de la caja, todo se hace en la publiczona predeterminada , pero hay varias otras zonas preconfiguradas que también se pueden aplicar.

Listado de todas las zonas disponibles

Es posible que deba obtener una lista de todas las zonas disponibles, de las cuales hay varias listas para usar. Nuevamente, esto se puede hacer usando firewall-cmd:

$ firewall-cmd --get-zones
block dmz drop external home internal public trusted work

Comprobación de la zona predeterminada

Puede descubrir la zona predeterminada que está configurada actualmente usando firewall-cmd:

$ firewall-cmd --get-default-zone
public

Si desea cambiar la zona predeterminada (por ejemplo, a home), esto puede hacerse ejecutando:

$ firewall-cmd --set-default-zone=home
success

Esta información se reflejará en el fichero de configuración principal, /etc/firewalld/firewalld.conf. Sin embargo, se recomienda que no modifique manualmente este archivo y en su lugar lo use firewall-cmd.

Comprobación de las zonas asignadas actualmente

Puede obtener una lista de las zonas a las que tiene interfaces asignadas ejecutando:

$ firewall-cmd --get-active-zones
public
  interfaces: eth0

También puede verificar la zona de una única interfaz ( eth0en este caso) ejecutando:

$  firewall-cmd --get-zone-of-interface=eth0
public

Creando zonas

Si las zonas preconfiguradas predeterminadas no satisfacen sus necesidades, la forma más fácil de crear una nueva zona ( zone1) es nuevamente a través de firewall-cmd:

$ firewall-cmd --permanent --new-zone=zone1
success

Después de la creación, debe volver a cargar:

$ firewall-cmd --reload
success

Aplicar una zona a una interfaz

Para asignar permanentemente una interfaz de red a una zona, puede usar, firewall-cmdaunque recuerde incluir la --permanentbandera para persistir el cambio. Si lo usa NetworkManager, también debe asegurarse de usarlo nmclipara configurar la zona de conexión.

$ firewall-cmd --permanent --zone=internal --change-interface=eth1`
success

Obtener la configuración permanente de una zona

Para verificar la configuración permanente de una zona ( publicen este caso) incluyendo las interfaces asignadas, los servicios permitidos, la configuración del puerto y más, ejecute:

$ firewall-cmd --permanent --zone=public --list-all
public (default)
  interfaces:
  sources:
  services: dhcpv6-client ssh
  ports:
  masquerade: no
  forward-ports:
  icmp-blocks:
  rich rules:

Servicios de gestion

Una vez que haya asignado y configurado sus zonas requeridas, puede comenzar a agregar servicios a las zonas. Los servicios describen los protocolos y puertos a los que se puede acceder para una zona.

Listado de servicios existentes

Varios servicios comunes están preconfigurados dentro de firewalld. Estos se pueden enumerar:

$ firewall-cmd --get-services
RH-Satellite-6 amanda-client bacula bacula-client dhcp dhcpv6 dhcpv6-client dns freeipa-ldap freeipa-ldaps freeipa-replication ftp high-availability http https imaps ipp ipp-client ipsec iscsi-target kerberos kpasswd ldap ldaps libvirt libvirt-tls mdns mountd ms-wbt mysql nfs ntp openvpn pmcd pmproxy pmwebapi pmwebapis pop3s postgresql proxy-dhcp radius rpc-bind rsyncd samba samba-client smtp ssh telnet tftp tftp-client transmission-client vdsm vnc-server wbem-https

También puede obtener una lista de los servicios habilitados para la zona predeterminada:

$ firewall-cmd --list-services
dhcpv6-client ssh

Agregar un servicio a una zona

Puede habilitar un servicio dado para una zona ( public) permanentemente usando la --add-servicebandera:

$ firewall-cmd --permanent --zone=public --add-service=http
success

Y luego vuelva a cargar la sesión de firewall actual:

$ firewall-cmd --reload
success

Luego, para verificar que se agregó:

$ firewall-cmd --zone=public --list-services
dhcpv6-client http ssh

Eliminar un servicio de una zona

Puede eliminar un servicio determinado para una zona ( public) permanentemente usando la --remove-servicebandera:

$ firewall-cmd --permanent --zone=public --remove-service=http
success

Y luego vuelva a cargar la sesión de firewall actual:

$ firewall-cmd --reload
success

Luego, para verificar que se agregó:

$ firewall-cmd --zone=public --list-services
dhcpv6-client ssh

Agregar / eliminar múltiples servicios de una zona

Puede agregar o eliminar múltiples servicios (por ejemplo, httpy https) de una zona, ya sea uno a la vez, o todos a la vez envolviendo los nombres de servicios deseados entre llaves ( {, }):

$ firewall-cmd --permanent --zone=public --add-service=
success

$ firewall-cmd --permanent --zone=public --list-services
dhcpv6-client http https ssh

Creando nuevos servicios

A veces puede que necesite agregar nuevos servicios personalizados, por ejemplo, si ha cambiado el puerto para el demonio SSH. Los servicios se definen utilizando archivos XML triviales, y los archivos predeterminados se encuentran en /usr/lib/firewalld/services:

$  tree /usr/lib/firewalld/services
/usr/lib/firewalld/services
├── amanda-client.xml
├── bacula-client.xml
├── bacula.xml
├── dhcpv6-client.xml
├── dhcpv6.xml
├── dhcp.xml
├── dns.xml
├── freeipa-ldaps.xml
├── freeipa-ldap.xml
├── freeipa-replication.xml
├── ftp.xml
├── high-availability.xml
├── https.xml
├── http.xml
...

La forma más fácil de crear un nuevo servicio es copiar uno de estos archivos de servicio existentes y modificarlo. Los servicios personalizados deben residir en /etc/firewalld/services. Por ejemplo, para personalizar el servicio SSH:

$ cp /usr/lib/firewalld/services/ssh.xml /etc/firewalld/services/ssh-custom.xml

El contenido de este archivo copiado debería verse así:

$ cat /etc/firewalld/services/ssh-custom.xml
<?xml version="1.0" encoding="utf-8"?>
<service>
  <short>SSH</short>
  <description>Secure Shell (SSH) is a protocol for logging into and executing commands on remote machines. It provides secure encrypted communications. If you plan on accessing your machine remotely via SSH over a firewalled interface, enable this option. You need the openssh-server package installed for this option to be useful.</description>
  <port protocol="tcp" port="22"/>
</service>

Para cambiar el puerto, debe cambiar el nombre corto del servicio y el puerto. También puede cambiar la descripción si lo desea, pero estos son solo metadatos adicionales que podrían ser utilizados por una interfaz de usuario u otra aplicación. En este ejemplo, estoy cambiando el puerto a 1234:

$ nano /etc/firewalld/services/ssh-custom.xml
<?xml version="1.0" encoding="utf-8"?>
<service>
  <short>SSH-Custom</short>
  <description>Secure Shell (SSH) is a protocol for logging into and executing commands on remote machines. It provides secure encrypted communications. If you plan on accessing your machine remotely via SSH over a firewalled interface, enable this option. You need the openssh-server package installed for this option to be useful.</description>
  <port protocol="tcp" port="1234"/>
</service>

Una vez guardado, deberá volver a cargar el firewall y luego puede aplicar su regla a su zona:

$ firewall-cmd --reload
success

$ firewall-cmd --permanent --zone=public --add-service=ssh-custom
success

Gestión portuaria

Además de usar los servicios, también puede permitir puertos manualmente por protocolo. Para permitir el puerto TCP 7777para la publiczona:

$ firewall-cmd --permanent --zone=public --add-port=7777/tcp
success

También puede agregar un rango de puertos:

$ firewall-cmd --permanent --zone=public --add-port=7000-8000/tcp
success

Para eliminar (y por lo tanto denegar) el puerto TCP 7777para la publiczona:

$ firewall-cmd --permanent --zone=public --remove-port=7777/tcp
success

También puede enumerar los puertos permitidos actualmente para una zona determinada ( public) después de volver a cargar la sesión de firewall actual:

$ firewall-cmd --zone=public --list-ports
7000-8000/tcp

Habilitar FirewallD

Una vez que haya configurado el firewall a su gusto, debe asegurarse de habilitarlo a través de systemd para asegurarse de que comience en el inicio:

$ systemctl enable firewalld

Conclusión

Hay muchas más configuraciones y opciones dentro de FirewallD, como el reenvío de puertos, el enmascaramiento y la comunicación con el firewall a través de D-Bus. Sin embargo, es de esperar que esta guía lo haya ayudado a comprender los conceptos básicos y le haya brindado las herramientas para comenzar con el firewall de su servidor. Algunas lecturas adicionales a continuación lo ayudarán a aprovechar al máximo su firewall.



Leave a Comment

Cómo instalar MODX Revolution en un CentOS 7 LAMP VPS

Cómo instalar MODX Revolution en un CentOS 7 LAMP VPS

¿Usando un sistema diferente? MODX Revolution es un sistema de gestión de contenido (CMS) de nivel empresarial rápido, flexible, escalable, gratuito y de código abierto escrito i

Configure su propia red privada con OpenVPN

Configure su propia red privada con OpenVPN

Vultr le ofrece una increíble conectividad de red privada para servidores que se ejecutan en la misma ubicación. Pero a veces quieres dos servidores en diferentes países.

How to Install and Configure CyberPanel on Your CentOS 7 Server

How to Install and Configure CyberPanel on Your CentOS 7 Server

Using a Different System? Introduction CyberPanel is one of the first control panels on the market that is both open source and uses OpenLiteSpeed. What thi

Install eSpeak on CentOS 7

Install eSpeak on CentOS 7

Using a Different System? ESpeak can generate text-to-speech (TTS) audio files. These can be useful for many reasons, such as creating your own Turin

Cómo instalar Thelia 2.3 en CentOS 7

Cómo instalar Thelia 2.3 en CentOS 7

¿Usando un sistema diferente? Thelia es una herramienta de código abierto para crear sitios web de comercio electrónico y administrar contenido en línea, escrito en PHP. Código fuente de Thelia i

Monitoree sus dispositivos usando LibreNMS en CentOS 7

Monitoree sus dispositivos usando LibreNMS en CentOS 7

¿Usando un sistema diferente? LibreNMS es un completo sistema de monitoreo de red de código abierto. Utiliza SNMP para obtener los datos de diferentes dispositivos. Una variedad

Cómo instalar Cacti 1.1 en CentOS 7

Cómo instalar Cacti 1.1 en CentOS 7

Cacti es una herramienta de gráficos y monitoreo de red de código abierto y libre escrita en PHP. Con la ayuda de RRDtool (herramienta de base de datos Round-Robin), Cacti se puede usar t

Cómo usar Sudo en Debian, CentOS y FreeBSD

Cómo usar Sudo en Debian, CentOS y FreeBSD

Usar un usuario sudo para acceder a un servidor y ejecutar comandos a nivel raíz es una práctica muy común entre Linux y Unix Systems Administrator. El uso de un sud

Cómo supervisar de forma segura los servidores remotos con Zabbix en CentOS 7

Cómo supervisar de forma segura los servidores remotos con Zabbix en CentOS 7

¿Usando un sistema diferente? Zabbix es un software gratuito y de código abierto listo para empresas que se utiliza para monitorear la disponibilidad de sistemas y componentes de red.

Cómo instalar MODX CMS y Nginx en CentOS 7

Cómo instalar MODX CMS y Nginx en CentOS 7

MODX es un sistema de gestión de contenido gratuito y de código abierto escrito en PHP. Utiliza MySQL o MariaDB para almacenar su base de datos. MODX está diseñado para el negocio i

Cómo instalar YOURLS en CentOS 7

Cómo instalar YOURLS en CentOS 7

YOURLS (Your Own URL Shortener) es una aplicación de análisis de datos y acortamiento de URL de código abierto. En este artículo, cubriremos el proceso de instalación

Setup Nginx-RTMP on CentOS 7

Setup Nginx-RTMP on CentOS 7

Using a Different System? RTMP is great for serving live content. When RTMP is paired with FFmpeg, streams can be converted into various qualities. Vultr i

Cómo instalar LimeSurvey en CentOS 7

Cómo instalar LimeSurvey en CentOS 7

LimeSurvey es una herramienta de encuestas en línea gratuita y de código abierto que se utiliza ampliamente para publicar encuestas en línea y para recopilar comentarios de encuestas. En este artículo, voy a

Cómo instalar Vanilla Forum en CentOS 7

Cómo instalar Vanilla Forum en CentOS 7

¿Usando un sistema diferente? Vanilla forum es una aplicación de foro de código abierto escrita en PHP. Es totalmente personalizable, fácil de usar y admite dispositivos externos.

Instalación de Netdata en CentOS 7

Instalación de Netdata en CentOS 7

¿Usando un sistema diferente? Netdata es una estrella en ascenso en el campo del monitoreo de métricas del sistema en tiempo real. En comparación con otras herramientas del mismo tipo, Netdata:

Cómo instalar el servidor Just Cause 2 (JC2-MP) en CentOS 7

Cómo instalar el servidor Just Cause 2 (JC2-MP) en CentOS 7

En este tutorial, aprende bien cómo configurar un servidor multijugador Just Cause 2. Requisitos previos Asegúrese de que el sistema esté completamente actualizado antes de comenzar

Cómo instalar Starbound Server en CentOS 7

Cómo instalar Starbound Server en CentOS 7

¿Usando un sistema diferente? En este tutorial, explicaré cómo configurar un servidor Starbound en CentOS 7. Requisitos previos Necesitas tener este juego contigo

Instalación y configuración de ZNC en CentOS 7

Instalación y configuración de ZNC en CentOS 7

ZNC es un enlace IRC gratuito y de código abierto que permanece permanentemente conectado a una red para que los clientes puedan recibir mensajes enviados mientras están desconectados. Thi

Cómo instalar Django en CentOS 7

Cómo instalar Django en CentOS 7

Django es un marco de Python popular para escribir aplicaciones web. Con Django, puede crear aplicaciones más rápido, sin reinventar la rueda. Si tu quieres

Cómo configurar ionCube Loader en CentOS 7

Cómo configurar ionCube Loader en CentOS 7

ionCube Loader es una extensión PHP que permite que un servidor web ejecute archivos PHP que han sido codificados usando ionCube Encoder y es necesario para ejecutar

¿Puede la IA luchar con un número cada vez mayor de ataques de ransomware?

¿Puede la IA luchar con un número cada vez mayor de ataques de ransomware?

Los ataques de ransomware van en aumento, pero ¿puede la IA ayudar a lidiar con el último virus informático? ¿Es la IA la respuesta? Lea aquí, sepa que la IA es una bendición o una perdición

ReactOS: ¿Es este el futuro de Windows?

ReactOS: ¿Es este el futuro de Windows?

ReactOS, un sistema operativo de código abierto y gratuito, está aquí con la última versión. ¿Puede satisfacer las necesidades de los usuarios de Windows de hoy en día y acabar con Microsoft? Averigüemos más sobre este estilo antiguo, pero una experiencia de sistema operativo más nueva.

Manténgase conectado a través de la aplicación de escritorio WhatsApp 24 * 7

Manténgase conectado a través de la aplicación de escritorio WhatsApp 24 * 7

Whatsapp finalmente lanzó la aplicación de escritorio para usuarios de Mac y Windows. Ahora puede acceder a Whatsapp desde Windows o Mac fácilmente. Disponible para Windows 8+ y Mac OS 10.9+

¿Cómo puede la IA llevar la automatización de procesos al siguiente nivel?

¿Cómo puede la IA llevar la automatización de procesos al siguiente nivel?

Lea esto para saber cómo la Inteligencia Artificial se está volviendo popular entre las empresas de pequeña escala y cómo está aumentando las probabilidades de hacerlas crecer y dar ventaja a sus competidores.

La actualización complementaria de macOS Catalina 10.15.4 está causando más problemas que resolver

La actualización complementaria de macOS Catalina 10.15.4 está causando más problemas que resolver

Recientemente, Apple lanzó macOS Catalina 10.15.4, una actualización complementaria para solucionar problemas, pero parece que la actualización está causando más problemas que conducen al bloqueo de las máquinas Mac. Lee este artículo para obtener más información

13 Herramientas comerciales de extracción de datos de Big Data

13 Herramientas comerciales de extracción de datos de Big Data

13 Herramientas comerciales de extracción de datos de Big Data

¿Qué es un sistema de archivos de diario y cómo funciona?

¿Qué es un sistema de archivos de diario y cómo funciona?

Nuestra computadora almacena todos los datos de una manera organizada conocida como sistema de archivos de diario. Es un método eficiente que permite a la computadora buscar y mostrar archivos tan pronto como presiona buscar.

Singularidad tecnológica: ¿un futuro lejano de la civilización humana?

Singularidad tecnológica: ¿un futuro lejano de la civilización humana?

A medida que la ciencia evoluciona a un ritmo rápido, asumiendo muchos de nuestros esfuerzos, también aumentan los riesgos de someternos a una singularidad inexplicable. Lea, lo que la singularidad podría significar para nosotros.

Una mirada a 26 técnicas analíticas de Big Data: Parte 1

Una mirada a 26 técnicas analíticas de Big Data: Parte 1

Una mirada a 26 técnicas analíticas de Big Data: Parte 1

El impacto de la inteligencia artificial en la atención médica 2021

El impacto de la inteligencia artificial en la atención médica 2021

La IA en la salud ha dado grandes pasos desde las últimas décadas. Por tanto, el futuro de la IA en el sector sanitario sigue creciendo día a día.