firewall 服务

一、firewall 服务介绍

firewalld是Rhel 7.0新推出的管理netfilter的用户空间软件工具 firewalld是配置和监控防火墙规则的系统守护进程。

可以实现iptables,ip6tables,ebtables的功能。

firewalld服务由firewalld包提供。

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

Firewalld会检查进入系统的每个数据包的源地址。如果该源地址被分配给特定区域,则应用该区域的规则。如果该源地址未分配给某个区域,firewalld就会将数据包与传入网络接口的区域相关联,并应用该区域的规则。如果出于某种原因,网络接口未与某个区域关联,则firewalld 会将数据包与默认区域相关联。

默认区域不是一个单独的区域,而是指代现有的区域。最初,firewalld指定public区域为默认区域,并将lo回环接口映射至trusted区域。

1、归入zone顺序:

  • 先根据数据包中源地址,将其纳为某个zone
  • 纳为网络接口所属zone
  • 纳入默认zone,默认为public zone,管理员可以改为其它zone

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

2、firewalld zone分类

Firewalld上有一些预定义区域,可分别进行自定义。默认情况下,如果传入流量属于系统启动的通信的一部分,则所有区域都允许这些传入流量和所有传出流量。下表详细介绍了这些初始区域配置。

3、预定义服务

0

4、firewalld预定义服务配置

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

5、firewalld 三种配置方法

  • firewall-config (firewall-config包)图形工具
  • firewall-cmd (firewalld包)命令行工具
  • /etc/firewalld 配置文件,一般不建议

6、firewall-cmd 命令

# firewall-cmd 格式 firewall-cmd [OPTIONS...] # 常用选项 --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= 选项,使用默认区域de --remove-service=<SERVICE> [--zone=<ZONE>] 从区域中删除指定服务,禁止该服务流量,如果无--zone= 选项,使用默认区域 --remove-port=<PORT/PROTOCOL>zone=<ZONE>] 从区域中删除指定端口和协议,禁止该端口的流量,如果无--zone= 选项,使用默认区域 --reload 删除当前运行时配置,应用加载永久配置 --list-services 查看开放的服务 --list-ports 查看开放的端口 --list-all [--zone=<ZONE>] 列出指定区域的所有配置信息,包括接口,源地址,端口,服务等,如果无--zone= 选项,使用默认区域 # 案例演示 #查看默认zone firewall-cmd --get-default-zone #默认zone设为dmz firewall-cmd --set-default-zone=dmz #在internal zone中增加源地址192.168.0.0/24的永久规则 firewall-cmd --permanent --zone=internal --add-source=192.168.0.0/24 #在internal zone中增加协议mysql的永久规则 firewall-cmd --permanent --zone=internal --add-service=mysql #加载新规则以生效 firewall-cmd --reload

  • 配置firewalld

systemctl enable firewalld systemctl start firewalld firewall-cmd --get-default-zone firewall-cmd --set-default-zone=public firewall-cmd --permanent --zone=public --list-all firewall-cmd --permanent --zone # 移除源 firewall-cmd --per --remove-sources=ip --zone=work

二、其他规则

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

  • rich-rules 富规则,功能强,表达性语言
  • Direct configuration rules 直接规则,灵活性差, 帮助:man 5 firewalld.direct

1、管理rich规则

rich规则比基本的firewalld语法实现更强的功能,不仅实现允许/拒绝,还可以实现日志syslog和 auditd,也可以实现端口转发,伪装和限制速率。

  • 规则实施顺序:
    • 该区域的端口转发,伪装规则
    • 该区域的日志规则
    • 该区域的允许规则
    • 该区域的拒绝规则
  • 每个匹配的规则生效,所有规则都不匹配,该区域的默认规则生效。

2、rich 语法

rule [source] ##来源 [destination] ###目的 service|port|protocol|icmp-block|masquerade|forward-port [log] [audit] [accept|reject|drop] ##接受/拒绝/放弃

  • man 5 firewalld.richlanguage
  • rich 规则选项

0

选项: family : 制定规则仅应用ipv4数据包 source address: 提供的数据包具有源地址 service: 服务类型

3、rich 规则实现

  • 拒绝从192.168.0.11的所有流量,当address 选项使用source 或 destination时,必须用family= ipv4 |ipv6

firewall-cmd --permanent --zone=public --add-rich-rule='rule family=ipv4 source address=192.168.0.11/32 reject'

  • 限制每分钟只有两个连接到ftp服务

firewall-cmd --add-rich-rule=‘rule service name=ftp limit value=2/m accept’

  • 抛弃esp( IPsec 体系中的一种主要协议)协议的所有数据包

firewall-cmd --permanent --add-rich-rule='rule protocol value=esp drop'

  • 接受所有192.168.1.0/24子网端口5900-5905范围的TCP流量

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'

4、端口的SELinux

主体为进程,客体为端口.

正常情况下,无法随意修改服务的端口,服务有自己的selinux标签的端口,标签不对,启动服务就会失败.

4.1、查看端口selinux标签类型

semanage prot -l 范例: [root@serverb ~]# semanage port -l | grep 80 amanda_port_t tcp 10080-10083 amanda_port_t udp 10080-10082 conntrackd_port_t udp 3780 cyphesis_port_t tcp 6767, 6769, 6780-6799 geneve_port_t tcp 6080 hadoop_namenode_port_t tcp 8020 hplip_port_t tcp 1782, 2207, 2208, 8290, 8292, 9100, 9101, 9102, 9220, 9221, 9222, 9280, 9281, 9282, 9290, 9291, 50000, 50002 http_cache_port_t tcp 8080, 8118, 8123, 10001-10010 http_port_t tcp 80, 81, 443, 488, 8008, 8009, 8443, 9000

4.2、在selinux标签中添加端口

semanage port [port] -a -t [type] -p [tcp/udp] 范例: [root@serverb ~]# semanage port 8800 -a -t http_port_t -p tcp [root@serverb ~]# semanage port -l | grep 8800 http_port_t tcp 8800, 80, 81, 443, 488, 8008, 8009, 8443, 9000

  • 9
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值