Configurar o firewall do IPTables no CentOS 6

Introdução

Um firewall é um tipo de ferramenta de segurança de rede que controla o tráfego da rede de entrada e saída de acordo com seu conjunto de regras predefinido. Podemos usar um firewall juntamente com outras medidas de segurança para proteger nossos servidores contra ataques e invasões de hackers.

O design de um firewall pode ser um hardware dedicado ou um programa de software em execução em nossa máquina. No CentOS 6, o programa de firewall padrão é iptables.

Neste artigo, mostrarei como configurar um firewall básico de tabelas de ip baseado no aplicativo Vultr "WordPress no CentOS 6 x64", que bloqueará todo o tráfego, exceto os serviços web, SSH, NTP, DNS e ping. No entanto, essa é apenas uma configuração preliminar que satisfaz as necessidades de segurança comuns. Você precisaria de uma configuração de iptables mais sofisticada se tiver mais requisitos.

Nota :

Se você adicionar um endereço IPv6 ao seu servidor, também deverá configurar o serviço ip6tables. A configuração de ip6tables está fora do escopo deste artigo.

Ao contrário do CentOS 6, o iptables não é mais o programa de firewall padrão no CentOS 7 e foi substituído por um programa chamado firewalld. Se você planeja usar o CentOS 7, precisará configurar seu firewall usando o firewalld.

Pré-requisitos

Implemente recentemente uma instância de servidor com o aplicativo Vultr "WordPress no CentOS 6 x64" e efetue login como root.

Etapa 1: determinar os serviços e portas usados ​​no seu servidor

Suponho que este servidor hospede apenas um blog WordPress e não seja usado como roteador ou forneça outros serviços (por exemplo, correio, FTP, IRC etc.).

Aqui, precisamos dos seguintes serviços:

  • HTTP (TCP na porta 80)
  • HTTPS (TCP na porta 443)
  • SSH (TCP na porta 22, por padrão, pode ser alterado por motivos de segurança)
  • NTP (UDP na porta 123)
  • DNS (TCP e UDP na porta 53)
  • ping (ICMP)

Todas as outras portas desnecessárias serão bloqueadas.

Etapa 2: Configurar regras do iptables

Iptables controla o tráfego com uma lista de regras. Quando os pacotes de rede são enviados ao nosso servidor, o iptables os inspecionará usando cada regra em sequência e executará as ações em conformidade. Se uma regra for atendida, as outras regras serão ignoradas. Se nenhuma regra for atendida, o iptables usará a política padrão.

Todo o tráfego pode ser classificado como INPUT, OUTPUT e FORWARD.

  • O tráfego de ENTRADA pode ser normal ou malicioso, deve ser permitido seletivamente.
  • O tráfego de SAÍDA é normalmente considerado seguro e deve ser permitido.
  • O tráfego FORWARD é inútil e deve ser bloqueado.

Agora, vamos configurar as regras do iptables de acordo com nossas necessidades. Todos os seguintes comandos devem ser introduzidos a partir do seu terminal SSH como root.

Verifique as regras existentes:

iptables -L -n

Liberar todas as regras existentes:

iptables -F; iptables -X; iptables -Z

Como as alterações na configuração do iptables terão efeito imediato, se você configurar incorretamente as regras do iptables, poderá ficar bloqueado no servidor. Você pode impedir bloqueios acidentais com o seguinte comando. Lembre-se de substituir [Your-IP-Address]por seu próprio endereço IP público ou intervalo de endereços IP (por exemplo, 201.55.119.43 ou 201.55.119.0/24).

iptables -A INPUT -s [Your-IP-Address] -p tcp --dport 22 -j ACCEPT

Permita todo o tráfego de loopback (lo) e solte todo o tráfego para 127.0.0.0/8, exceto lo:

iptables -A INPUT -i lo -j ACCEPT
iptables -A INPUT -d 127.0.0.0/8 -j REJECT

Bloqueie alguns ataques comuns:

iptables -A INPUT -p tcp ! --syn -m state --state NEW -j DROP
iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP
iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP

Aceite todas as conexões de entrada estabelecidas:

iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

Permitir tráfego de entrada HTTP e HTTPS:

iptables -A INPUT -p tcp --dport 80 -j ACCEPT
iptables -A INPUT -p tcp --dport 443 -j ACCEPT

Permitir conexões SSH:

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

Permitir conexões NTP:

iptables -A INPUT -p udp --dport 123 -j ACCEPT

Permitir consultas DNS:

iptables -A INPUT -p udp --dport 53 -j ACCEPT
iptables -A INPUT -p tcp --dport 53 -j ACCEPT

Permitir ping:

iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT

Por fim, defina as políticas padrão:

iptables -P INPUT DROP
iptables -P OUTPUT ACCEPT
iptables -P FORWARD DROP

Etapa 3: salvar as configurações

Cada uma das alterações que fizemos acima entrou em vigor, mas não são permanentes. Se não os salvarmos no disco rígido, eles serão perdidos quando o sistema reiniciar.

Salve a configuração do iptables com o seguinte comando:

service iptables save

Nossas alterações serão salvas no arquivo /etc/sysconfig/iptables. Você pode revisar ou modificar as regras editando esse arquivo.

Soluções alternativas para bloqueio acidental

Se o seu servidor estiver bloqueado devido a um erro de configuração, você ainda poderá recuperar seu acesso com algumas soluções alternativas.

  • Se você ainda não salvou suas modificações nas regras do iptables, poderá reiniciar o servidor na interface do site Vultr, e as alterações serão descartadas.
  • Se você salvou as alterações, pode efetuar login no servidor através do console na interface do site Vultr e inserir iptables -Fpara liberar todas as regras do iptables. Então você pode configurar as regras novamente.


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.