您当前的位置:首页 > 电脑百科 > 安全防护 > 软件工具

浅谈,linux防火墙,Firewalld服务

时间:2019-12-26 13:41:15  来源:  作者:

Firewalld服务简介

▶1 基本介绍

firewalld是centos 7.0新推出的管理netfilter的工具

firewalld是配置和监控防火墙规则的系统守护进程,可以实现iptables,ip6tables,ebtables的功能

firewalld服务由firewalld包提供

浅谈,linux防火墙,Firewalld服务

 

​▶2 ZONE:区域

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

归入zone顺序:

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

纳为网络接口所属zone

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

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

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预定义服务之外的其它所有传入流量,新加的网卡默认属于publiczone

external 拒绝除和传出流量相关的,以及ssh预定义服务之外的其它所有传入流量,属于external zone的传出ipv4流量的源地址将被伪装为传出网卡的地址。

dmz 拒绝除和传出流量相关的,以及ssh预定义服务之外的其它所有传入流量

block 拒绝除和传出流量相关的所有传入流量

drop 拒绝除和传出流量相关的所有传入流量(甚至不以ICMP错误进行回应)

预定义服务,下表只是列出几个例子,Firewalld预定义的服务太多了

服务名称 配置

ssh Local SSH server. Traffic to 22/tcp

dhcpv6-client Local DHCPv6 client. Traffic to 546/udp on the fe80::/64 IPv6 network

ipp-client Local IPP printing. Traffic to 631/udp.

samba-client Local windows file and print sharing client. Traffic to 137/udp and 138/udp.

mDNS Multicast DNS (mDNS) local-link name resolution. Traffic to 5353/udp to the

224.0.0.251 (IPv4) or ff02::fb (IPv6) multicast addresses.

浅谈,linux防火墙,Firewalld服务

 

​2️⃣ Firewalld服务配置

▶1 Firewalld预定义服务配置

firewall-cmd --get-services 查看预定义服务列表

/usr/lib/firewalld/services/*.xml 预定义服务的配置

▶2 Firewalld 三种配置方法

firewall-config (firewall-config包)图形工具

firewall-cmd (firewalld包)命令行工具

/etc/firewalld 配置文件,一般不建议

▶3 Firewall-cmd 命令选项

格式: Usage: firewall-cmd [OPTIONS...]

常见选项参数

--get-zones 列出所有可用区域

--get-default-zone 查询默认区域

--set-default-zone= 设置默认区域

--get-active-zones 列出当前正使用的区域

--add-source=[--zone=] 添加源地址的流量到指定区域,如果无--zone= 选项,使用默认区域

--remove-source= [--zone=] 从指定区域删除源地址的流量,如无--zone= 选项,使用默认区域

--add-interface=[--zone=] 添加来自于指定接口的流量到特定区域,如果无--zone= 选项,使用默认区

--change-interface=[--zone=] 改变指定接口至新的区域,如果无--zone= 选项,使用默认区域

--add-service= [--zone=] 允许服务的流量通过,如果无--zone= 选项,使用默认区域

--add-port=<PORT/PROTOCOL>[--zone=] 允许指定端口和协议的流量,如果无--zone= 选项,使用默

认区域

--remove-service= [--zone=] 从区域中删除指定服务,禁止该服务流量,如果无--zone= 选项,使用默

认区域

--remove-port=<PORT/PROTOCOL>[--zone=] 从区域中删除指定端口和协议,禁止该端口的流量,如

果无--zone= 选项,使用默认区域

--reload 删除当前运行时配置,应用加载永久配置

--list-services 查看开放的服务

--list-ports 查看开放的端口

--list-all [--zone=] 列出指定区域的所有配置信息,包括接口,源地址,端口,服务等,如果无--zone=

选项,使用默认区域

  • 示例

/ 查看默认zone

[root@Centos7 ~]# firewall-cmd --get-default-zone

public

/ 设置默认zone问dmz

[root@Centos7 ~]# firewall-cmd --set-default-zone=dmz

success

[root@Centos7 ~]# firewall-cmd --get-default-zone

dmz

/ 在internal zone中增加源地址192.168.0.0/24的永久规则

[root@Centos7 ~]# firewall-cmd --permanent --zone=internal --add-source=192.168.0.0/24

success

/ 在internal zone中增加协议MySQL的永久规则

[root@Centos7 ~]# firewall-cmd --permanent --zone=internal --add-service=mysql

success

/ 加载新增规则生效

[root@Centos7 ~]# firewall-cmd --reload

success

/ 查看前面两个设置的规则

[root@Centos7 ~]# firewall-cmd --list-all --zone=internal

internal (active)

target: default

icmp-block-inversion: no

interfaces:

sources: 192.168.0.0/24

services: dhcpv6-client mdns mysql samba-client ssh

ports:

protocols:

masquerade: no

forward-ports:

source-ports:

icmp-blocks:

rich rules:

3️⃣ rich规则

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

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

direct configuration rules:直接规则,灵活性差

帮助:man 5 firewalld.direct

浅谈,linux防火墙,Firewalld服务

 

​1 rich规则简介

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

rich语法

rule

[source]

[destination]

service|port|protocol|icmp-block|masquerade|forward-port

[log]

[audit]

[accept|reject|drop]

man 5 firewalld.richlanguage

▶2 rich规则实施顺序:

该区域的端口转发,伪装规则

该区域的日志规则

该区域的允许规则

该区域的拒绝规则

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

▶3 rich规则选项

--add-rich-rule='<RULE>'

添加rich规则至指定zone,若未指明zone则为默认zone

--remove-rich-rule='<RULE>'

从指定zone删除rich规则,若未指明zone则为默认zone

--query-rich-rule='<RULE>'

查询指定zone中是否有RULE规则,若未指定zone则为默认zone

返回值0代表存在,返回值1代表不存在

浅谈,linux防火墙,Firewalld服务

 

​--list-rich-rules

列出指定zone的所有rich规则,若未指定zone则为默认zone

示例:

/ 拒绝从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服务,下面命令省略指定zone区域,所以是给默认zone添加规则

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

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

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

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

firewall-cmd --permanent --zone=public --add-rich-rule='rule family=ipv4 source address=192.168.1.0/24 port port=5900-5905 protocol=tcp accept'

/ 查看所有添加的rich-rules

[root@Centos7 ~]# firewall-cmd --list-rich-rules

You're performing an operation over default zone ('public'),

but your connections/interfaces are in zone 'internal' (see --get-active-zones)

You most likely need to use --zone=internal option.

rule service name="ftp" accept limit value="2/m"

rule protocol value="esp" drop

▶4 rich日志规则

log [prefix="<PREFIX TEXT>" [level=<LOGLEVEL>] [limit value="<RATE/DURATION>"]

<LOGLEVEL>

可以是emerg, alert, crit, error, warning, notice, info, debug

浅谈,linux防火墙,Firewalld服务

 

​<DURATION>

s:秒,m:分钟,h:小时,d:天

audit [limit value="<RATE/DURATION>"]

示例

#接受ssh新连接,记录日志到syslog的notice级别,每分钟最多三条信息

firewall-cmd --permanent --zone=work --add-rich-rule='rule service name="ssh"

log prefix="ssh " level="notice" limit value="3/m" accept

#从2001:db8::/64子网的DNS连接在5分钟内被拒绝,并记录到日志到audit,每小时最大记录一条信息

firewall-cmd --add-rich-rule='rule family=ipv6 source address="2001:db8::/64"

service name="dns" audit limit value="1/h" reject' --timeout=300

firewall-cmd --permanent --add-rich-rule='rule family=ipv4 source

address=172.25.X.10/32 service name="http" log level=notice prefix="NEW HTTP " limit value="3/s" accept'

firewall-cmd --reload

tail -f /var/log/messages

curl http://serverX.example.com

▶5 伪造和端口转发

  • NAT网络地址转换,firewalld支持伪造和端口转发两种NAT方式
  • 伪造NAT
  • 格式:firewall-cmd --zone=<ZONE> --add-masquerade

firewall-cmd --permanent --zone=<ZONE> --add-masquerade

firewall-cmd --query-masquerade #检查是否允许伪装

firewall-cmd --add-masquerade #允许防火墙伪装IP

firewall-cmd --remove-masquerade #禁止防火墙伪装IP

示例:将来自192.168.0.0/24网段的IP伪造为外网动态IP

firewall-cmd --add-rich-rule='rule family=ipv4 source address=192.168.0.0/24 masquerade'

端口转发:将发往本机的特定端口的流量转发到本机或不同机器的另一个端口。通常要配合地址伪造才能实现

格式:firewall-cmd --zone=<ZONE> --add-forward-port=port=<PORTNUMBER>:proto=<PROTOCOL>[:toport=<PORTNUMBER>][:toaddr=<IPADDR>]

说明:toport=和toaddr=至少要指定一个

示例

转发传入的连接9527/TCP,到防火墙的80/TCP到public zone 的192.168.0.254

firewall-cmd --add-masquerade 启用伪装

firewall-cmd --zone=public --add-forwardport=

port=9527:proto=tcp:toport=80:toaddr=192.168.0.254

rich规则语法:

  • 格式:forward-port port=<PORTNUM> protocol=tcp|udp [to-port=<PORTNUM>] [to-addr=<ADDRESS>]
  • 示例

/ 转发从192.168.0.0/24来的,发往80/TCP的流量到防火墙的端口8080/TCP

firewall-cmd --zone=work --add-rich-rule='rule family=ipv4 source

address=192.168.0.0/24 forward-port port=80 protocol=tcp to-port=8080'

 

山东掌趣网络科技



Tags:Firewalld   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
如果你运行的服务器有面向公众的 SSH 访问,你可能遇到过恶意登录尝试。本文介绍了如何使用两个实用程序来防止入侵者进入我们的系统。&bull; 来源:linux.cn &bull; 作者:Hobbe...【详细内容】
2020-07-15  Tags: Firewalld  点击:(40)  评论:(0)  加入收藏
iptables是Linux内核自带的防火墙,功能强大,但是因为其配置比较复杂,往往会让新手望而生畏。想当年,我在学习iptbles的时候就花费了不少精力,全凭自己零碎地摸索积累,着实走了不少...【详细内容】
2020-06-16  Tags: Firewalld  点击:(140)  评论:(0)  加入收藏
FirewallD 是由红帽发起的提供了支持网络/防火墙区域定义网络链接以及接口安全等级的动态防火墙管理工具。 作者:王震华, 朱丽璇FirewallD 是由红帽发起的提供了支持网络/防...【详细内容】
2020-05-22  Tags: Firewalld  点击:(66)  评论:(0)  加入收藏
centos的防火墙iptables很强大,但是centos7的防火墙升级为Firewalld,命令也是大不一样。但是iptables并未被替换,而作为Firewalld的底层存在着。防火墙无论是在windows还是在li...【详细内容】
2020-05-07  Tags: Firewalld  点击:(83)  评论:(0)  加入收藏
Firewalld服务简介▶1 基本介绍firewalld是CentOS 7.0新推出的管理netfilter的工具firewalld是配置和监控防火墙规则的系统守护进程,可以实现iptables,ip6tables,ebtables的...【详细内容】
2019-12-26  Tags: Firewalld  点击:(87)  评论:(0)  加入收藏
一、Linux防火墙的基础Linux的防火墙体系主要工作在网络层,针对TCP/IP数据包实时过滤和限制,属于典型的包过滤防火墙(或称为网络层防火墙)。Linux系统的防火墙体系基于内核共存:f...【详细内容】
2019-11-28  Tags: Firewalld  点击:(107)  评论:(0)  加入收藏
1. 前言本文将会详细介绍CentOS 7 firewalld的来由、功能、常用命令、常用的案例及使用方法。希望能帮助读者全面了解firewalld,并能正确配置和使用它。 centos7 firewalld2....【详细内容】
2019-09-16  Tags: Firewalld  点击:(180)  评论:(0)  加入收藏
▌简易百科推荐
已经观察到一种新的基于JavaScript的远程访问木马(RAT)利用社会工程学传播,采用隐蔽的"无文件"技术作为其逃避检测和分析的方法。该恶意软件由Prevalyion的对抗性反情报团队(PA...【详细内容】
2021-12-17  网安老葫    Tags:恶意软件   点击:(13)  评论:(0)  加入收藏
关于windows Defender防病毒的问题升级win10后,我们会经常遇到打开或下载文件时弹出提示框提示你下载的文件是病毒之类,直接给你删除。你好不容易找了个激活工具,你刚打开发现...【详细内容】
2021-11-08  IT小哥吧    Tags:defender   点击:(47)  评论:(0)  加入收藏
喽!大家好,我是小易,欢迎来到我的知识分享站!今天给大家分享5个杀毒神器,让你的电脑干干净净,建议收藏起来哟! 1、Windows Defender随着Win10系统的更新已经日趋完善,它可以很好的解...【详细内容】
2021-11-08  知识与技能    Tags:流氓软件   点击:(74)  评论:(0)  加入收藏
介绍其实Iptables服务不是真正的防火墙,只是用来定义防火墙规则功能的"防火墙管理工具",将定义好的规则交由内核中的netfilter即网络过滤器来读取,从而真正实现防火墙功能。fil...【详细内容】
2021-10-18  互联网IT技术全栈    Tags:   点击:(52)  评论:(0)  加入收藏
什么是Nessus?Nessus 是目前全世界最多人使用的系统漏洞扫描与分析软件。总共有超过75,000个机构使用Nessus 作为扫描该机构电脑系统的软件步骤如下:查看当前kali系统内核版本...【详细内容】
2021-09-09  TestGO    Tags:Nessus   点击:(112)  评论:(0)  加入收藏
http 头部信息http头部信息经常包含着主机服务的一些版本信息,经常使用的字段信息有:Server, X-Powered-By, X-AspNet-Version工具可采用curl进行curl --location --head $URL...【详细内容】
2021-08-19  80后IT老民工    Tags:渗透   点击:(227)  评论:(0)  加入收藏
一、杀软常见的三种方式二、免杀的三种常用方式三、利用工具实现免杀1、veil工具基础实现免杀+进阶2、venom免杀3、利用kali自带的shellter进行免杀4、利用avet实现免杀四、...【详细内容】
2021-08-18  白帽hacker淬炼    Tags:免杀   点击:(82)  评论:(0)  加入收藏
关于工具现有工具现在,现成的污点分析工具已经有很多了。其中,我最感兴趣的是Triton和bincat,因为两者已经相当成熟。然而,我们却无法使用这两种工具,因为它们不支持目标设备所...【详细内容】
2021-08-12  Hbo涵    Tags:安全漏洞   点击:(94)  评论:(0)  加入收藏
从实现原理上分,防火墙的技术包括四大类:网络级防火墙、应用级网关、电路级网关和规则检查防火墙。1、网络级防火墙一般是基于源地址和目的地址、应用、协议以及每个IP包的端...【详细内容】
2021-07-20  趣谈文化  搜狐号  Tags:防火墙   点击:(225)  评论:(0)  加入收藏
一、VMware部分1、Vmware简介虚拟机就是一个用来模拟真实的物理机环境的一个软件,可以在虚拟机中安装不同版本的操作系统。就是一个把下载好的ISO安装在物理机操作系统的一个...【详细内容】
2021-07-12  Kali与编程  公众号  Tags:Kali Linux   点击:(113)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条