Usando o FirewallD para gerenciar seu firewall no CentOS 7

O FirewallD é um firewall gerenciado dinamicamente que fornece suporte para regras de firewall IPv4 e IPv6 e zonas de firewall disponíveis em servidores baseados no RHEL 7. É um substituto direto iptablese trabalha com o código do kernel netfilter.

Neste artigo, veremos brevemente o gerenciamento do firewall no CentOS 7 usando o firewall-cmdcomando

Verificando se o FirewallD está sendo executado

O primeiro passo é verificar se o FirewallD está instalado e em execução. Isso pode ser feito via systemdexecutando o seguinte:

$ 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
   ...

Como alternativa, você pode verificar usando a firewall-cmdferramenta:

$ firewall-cmd --state
running

Gerenciando zonas

O FirewallD opera usando o conceito de zonesonde uma zona definiu o nível de confiança usado para uma conexão. Você pode dividir interfaces de rede diferentes em zonas diferentes para aplicar regras de firewall específicas por interface ou usar uma zona para todas as interfaces.

Pronto, tudo é feito na publiczona padrão , mas existem várias outras zonas pré-configuradas que também podem ser aplicadas.

Listando todas as zonas disponíveis

Pode ser necessário obter uma lista de todas as zonas disponíveis, das quais existem várias prontas para uso. Novamente, isso pode ser feito usando firewall-cmd:

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

Verificando a zona padrão

Você pode descobrir a zona padrão atualmente configurada usando firewall-cmd:

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

Se você deseja alterar a zona padrão (por exemplo, para home), isso pode ser feito executando:

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

Esta informação será refletida no arquivo de configuração principal /etc/firewalld/firewalld.conf,. No entanto, é recomendável que você não modifique esse arquivo manualmente e use-o firewall-cmd.

Verificando as zonas atribuídas atualmente

Você pode obter uma lista das zonas às quais você tem interfaces atribuídas executando:

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

Você também pode verificar a zona de uma única interface ( eth0neste caso) executando:

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

Criando zonas

Se as zonas pré-configuradas padrão não atenderem bem às suas necessidades, a maneira mais fácil de criar uma nova zona ( zone1) é novamente através de firewall-cmd:

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

Após a criação, você precisa recarregar:

$ firewall-cmd --reload
success

Aplicando uma zona a uma interface

Para atribuir permanentemente uma interface de rede a uma zona, você pode usar, firewall-cmdembora lembre-se de incluir o --permanentsinalizador para persistir na alteração. Se estiver usando NetworkManager, você também deve usar nmclia configuração da zona de conexão.

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

Obtendo a configuração permanente de uma região

Para verificar a configuração permanente de uma zona ( publicneste caso), incluindo as interfaces atribuídas, serviços permitidos, configurações de porta e mais, execute:

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

Gerenciando serviços

Depois de atribuir e configurar as zonas necessárias, você poderá começar a adicionar serviços às zonas. Os serviços descrevem os protocolos e portas que podem ser acessados ​​para uma zona.

Listando serviços existentes

Vários serviços comuns são pré-configurados no firewalld. Estes podem ser listados:

$ 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

Você também pode obter uma lista dos serviços ativados para a zona padrão:

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

Adicionando um serviço a uma zona

Você pode ativar um determinado serviço para uma zona ( public) permanentemente usando o --add-servicesinalizador:

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

E recarregue a sessão atual do firewall:

$ firewall-cmd --reload
success

Em seguida, para verificar se foi adicionado:

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

Removendo um Serviço de uma Zona

Você pode remover publicpermanentemente um determinado serviço de uma zona ( ) usando o --remove-servicesinalizador:

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

E recarregue a sessão atual do firewall:

$ firewall-cmd --reload
success

Em seguida, para verificar se foi adicionado:

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

Adicionando / removendo vários serviços de uma zona

Você pode adicionar ou remover vários serviços (por exemplo, httpe https) de uma zona, um de cada vez, ou todos de uma vez, envolvendo os nomes de serviço desejados entre chaves ( {, }):

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

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

Criando novos serviços

Às vezes, pode ser necessário adicionar novos serviços personalizados - por exemplo, se você alterou a porta do daemon SSH. Os serviços são definidos usando arquivos XML triviais, com os arquivos padrão encontrados em /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
...

A maneira mais fácil de criar um novo serviço é copiar um desses arquivos de serviço existentes e modificá-lo. Serviços personalizados devem residir em /etc/firewalld/services. Por exemplo, para personalizar o serviço SSH:

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

O conteúdo deste arquivo copiado deve ter a seguinte aparência:

$ 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 alterar a porta, você deve alterar o nome abreviado do serviço e a porta. Você também pode alterar a descrição, se desejar, mas esses são apenas metadados extras que podem ser usados ​​por uma interface do usuário ou outro aplicativo. Neste exemplo, estou alterando a porta para 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>

Depois de salvo, você precisará recarregar o firewall e poderá aplicar sua regra à sua zona:

$ firewall-cmd --reload
success

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

Gerenciamento portuário

Além de usar serviços, você também pode permitir manualmente portas por protocolo. Para permitir a porta TCP 7777para a publiczona:

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

Você também pode adicionar um intervalo de portas:

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

Para remover (e, assim, negar) a porta TCP 7777da publiczona:

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

Você também pode listar as portas atualmente permitidas para uma determinada zona ( public) após recarregar a sessão atual do firewall:

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

Ativando o FirewallD

Depois de configurar o firewall ao seu gosto, habilite-o via systemd para garantir que ele inicie na inicialização:

$ systemctl enable firewalld

Conclusão

Há muito mais configurações e opções no FirewallD, como encaminhamento de porta, mascaramento e comunicação com o firewall via D-Bus. Esperamos que este guia tenha ajudado você a entender o básico e tenha fornecido as ferramentas para começar a firewall do seu servidor. Algumas leituras adicionais abaixo ajudarão você a tirar o máximo proveito do seu firewall.



Leave a Comment

Configure sua própria rede privada com o OpenVPN

Configure sua própria rede privada com o OpenVPN

O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes

Como instalar e configurar o CyberPanel no servidor CentOS 7

Como instalar e configurar o CyberPanel no servidor CentOS 7

Usando um sistema diferente? Introdução O CyberPanel é um dos primeiros painéis de controle do mercado, tanto de código aberto quanto de OpenLiteSpeed. What thi

Instale o eSpeak no CentOS 7

Instale o eSpeak no CentOS 7

Usando um sistema diferente? O ESpeak pode gerar arquivos de áudio de conversão de texto em fala (TTS). Isso pode ser útil por vários motivos, como criar seu próprio Turim

Monitore seus dispositivos usando o LibreNMS no CentOS 7

Monitore seus dispositivos usando o LibreNMS no CentOS 7

Usando um sistema diferente? O LibreNMS é um sistema de monitoramento de rede de código aberto completo. Ele usa o SNMP para obter os dados de diferentes dispositivos. Uma variedade

Como usar o Sudo no Debian, CentOS e FreeBSD

Como usar o Sudo no Debian, CentOS e FreeBSD

Usar um usuário sudo para acessar um servidor e executar comandos no nível raiz é uma prática muito comum entre o Linux e o Unix Systems Administrator. O uso de um sud

Como instalar o RabbitMQ no CentOS 7

Como instalar o RabbitMQ no CentOS 7

Usando um sistema diferente? O RabbitMQ é um intermediário de mensagens de código aberto amplamente usado, escrito na linguagem de programação Erlang. Como um middleware orientado a mensagens

Configurar o Nginx-RTMP no CentOS 7

Configurar o Nginx-RTMP no CentOS 7

Usando um sistema diferente? O RTMP é ótimo para veicular conteúdo ao vivo. Quando o RTMP é emparelhado com o FFmpeg, os fluxos podem ser convertidos em várias qualidades. Vultr i

Como instalar o Gradle no CentOS 7

Como instalar o Gradle no CentOS 7

Usando um sistema diferente? Gradle é um conjunto de ferramentas de automação de compilação de código aberto e gratuito baseado nos conceitos do Apache Ant e Apache Maven. Gradle fornece

Instale um servidor FTP com ProFTPd no CentOS 6 ou CentOS 7

Instale um servidor FTP com ProFTPd no CentOS 6 ou CentOS 7

Usando um sistema diferente? Neste guia, veremos como configurar um servidor FTP (ProFTPd) para transferir arquivos entre o seu PC e o seu servidor.

Instalando o Netdata no CentOS 7

Instalando o Netdata no CentOS 7

Usando um sistema diferente? O Netdata é uma estrela em ascensão no campo do monitoramento de métricas do sistema em tempo real. Comparado com outras ferramentas do mesmo tipo, o Netdata:

Como instalar o Apache Cassandra 3.11.x no CentOS 7

Como instalar o Apache Cassandra 3.11.x no CentOS 7

Usando um sistema diferente? O Apache Cassandra é um sistema de gerenciamento de banco de dados NoSQL gratuito e de código aberto, projetado para fornecer escalabilidade, alta

Como instalar um servidor Just Cause 2 (JC2-MP) no CentOS 7

Como instalar um servidor Just Cause 2 (JC2-MP) no CentOS 7

Neste tutorial, aprenda como configurar um servidor multiplayer Just Cause 2. Pré-requisitos Verifique se o sistema está totalmente atualizado antes de começarmos

Como instalar o servidor Starbound no CentOS 7

Como instalar o servidor Starbound no CentOS 7

Usando um sistema diferente? Neste tutorial, explicarei como configurar um servidor Starbound no CentOS 7. Pré-requisitos Você precisa ser o proprietário deste jogo

Instalando e configurando o ZNC no CentOS 7

Instalando e configurando o ZNC no CentOS 7

O ZNC é um segurança IRC gratuito e de código aberto que permanece permanentemente conectado a uma rede para que os clientes possam receber mensagens enviadas enquanto estiverem offline. Thi

Como instalar o Django no CentOS 7

Como instalar o Django no CentOS 7

O Django é uma estrutura Python popular para escrever aplicativos da web. Com o Django, você pode criar aplicativos mais rapidamente, sem reinventar a roda. Se você quiser você

Como instalar o CMS de outubro no CentOS 7

Como instalar o CMS de outubro no CentOS 7

Outubro é um sistema de gerenciamento de conteúdo de código aberto baseado no Laravel PHP Framework. Com uma interface elegante e uma arquitetura modular concisa

Como configurar a autenticação de dois fatores (2FA) para SSH no CentOS 6 usando o Google Authenticator

Como configurar a autenticação de dois fatores (2FA) para SSH no CentOS 6 usando o Google Authenticator

Após alterar a porta SSH, configurar a batida na porta e fazer outros ajustes para a segurança SSH, talvez haja mais uma maneira de protegê-lo

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Introdução O MyCLI é um cliente de linha de comando para MySQL e MariaDB que permite concluir automaticamente e ajuda na sintaxe de seus comandos SQL. MyCL

Como instalar o Directus 6.4 CMS em um CentOS 7 LAMP VPS

Como instalar o Directus 6.4 CMS em um CentOS 7 LAMP VPS

Usando um sistema diferente? O Directus 6.4 CMS é um sistema de gerenciamento de conteúdo sem cabeça (CMS) poderoso e flexível, gratuito e de código aberto que fornece

Como instalar o Reader Self 3.5 RSS Reader em um CentOS 7 LAMP VPS

Como instalar o Reader Self 3.5 RSS Reader em um CentOS 7 LAMP VPS

Usando um sistema diferente? O Reader Self 3.5 é um leitor de RSS auto-hospedado, simples e flexível, gratuito e de código aberto, e uma alternativa ao Google Reader. Leitor Sel

A IA pode lutar contra o aumento do número de ataques de ransomware

A IA pode lutar contra o aumento do número de ataques de ransomware

Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane

ReactOS: Este é o futuro do Windows?

ReactOS: Este é o futuro do Windows?

ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+

Como a IA pode levar a automação de processos ao próximo nível?

Como a IA pode levar a automação de processos ao próximo nível?

Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

O que é um sistema de arquivos de registro no diário e como ele funciona?

O que é um sistema de arquivos de registro no diário e como ele funciona?

Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true

Singularidade tecnológica: um futuro distante da civilização humana?

Singularidade tecnológica: um futuro distante da civilização humana?

À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

O impacto da inteligência artificial na saúde 2021

O impacto da inteligência artificial na saúde 2021

A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA ​​na área da saúde ainda está crescendo dia a dia.