linux firewalld服务使用及开放所有端口
linux简易教程 2024-11-21 18:19 145

1、使用systemctl管理服务

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

 

2、firewalld-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 (--permanent永久生效,没有此参数重启后失效)

重新载入:
firewall-cmd --reload

查看:
firewall-cmd --zone= public --query-port=80/tcp

删除:
firewall-cmd --zone=public --remove-port=80/tcp --permanent

端口转发:
firewall-cmd --add-forward-port=port=80:proto=tcp:toport=8888 #对80端口的请求转发到8888

移除端口转发:
firewall-cmd --remove-forward-port=port=80:proto=tcp:toport=8888

查询端口转发:
firewall-cmd --query-forward-port=port=80:proto=tcp:toport=8888

禁止一个IP:
firewall-cmd --permanent --add-rich-rule='rule family=ipv4 source address="123.44.55.66" drop'
firewall-cmd --reload

禁止一个IP访问ssh服务:
firewall-cmd --permanent --zone=public --add-rich-rule="rule family=ipv4 source address=‘x.x.x.x/24‘ service name=‘ssh‘ drop"
firewall-cmd --reload


开启所有端口:

firewall-cmd --permanent --zone=public --add-port=1-65535/tcp

 

开启除8088以外的所有端口:

firewall-cmd --permanent --zone=public --add-port=1-8087/tcp
firewall-cmd --permanent --zone=public --add-port=8089-65535/tcp
firewall-cmd --reload
Powered by ©IDCSMART