firewall-cmd rejeitar endereço de destino

2

Estou usando o seguinte:

# cat /etc/redhat-release 
CentOS Linux release 7.1.1503 (Core) 
# rpm -q firewalld
firewalld-0.3.9-11.el7.noarch
#

Estou tentando bloquear um endereço IP específico (10.52.208.220) de meu sistema, mas não consigo:

antes:

# firewall-cmd --reload
success
# firewall-cmd --list-all
public (default, active)
  interfaces: eno1
  sources: 
  services: dhcpv6-client high-availability http https ssh
  ports: 5666/tcp 3306/tcp 5900/tcp 9001/tcp
  masquerade: no
  forward-ports: 
  icmp-blocks: 
  rich rules: 

# ping -c1 wcmisdlin01
PING wcmisdlin01.uftmasterad.org (10.52.208.220) 56(84) bytes of data.
64 bytes from wcmisdlin01.uftmasterad.org (10.52.208.220): icmp_seq=1 ttl=64 time=0.379 ms

--- wcmisdlin01.uftmasterad.org ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 0ms
rtt min/avg/max/mdev = 0.379/0.379/0.379/0.000 ms
#

depois:

# firewall-cmd --add-rich-rule='rule family="ipv4" destination address="10.52.208.220" protocol value="icmp" reject'
success
# firewall-cmd --list-all
public (default, active)
  interfaces: eno1
  sources: 
  services: dhcpv6-client high-availability http https ssh
  ports: 5666/tcp 3306/tcp 5900/tcp 9001/tcp
  masquerade: no
  forward-ports: 
  icmp-blocks: 
  rich rules: 
    rule family="ipv4" destination address="10.52.208.220" protocol value="icmp" reject

# ping -c1 wcmisdlin01
PING wcmisdlin01.uftmasterad.org (10.52.208.220) 56(84) bytes of data.
64 bytes from wcmisdlin01.uftmasterad.org (10.52.208.220): icmp_seq=1 ttl=64 time=0.266 ms

--- wcmisdlin01.uftmasterad.org ping statistics ---
1 packets transmitted, 1 received, 0% packet loss, time 0ms
rtt min/avg/max/mdev = 0.266/0.266/0.266/0.000 ms
# 

IPTABLES(8) - iptables/ip6tables — administration tool for IPv4/IPv6 packet filtering and NAT

# iptables --list IN_public_deny
Chain IN_public_deny (1 references)
target     prot opt source               destination         
REJECT     icmp --  anywhere             wcmisdlin01.uftmasterad.org  ctstate NEW reject-with icmp-port-unreachable
# 

O que estou fazendo de errado?

    
por alexus 27.08.2015 / 17:00

1 resposta

0

Na inspeção da saída completa iptables -n --list , IN_public_deny é (eventualmente) chamado da cadeia INPUT , que não tem nada a ver com pacotes enviados do sistema para o host não cancelado; esses pacotes são roteados pela cadeia OUTPUT (ou possivelmente FORWARD se o firewall for um roteador ou uma ponte entre a origem e o destino). firewalld.richlanguage(5) parece não oferecer nenhum meio de especificar que a regra deve ir para a cadeia OUTPUT (ou FORWARD ), portanto, a opção "último recurso" de uma regra direta parece ser uma solução.

firewall-cmd --direct --add-rule ipv4 filter OUTPUT_direct 0 -p icmp -d 10.52.208.220 -j REJECT --reject-with icmp-host-prohibited

(Embora geralmente eu prefira DROP (e possivelmente LOG com limitação de taxa) ao invés de enviar rejeições ICMP, como se o host-a-ser-bloqueado estivesse enlouquecendo, lançar pacotes de resposta ICMP para ele de volta em uma rede sobrecarregada fazer as coisas de mal a pior ...)

    
por 27.08.2015 / 20:08