firewalld:禁ping设置

目录

1、rich rule禁ping 

2、通过icmp-block-inversion实现禁ping

3、通过icmp-block实现禁ping


Firewalld禁ping配置,可以通过多种方式实现,这里介绍三种方法:

1、rich rule禁ping 

通过rich rule实现禁ping,是我们最容易想到,且效果也符合要求的方案。但是,如果在此基础上还需要配置白名单,允许某些源地址可以Ping通该服务器,将无法实现!

rich rule会完全封堵icmp包,不再允许白名单设置:即便有下面的“允许192.168.188.30”也不会放行;这是跟rich rule的匹配优先级策略有关!

firewall-cmd --permanent --add-rich-rule='rule protocol value=icmp drop'
firewall-cmd --permanent --add-rich-rule='rule family=ipv4 source address="192.168.188.30" accept'

 rich rule的匹配优先级策略
日志规则始终在拒绝规则之前发生。 拒绝规则总是发生在允许规则之前。

因此firewalld的rich规则匹配顺序如下:

> 日志规则
> drop/reject规则
> accept规则

更多rich rule相关用法,执行man firewalld.richlanguage查阅帮助文档。

2、通过'icmp-block-inversion'实现禁ping

该方式其实就是如下一条iptables策略(并不是-j drop):

-A IN_public -p icmp -j REJECT --reject-with icmp-host-prohibited

当ping目的服务器时,会收到“Destination host 192.168.xx.xx administratively prohibited”响应!

这和我们想要的(直接drop)有些出入,但是,我们可以设置白名单策略!

# 禁止所有源ping
firewall-cmd --permanent --add-icmp-block-inversion
# 允许192.168.188.30 ping
firewall-cmd --permanent --add-rich-rule='rule family=ipv4 source address="192.168.188.30" icmp-type name="echo-request" accept'

3、通过icmp-block实现禁ping

icmp-block-inversion默认为no,即黑名单模式:默认放行,允许处理所有的icmp type。只有添加到黑名单的icmp type被禁止响应:通过下面的命令禁止echo-request:

该方式同样是禁止所有源地址ping,无法添加例外!

firewall-cmd --permanent --add-rich-rule='rule protocol value=icmp drop'

### 解决启动 `firewalld` 报错 “未被识别的服务” 当尝试启动 `firewalld` 服务时如果遇到“未被识别的服务”的错误提示,这通常意味着系统无法找到或加载该服务。以下是几种可能的原因及解决方案: #### 检查 `firewalld` 是否已安装 确保 `firewalld` 已经正确安装在操作系统上。可以使用包管理器来验证这一点。 对于基于 Red Hat 的发行版(如 CentOS 和 Fedora),可执行如下命令: ```bash yum install firewalld ``` 对于 Debian 及其衍生版本,则应运行: ```bash apt-get update && apt-get install firewalld ``` #### 验证服务状态并启用开机自启 即使已经安装了 `firewalld`,也有可能因为某些原因而未能正常注册为系统服务。因此建议先查看当前服务的状态: ```bash systemctl status firewalld ``` 若显示未激活或者不存在,则可以通过下面的指令将其设置为随系统启动自动开启,并立即启动它: ```bash systemctl enable firewalld systemctl start firewalld ``` #### 更新服务配置文件 有时由于更新或其他因素可能导致 `/etc/systemd/system/multi-user.target.wants/firewalld.service` 文件损坏或丢失。此时可以从原始位置重新链接此文件或将整个软件包重置到初始状态。 #### 清理缓存和服务重启 清理 systemd 缓存可能会解决问题: ```bash systemctl daemon-reload ``` 之后再次尝试启动 `firewalld` 服务。 以上操作均需具备 root 权限才能完成。通过上述措施应该能够有效处理大多数情况下关于 `firewalld` 启动失败的问题[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值