Home Diary Blog Photo Community Open Source
Firewalld For CentOS

Firewalld For CentOS

Firewalld基本使用

启动: systemctl start firewalld
停止: systemctl stop firewalld
禁用: systemctl disable firewalld
启用: systemctl enable firewalld
状态: systemctl status firewalld

Firewalld基本操作

systemctl是CentOS7的服务管理工具中主要的工具,它融合之前service和chkconfig的功能于一体。

启动一个服务: systemctl start firewalld.service
关闭一个服务: systemctl stop firewalld.service
重启一个服务: systemctl restart firewalld.service
显示一个服务的状态: systemctl status firewalld.service
在开机时启用一个服务: systemctl enable firewalld.service
在开机时禁用一个服务: systemctl disable firewalld.service
查看服务是否开机启动: systemctl is-enabled firewalld.service
查看已启动的服务列表: systemctl list-unit-files|grep enabled
查看启动失败的服务列表: systemctl --failed

配置firewalls-cmd

查看版本:  firewall-cmd --version
查看帮助:  firewall-cmd --help
显示状态:  firewall-cmd --state
查看所有打开的端口:  firewall-cmd --zone=public --list-ports
更新防火墙规则:  firewall-cmd --reload
查看区域信息:  firewall-cmd --get-active-zones
查看指定接口所属区域:  firewall-cmd --get-zone-of-interface=eth0
拒绝所有包: firewall-cmd --panic-on
取消拒绝状态:  firewall-cmd --panic-off
查看是否拒绝:  firewall-cmd --query-panic

开启端口

增加端口: firewall-cmd --zone=public --add-port=80/tcp --permanent 
重新载入: firewall-cmd --reload
查看端口: firewall-cmd --zone=public --query-port=80/tcp
删除端口: firewall-cmd --zone=public --remove-port=80/tcp --permanent

--permanent永久生效,没有此参数重启后失效

查看端口

firewall-cmd --list-services

其实一个服务对应一个端口,每个服务对应/usr/lib/firewalld/services下面一个xml文件。

查看服务

firewall-cmd --get-services

查看所有打开的端口

firewall-cmd --zone=public --list-ports

对指定IP开放指定端口

(1)mysql端口设置。允许192.168.1.125访问3306端口

firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.1.125" port protocol="tcp" port="3306" accept"

(2)redis端口设置。允许192.168.142.166访问6379端口

firewall-cmd --permanent --add-rich-rule="rule family="ipv4" source address="192.168.1.125" port protocol="tcp" port="6379" accept"

(3)重启防火墙,使配置生效

systemctl restart firewalld.service

(4)查看配置结果,验证配置

firewall-cmd --list-all

(5)删除规则

firewall-cmd --permanent --remove-rich-rule="rule family="ipv4" source address="192.168.1.125" port protocol="tcp" port="3306" accept"