firewalld(Dynamic Firewall Manager of Linux systems,Linux系统的动态防火墙管理器)服务是默认的防火墙配置管理工具。

firewall-cmd 是 firewalld的字符界面管理工具,firewalld是centos7的一大特性,最大的好处有两个:支持动态更新,不用重启服务;第二个就是加入了防火墙的“zone”概念。

firewalld自身并不具备防火墙的功能,而是和iptables一样需要通过内核的netfilter来实现,也就是说firewalld和 iptables一样,他们的作用都是用于维护规则,而真正使用规则干活的是内核的netfilter。

1、firewall-cmd 主要参数

--get-default-zone  查询默认的区域名称
--set-default-zone=<区域名称> 设置默认的区域,使其永久生效
--get-zones 显示可用的区域
--get-services 显示预先定义的服务
--get-active-zones 显示当前正在使用的区域与网卡名称
--add-source= 将源自此 IP 或子网的流量导向指定的区域
--remove-source= 不再将源自此 IP 或子网的流量导向某个指定区域
--add-interface=<网卡名称> 将源自该网卡的所有流量都导向某个指定区域
--change-interface=<网卡名称> 将某个网卡与区域进行关联
--list-all 显示当前区域的网卡配置参数、资源、端口以及服务等信息
--list-all-zones 显示所有区域的网卡配置参数、资源、端口以及服务等信息
--add-service=<服务名> 设置默认区域允许该服务的流量
--add-port=<端口号/协议> 设置默认区域允许该端口的流量
--remove-service=<服务名> 设置默认区域不再允许该服务的流量
--remove-port=<端口号/协议> 设置默认区域不再允许该端口的流量
--reload 让“永久生效”的配置规则立即生效,并覆盖当前的配置规则
--panic-on 开启应急状况模式
--panic-off 关闭应急状况模式

2、常用备忘

# 查看设置:
firewall-cmd --state # 显示状态
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 --reload # 更新防火墙规则
firewall-cmd --complete-reload
# 两者的区别就是第一个无需断开连接,就是firewalld特性之一动态添加规则,第二个需要断开连接,类似重启服务 # 将接口添加到区域,默认接口都在public
firewall-cmd --zone=public --add-interface=eth0
# 永久生效再加上 --permanent 然后reload防火墙 # 设置默认接口区域,立即生效无需重启
firewall-cmd --set-default-zone=public # 查看所有打开的端口:
firewall-cmd --zone=dmz --list-ports # 加入一个端口到区域:
firewall-cmd --zone=dmz --add-port=/tcp
# 若要永久生效方法同上 # 打开一个服务,类似于将端口可视化,服务需要在配置文件中添加,/etc/firewalld 目录下有services文件夹,这个不详细说了,详情参考文档
firewall-cmd --zone=work --add-service=smtp # 移除服务
firewall-cmd --zone=work --remove-service=smtp # 显示支持的区域列表
firewall-cmd --get-zones # 设置为家庭区域
firewall-cmd --set-default-zone=home # 查看当前区域
firewall-cmd --get-active-zones # 设置当前区域的接口
firewall-cmd --get-zone-of-interface=enp03s # 显示所有公共区域(public)
firewall-cmd --zone=public --list-all # 临时修改网络接口(enp0s3)为内部区域(internal)
firewall-cmd --zone=internal --change-interface=enp03s # 永久修改网络接口enp03s为内部区域(internal)
firewall-cmd --permanent --zone=internal --change-interface=enp03s 服务管理 # 显示服务列表
Amanda, FTP, Samba和TFTP等最重要的服务已经被FirewallD提供相应的服务,可以使用如下命令查看: firewall-cmd --get-services # 允许SSH服务通过
firewall-cmd --enable service=ssh # 禁止SSH服务通过
firewall-cmd --disable service=ssh # 打开TCP的8080端口
firewall-cmd --enable ports=/tcp # 临时允许Samba服务通过600秒
firewall-cmd --enable service=samba --timeout= # 显示当前服务
firewall-cmd --list-services # 添加HTTP服务到内部区域(internal)
firewall-cmd --permanent --zone=internal --add-service=http
firewall-cmd --reload # 在不改变状态的条件下重新加载防火墙 端口管理 # 打开443/TCP端口
firewall-cmd --add-port=/tcp # 永久打开3690/TCP端口
firewall-cmd --permanent --add-port=/tcp # 永久打开端口需要reload一下,reload后临时打开的端口就失效了
firewall-cmd --reload # 查看防火墙,添加的端口也可以看到
firewall-cmd --list-all 直接模式
# FirewallD包括一种直接模式,使用它可以完成一些工作,例如打开TCP协议的9999端口
firewall-cmd --direct -add-rule ipv4 filter INPUT -p tcp --dport -j ACCEPT
firewall-cmd --reload 控制端口 / 服务
可以通过两种方式控制端口的开放,一种是指定端口号另一种是指定服务名。虽然开放 http 服务就是开放了 端口,但是还是不能通过端口号来关闭,
也就是说通过指定服务名开放的就要通过指定服务名关闭;通过指定端口号开放的就要通过指定端口号关闭。 firewall-cmd --add-service=mysql # 开放mysql端口
firewall-cmd --remove-service=http # 阻止http端口
firewall-cmd --list-services # 查看开放的服务
firewall-cmd --add-port=/tcp # 开放通过tcp访问3306
firewall-cmd --remove-port=80tcp # 阻止通过tcp访问3306
firewall-cmd --add-port=/udp # 开放通过udp访问233
firewall-cmd --list-ports # 查看开放的端口 伪装 IP
firewall-cmd --query-masquerade # 检查是否允许伪装IP
firewall-cmd --add-masquerade # 允许防火墙伪装IP
firewall-cmd --remove-masquerade# 禁止防火墙伪装IP 端口转发 端口转发可以将指定地址访问指定的端口时,将流量转发至指定地址的指定端口。
转发的目的如果不指定 ip 的话就默认为本机,如果指定了 ip 却没指定端口,则默认使用来源端口。
如果配置好端口转发之后不能用,可以检查下面两个问题: 比如我将 端口转发至 端口,首先检查本地的 端口和目标的 端口是否开放监听了
其次检查是否允许伪装 IP,没允许的话要开启伪装 IP firewall-cmd --add-forward-port=port=:proto=tcp:toport= # 将80端口的流量转发至8080
firewall-cmd --add-forward-port=proto=:proto=tcp:toaddr=192.168.1.0. # 将80端口的流量转发至192.168.0.
firewall-cmd --add-forward-port=proto=:proto=tcp:toaddr=192.168.0.1:toport= # 将80端口的流量转发至192.168.0.1的8080端口 当我们想把某个端口隐藏起来的时候,就可以在防火墙上阻止那个端口访问,然后再开一个不规则的端口,之后配置防火墙的端口转发,将流量转发过去。
端口转发还可以做流量分发,一个防火墙拖着好多台运行着不同服务的机器,然后用防火墙将不同端口的流量转发至不同机器。

最新文章

  1. FMDB第三方框架
  2. Material Design - CollapsingToolbarLayout
  3. 《JAVA学习笔记(14-10---14-11抽象类)》
  4. android学习笔记八——SeekBar
  5. CentOS6.6安装mysql出现的问题
  6. velocity properties
  7. VS 2003 无法打开Web项目 文件路径与URL不符 这两者需要映射到相同的服务器位置
  8. Nhibernate分页测试续
  9. Scaffolding Template on Asp.Net Core Razor Page
  10. 微信小程序入门(一)
  11. layer —— 一个简单的jQuery弹出层插件
  12. JavaScript中常用的BOM对象(属性、方法)
  13. Windows10安装pycocotools方法,亲测可用!
  14. 【Teradata】设置 QUERY_BAND
  15. SVN在update的时候报错Please execute the &#39;Cleanup&#39; command.
  16. Python: 字典应用题
  17. react封装组织架构递归树
  18. head first java读书笔记
  19. CF833B The Bakery 线段树,DP
  20. Android Studio安装&amp;&amp;安装bug

热门文章

  1. NB-IOT连接移动onenet平台流程
  2. Linux 7.4配置VSFTP服务器
  3. nginx支持php配置
  4. Linux命令应用大词典-第39章 网络安全
  5. C do whlie 数数位
  6. 227. Mock Hanoi Tower by Stacks【LintCode java】
  7. appcrawler遍历工具常用方法
  8. Linux服务架设篇--arp命令
  9. Docker 镜像构建的时候,应该小心的坑
  10. 【RL系列】Multi-Armed Bandit笔记——UCB策略与Gradient策略