Centos7防火墙firewalld基本配置与端口转发

作者: seamus 分类: Linux基础知识 发布时间: 2021-12-02 13:49

1.firewalld服务配置

启动服务:systemctl start firewalld

关闭服务:systemctl stop firewalld

重启服务:systemctl restart firewalld

查看服务状态:systemctl status firewalld

开机自启服务:systemctl enable firewalld

开机禁用服务:systemctl disable firewalld

查看是否开机自启:systemctl is-enable firewalld

PS:systemctl常见其他命令:

查看已启动的服务列表:systemctl list-unit-files | grep enabled

查看启动失败的服务列表:systemctl –failed

2.firewalld规则配置

查看版本:firewall-cmd –version

查看帮助:firewall-cmd –help

查看状态:firewall-cmd –state

查看所有打开的端口:firewalld-cmd –zone=public –list-ports

查看所有规则:firewall-cmd –list-all

重载规则:firewall-cmd –reload

查看区域信息:firewall-cmd –get-active-zones

查看指定接口所属区域: firewall-cmd –get-zone-of-interface=enp4s0

拒绝所有包:firewall-cmd –panic-on

取消拒绝所有包: firewall-cmd –panic-off

查看是否拒绝: firewall-cmd –query-panic

3.firewalld端口规则

添加端口:firewall-cmd –add-port=80/tcp –permanent

移除端口:firewall-cmd –remove-port=80/tcp –permanent

查看端口状态:firewall-cmd –zone=public –query-port=80/tcp

(PS:添加或删除端口后不会立即生效,配置完 –reload后才能生效;–permanent代表永久生效)

4.firewalld端口转发

开启防火墙伪装:firewall-cmd –add-masquerade –permanent    //开启后才能转发端口

添加转发规则:firewall-cmd –add-forward-port=port=80:proto=tcp:toport=8080:toaddr=192.168.1.1 –permanent

(PS:此规则将本机80端口转发到192.168.1.1的8080端口上,配置完–reload才生效)

如果配置完以上规则后仍不生效,检查防火墙是否开启80端口,如果80端口已开启,仍无法转发,可能是由于内核参数文件sysctl.conf未配置ip转发功能,具体配置如下:

vi /etc/sysctl.conf

在文本内容中添加:net.ipv4.ip_forward = 1

也可以用用命令:echo ‘net.ipv4.ip_forward = 1’ >> /etc/sysctl.conf

保存文件后,输入命令sysctl -p生效