当前位置:   article > 正文

Linux系统——防火墙Firewalld

Linux系统——防火墙Firewalld

目录

一、firewalld介绍

1.归入zone顺序

2.firewalld zone分类

3.预定义服务

二、图形化操作

1.打开firewalld图形化界面

2.以http服务为例,打开httpd服务

3.修改端口号

三、命令行配置

1.基础配置

2.查看现有firewalld设置

3.设置查看默认区

4.添加源地址(网段)及端口及服务

四、其他规则

1.管理rich规则

1.1rich语法

1.2man 5 firewalld.richlanguage

2.示例


一、firewalld介绍

firewalld是CentOS 7.0新推出的管理netfilter的用户空间软件工具,也被ubuntu18.04版以上所支持(apt install firewalld安装即可)

firewalld是配置和监控防火墙规则的系统守护进程。可以实iptables,ip6tables,ebtables的功能firewalld服务由firewalld包提供

1.归入zone顺序

  • 先根据数据包中源地址,将其纳为某个zone

  • 纳为网络接口所属zone

  • 纳入默认zone,默认为public zone,管理员可以改为其它zone

  • 网卡默认属于public zone,lo网络接口属于trusted zone

firewalld支持划分区域zone,每个zone可以设置独立的防火墙规则

1.已经存在了zone区域

2.使用firewall,就是将特定的流量关联到某个zone中

  • 通过源网段关联zone

  • 通过网卡关联zone区域

  • 如果两者都没有关联的数据报文,那就会去default zone

3.进入到zone以后,开始匹配zone内的规则

2.firewalld zone分类

zone名称默认配置
trusted允许所有流量
home拒绝除和传出流量相关的,以及ssh,mdsn,ipp-client,samba-client,dhcpv6-client预 定义服务之外其它所有传入流量
internal和home相同
work拒绝除和传出流量相关的,以及ssh,ipp-client,dhcpv6-client预定义服务之外的其它所有传入流量
public拒绝除和传出流量相关的,以及ssh,dhcpv6-client预定义服务之外的其它所有传入流 量,新加的网卡默认属于public zone
external拒绝除和传出流量相关的,以及ssh预定义服务之外的其它所有传入流量,属于external zone的传出ipv4流量的源地址将被伪装为传出网卡的地址
dmz拒绝除和传出流量相关的,以及ssh预定义服务之外的其它所有传入流量
block拒绝除和传出流量相关的所有传入流量
drop拒绝除和传出流量相关的所有传入流量(甚至不以ICMP错误进行回应)

3.预定义服务

服务名称配置
sshLocal SSH server. Traffic to 22/tcp
dhcpv6- clientLocal DHCPv6 client. Traffic to 546/udp on the fe80::/64 IPv6 network
ipp- clientLocal IPP printing. Traffic to 631/udp
samba- clientLocal Windows file and print sharing client. Traffic to 137/udp and 138/udp
mdnsMulticast DNS (mDNS) local-link name resolution. Traffic to 5353/udp to the 224.0.0.251 (IPv4) or ff02::fb (IPv6) multicast addresses

firewalld预定义服务配置

  • firewall-cmd --get-services 查看预定义服务列表
  • /usr/lib/firewalld/services/*.xml预定义服务的配置

firewalld 三种配置方法

  • firewall-config 图形工具: 需安装 firewall-config包
  • firewall-cmd 命令行工具: firewalld包,默认安装
  • /etc/firewalld/ 配置文件,一般不建议,如:/etc/firewalld/zones/public.xml

二、图形化操作

1.打开firewalld图形化界面

2.以http服务为例,打开httpd服务

运行时:修改后立即生效

永久:重新加载或者重启之后永久生效

3.修改端口号

三、命令行配置

1.基础配置

firewall-cmd [OPTIONS...]
firewall-cmd

选项含义
--permanent设置永久生效
--add-port=端口号/协议(tcp/udp) 设置端口号和协议
--reload重新加载防火墙设置
--remove移除规则
--get-zones列出所有可用区域
--get-default-zone查询默认区域
--set-default-zone=<ZONE>设置默认区域
--get-active-zones列出当前正使用的区域
--add-source=<CIDR>[--zone=<ZONE>]添加源地址的流量到指定区域,如果无--zone= 选项,使用
默认区域
--remove-source=<CIDR> [--zone=ZONE>]从指定区域删除源地址的流量,如无--zone= 选项,使用默认区域
--add-interface=<INTERFACE>[--zone=<ZONE>]添加来自于指定接口的流量到特定区域,如果无--zone= 选项,使用默认区域
--change-interface=<INTERFACE>[--zone=<ZONE>]改变指定接口至新的区域,如果无--zone=选项,使用默认区域
--add-service=<SERVICE> [--zone=<ZONE>]允许服务的流量通过,如果无--zone= 选项,使用默认区域
--add-port=<PORT/PROTOCOL>[--zone=<ZONE>]允许指定端口和协议的流量,如果无--zone= 选项,使用默认区域
--remove-service=<SERVICE> [--zone=<ZONE>]从区域中删除指定服务,禁止该服务流量,如果无--zone= 选项,使用默认区域
--remove-port=<PORT/PROTOCOL>[--zone=<ZONE>] 从区域中删除指定端口和协议,禁止该端口的流量,如果无--zone= 选项,使用默认区域
--reload删除当前运行时配置,应用加载永久配置
--list-services查看开放的服务
--list-ports查看开放的端口
--list-all [--zone=<ZONE>]列出指定区域的所有配置信息,包括接口,源地址,端口,服务等,如果无--zone= 选项,使用默认区域

2.查看现有firewalld设置

  1. [root@localhost ~]#systemctl start firewalld
  2. #开启
  3. [root@localhost ~]#systemctl stop firewalld.service
  4. #关闭
  5. [root@localhost ~]#systemctl status firewalld
  6. #查看状态
  7. [root@localhost ~]#firewall-cmd --list-all
  8. public (active)
  9. target: default
  10. icmp-block-inversion: no
  11. interfaces: ens33
  12. sources:
  13. services: ssh dhcpv6-client
  14. ports:
  15. protocols:
  16. masquerade: no
  17. forward-ports:
  18. source-ports:
  19. icmp-blocks:
  20. rich rules:

3.设置查看默认区

  1. [root@localhost ~]#firewall-cmd --zone=
  2. #查看区域
  3. block dmz drop external home internal public trusted work
  4. [root@localhost ~]#firewall-cmd --get-default-zone
  5. #查看默认区域
  6. [root@localhost ~]#firewall-cmd --set-default-zone
  7. block dmz drop external home internal public trusted work
  8. [root@localhost ~]#firewall-cmd --set-default-zone
  9. block dmz drop external home internal public trusted work
  10. [root@localhost ~]#firewall-cmd --set-default-zone home
  11. success
  12. [root@localhost ~]#firewall-cmd --get-default-zone
  13. home

4.添加源地址(网段)及端口及服务

  1. [root@localhost ~]#firewall-cmd --permanent --add-port=80/tcp
  2. #添加80端口
  3. [root@localhost ~]#firewall-cmd --permanent --remove-port=80/tcp
  4. #移除80端口
  5. [root@localhost ~]#firewall-cmd --permanent --add-port=80/tcp --zone=home
  6. #可以指定区域
  7. success
  8. [root@localhost ~]#firewall-cmd --add-service=http
  9. #允许http服务
  10. [root@localhost ~]#firewall-cmd --permanent --add-icmp-block=echo-request
  11. #禁止ping
  12. success
  13. [root@localhost ~]#firewall-cmd --reload
  14. success
  15. [root@localhost ~]#firewall-cmd --permanent --add-source=192.168.100.0/24
  16. # 基础命令 永久生效 添加 源 网段 子网掩码
  17. [root@localhost ~]#firewall-cmd --reload
  18. success
  19. [root@localhost ~]#firewall-cmd --list-all
  20. #查看生效策略
  21. 删除source
  22. [root@localhost ~]#firewall-cmd --zone=home --remove-source=192.168.91.0/24 --remove-source=192.168.50.0/24 --remove-source=192.168.100.0/24 --permanent

四、其他规则

当基本firewalld语法规则不能满足要求时,可以使用以下更复杂的规则

rich-rules 富规则,功能强,表达性语言

Direct configuration rules 直接规则,灵活性差, 帮助:man 5 firewalld.direct

1.管理rich规则

rich规则比基本的firewalld语法实现更强的功能,不仅实现允许/拒绝,还可以实现日志syslog和

auditd,也可以实现端口转发,伪装和限制速率

规则实施顺序:

  • 该区域的端口转发,伪装规则
  • 该区域的日志规则
  • 该区域的允许规则
  • 该区域的拒绝规则

每个匹配的规则生效,所有规则都不匹配,该区域默认规则生效

1.1rich语法

  1. rule
  2. [source]
  3. [destination]
  4. service|port|protocol|icmp-block|masquerade|forward-port
  5. [log]
  6. [audit]
  7. [accept|reject|drop]

1.2man 5 firewalld.richlanguage

选项描述
--add-rich-rule=Add to the specified zone, or the default zone if no zone is specified.
--remove-rich-rule=Remove to the specified zone, or the default zone if no zone is specified.
--query-rich-rule=Query if has been added to the specified zone, or the default zone if no zoneis specified. Returns 0 if the rule is present, otherwise 1.
--list-rich-rule=Outputs all rich rules for the specified zone, or the default zone if no zone is

2.示例

  1. 拒绝从192.168.0.100的所有流量,当address 选项使用source 或 destination时,必须用family= ipv4
  2. |ipv6
  3. [root@localhost ~]# firewall-cmd --permanent --zone=public --add-rich-rule='rule   family=ipv4 source address=192.168.0.100/32 reject'
  4. [root@localhost ~]#firewall-cmd --remove-rich-rule='rule family="ipv4" source address="192.168.91.101" reject'
  5. 限制每分钟只有两个连接到ftp服务
  6. [root@localhost ~]#firewall-cmd --add-rich-rule=‘rule service name=ftp limit value=2/m accept’
  7. 接受所有192.168.1.0/24子网端口5900-5905范围的TCP流量
  8. [root@localhost ~]#firewall-cmd --permanent --zone=vnc --add-rich-rule='rule family=ipv4 source address=192.168.1.0/24 port port=5900-5905 protocol=tcp accept'
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/114976?site
推荐阅读
相关标签
  

闽ICP备14008679号