【firewalld防火墙】

news2025/1/20 3:57:24

目录

  • 一、firewalld概述
  • 二、firewalld 与 iptables 的区别
    • 1、firewalld 区域的概念
  • 三、firewalld防火墙默认的9个区域
  • 四、Firewalld 网络区域
    • 1、区域介绍
    • 2、firewalld数据处理流程
  • 五、firewalld防火墙的配置方法
    • 1、使用firewall-cmd 命令行工具。
    • 2、使用firewall-config 图形工具。
    • 3、区域管理
    • 4、服务管理
    • 5、端口管理
    • 6、设置地址转换


一、firewalld概述

1、firewalld防火墙是Centos7系统默认的防火墙管理工具,取代了之前的iptables防火墙,也是工作在网络层,属于包过滤防火墙。

2、firewalld和iptables都是用来管理防火墙的工具(属于用户态)来定义防火墙的各种规则功能,内部结构都指向netfilter网络过过滤子系统(属于内核态)来实现包过滤防火墙功能。字号4

3、firewalld提供了支持网络区域所定义的网络链接以及接口安全等级的动态防火墙管理工具。 它支持IPv4、IPv6防火墙设置以及以太网桥(在某些高级服务可能会用到,比如云计算), 并且拥有两种配置模式:运行时配置与永久配置。

二、firewalld 与 iptables 的区别

1.
iptables 主要是基于接口,来设置规则,从而判断网络的安全性。
firewalld 是基于区域,根据不同的区域来设置不同的规则,从而保证网络的安全。与硬件防火墙的设置相类似。

2.
iptables 在 /etc/sysconfig/iptables 中储存配置
firewalld 将配置储存在 /etc/firewalld/(优先加载) 和 /usr/lib/firewalld/(默认的配置文件)中的各种 XML 文件里。

在这里插入图片描述

默认使用的公共规则
在这里插入图片描述

3.
使用 iptables 规则修改后会立即生效
使用 firewalld 却不会再创建任何新的规则仅仅运行规则中的不同之处。因此firewalld 可以在运行时间内,改变设置而不丢失现行连接。

4、iptables 防火墙类型为静态防火墙
firewalld 防火墙类型为动态防火墙

在这里插入图片描述

1、firewalld 区域的概念

firewalld防火墙为了简化管理,将所有网络流量分为多个区域(zone)。然后根据数据包的源IP地址或传入的网络接口等条件将流量传入相应区域。每个区域都定义了自己打开或者关闭的端口和服务列表。

1、规则定义区域
区域与网卡或源地址绑定

区域1  (定义规则,如放通HTTP/TFP/DNS ... ) ——> 网卡 绑定

三、firewalld防火墙默认的9个区域

ls /etc/firewalld/zones   #文件里优先使用 public.xml	区域文件

cd /usr/lib/firewalld/   
#在优先的区域文件里没有找到对应的区域就在这里面找到默认区域
cd zones/      #默认区域配置文件

在这里插入图片描述

firewalld防火墙预定义了9个区域:

命令解释
1、trusted(信任区域)允许所有的传入流量。
2、public(公共区域允许与ssh或dhcpv6-client预定义服务匹配的传入流量,其余均拒绝。是新添加网络接口的默认区域。
3、external(外部区域)允许与 ssh 预定义服务匹配的传入流量,其余均拒绝。 默认将通过此区域转发的IPv4传出流量将进行地址伪装,可用于为路由器启用了伪装功能的外部网络。
4、home(家庭区域)允许与ssh、ipp-client、mdns、samba-client或dhcpv6-client预定义服务匹配的传入流量,其余均拒绝。
5、internal(内部区域)默认值时与home区域相同。
6、work(工作区域)允许与 ssh、ipp-client、dhcpv6-client 预定义服务匹配的传入流量,其余均拒绝。
7、dmz(隔离区域也称为非军事区域)允许与 ssh 预定义服务匹配的传入流量,其余均拒绝。
8、block(限制区域)拒绝所有传入流量。
9、drop(丢弃区域)丢弃所有传入流量,并且不产生包含 ICMP的错误响应。

四、Firewalld 网络区域

1、区域介绍

区域如同进入主机的安全门,每个区域都具有不同限制程度的规则

可以使用一个或多个区域,但是任何一个活跃区域至少需要关联源地址或接口

默认情况下,public区域是默认区域,包含所有接口(网卡)

在这里插入图片描述

2、firewalld数据处理流程

检查数据来源的源地址
1.若源地址关联到特定的区域(即源地址或接口绑定的区域有冲突),则执行该区域所制定的规则。
2.若源地址未关联到特定的区域(即源地址或接口绑定的区域没有冲突),则使用传入网络接口的区域并执行该区域所制定的规则。
3.若网络接口也未关联到特定的区域(即源地址或接口都没有绑定特定的某个区域),则使用默认区域并执行该区域所制定的规则。

五、firewalld防火墙的配置方法

1、使用firewall-cmd 命令行工具。

2、使用firewall-config 图形工具。

3、编写/etc/firewalld/中的配置文件。

1、使用firewall-cmd 命令行工具。

常用的firewall-cmd 命令选项

--get-default-zone :显示当前默认区域

--set-default-zone=<zone> :设置默认区域

--get-active-zones :显示当前正在使用的区域及其对应的网卡接口

--get-zones :显示所有可用的区域

--get-zone-of-interface=<interface> :显示指定接口绑定的区域

--zone=<zone> --add-interface=<interface> :为指定接口绑定区域

--zone=<zone> --change-interface=<interface> :为指定的区域更改绑定的网络接口

--zone=<zone> --remove-interface=<interface> :为指定的区域删除绑定的网络接口

--zone=<zone> --add-source=<source> 	为指定源地址绑定区域

--zone=<zone> --change-source=<source>	为指定的区域更改绑定的源地址

--zone=<zone> --remove-source=<source>	为指定的区域删除绑定的源地址
--list-all-zones :显示所有区域及其规则

[--zone=<zone>] --list-all :显示所有指定区域的所有规则,省略--zone=<zone>时表示仅对默认区域操作

[--zone=<zone>] --list-services :显示指定区域内允许访问的所有服务

[--zone=<zone>] --add-service=<service> :为指定区域设置允许访问的某项服务

[--zone=<zone>] --remove-service=<service> :删除指定区域已设置的允许访问的某项服务


[--zone=<zone>] --list-ports :显示指定区域内允许访问的所有端口号

[--zone=<zone>] --add-port=<portid>[-<portid>]/<protocol> :为指定区域设置允许访问的某个/某段端口号(包括协议名)

[--zone=<zone>] --remove-port=<portid>[-<portid>]/<protocol> :删除指定区域已设置的允许访问的端口号(包括协议名)


[--zone=<zone>] --list-icmp-blocks :显示指定区域内拒绝访问的所有 ICMP 类型

[--zone=<zone>] --add-icmp-block=<icmptype> :为指定区域设置拒绝访问的某项 ICMP 类型

[--zone=<zone>] --remove-icmp-block=<icmptype> :删除指定区域已设置的拒绝访问的某项ICMP类型

firewall-cmd --get-icmptypes :显示所有 ICMP 类型

1、–get-default-zone :显示当前默认区域
2、–get-zone-of-interface= :显示指定接口绑定的区域

在这里插入图片描述

#为指定的区域删除绑定的网络接口

[root@dz666 ~]# firewall-cmd --remove-interface=ens35 --zone=public
success

[root@dz666 ~]# firewall-cmd --get-zone-of-interface=ens35
no zone

1、–zone=<区域> --add-interface= :为指定接口绑定区域

在这里插入图片描述
1、–zone= --change-interface= :为指定的区域更改绑定的网络接口

在这里插入图片描述

1、–zone= --remove-interface= :为指定的区域删除绑定的网络接口

在这里插入图片描述

1、–zone= --change-source= 为指定的区域更改绑定的源地址
2、–zone= --remove-source= 为指定的区域删除绑定的源地址

在这里插入图片描述

1、–list-all-zones :显示所有区域及其规则
在这里插入图片描述

1、[–zone=] --list-ports :显示指定区域内允许访问的所有端口号
2、[–zone=] --add-port=[-]/ :为指定区域设置允许访问的某个/某段端口号(包括协议名)
3、[–zone=] --remove-port=[-]/ :删除指定区域已设置的允许访问的端口号(包括协议名)

在这里插入图片描述

1、[–zone=] --list-ports :显示指定区域内允许访问的所有端口号
2、[–zone=] --add-port=[-]/ :为指定区域设置允许访问的某个/某段端口号(包括协议名)
3、[–zone=] --remove-port=[-]/ :删除指定区域已设置的允许访问的端口号(包括协议名)

在这里插入图片描述

1、firewall-cmd --get-icmptypes :显示所有 ICMP 类型

在这里插入图片描述

1、[–zone=] --list-icmp-blocks :显示指定区域内拒绝访问的所有 ICMP 类型
2、[–zone=] --add-icmp-block= :为指定区域设置拒绝访问的某项 ICMP 类型
3、[–zone=] --remove-icmp-block= :删除指定区域已设置的拒绝访问的某项ICMP类型

在这里插入图片描述

2、使用firewall-config 图形工具。

systemctl start firewalld.service
#进入图形工具时要先打开防火墙

在里面选择要开放哪些协议直接将协议点击选择
在这里插入图片描述

3、区域管理

(1)显示当前系统中的默认区域
firewall-cmd --get-default-zone

(2)显示默认区域的所有规则
firewall-cmd --list-all

(3)显示当前正在使用的区域及其对应的网卡接口
firewall-cmd --get-active-zones

(4)设置默认区域
firewall-cmd --set-default-zone=home
firewall-cmd --get-default-zone

在这里插入图片描述

4、服务管理

(1)查看默认区域内允许访问的所有服务
firewall-cmd --list-service

(2)添加httpd 服务到public 区域
firewall-cmd --add-service=http --zone=public

(3)查看public 区域已配置规则
firewall-cmd --list-all --zone=public

(4)删除public 区域的httpd 服务
firewall-cmd --remove-service=http --zone=public

(5)同时添加httpd、https 服务到默认区域,设置成永久生效
firewall-cmd --add-service=http --add-service=https --permanent
firewall-cmd --reload	#重新加载服务
firewall-cmd --list-all		

设置成永久生效
在这里插入图片描述

显示区域的规则
在这里插入图片描述

5、端口管理

(1)允许TCP的443端口到internal 区域
firewall-cmd --zone=internal --add-port=443/tcp
firewall-cmd --list-all --zone=internal

(2)从internal 区域将TCP的443端口移除
firewall-cmd --zone=internal --remove-port=443/tcp

(3)允许UDP的2048~2050端口到默认区域
firewall-cmd --add-port=2048-2050/udp
firewall-cmd --list-all

6、设置地址转换

(1)设置 SNAT
firewall-cmd --zone=public --direct --passthrough ipv4 -t nat -A POSTROUTING -s 192.168.80.0/24 -j SNAT --to-source 12.0.0.1

(2)设置 DNAT
firewall-cmd --zone=public --direct --passthrough ipv4 -t nat -A PREROUTING -d 12.0.0.1 -p tcp --dport 80 -j DNAT --to-destination 192.168.80.11

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/556169.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【计算机网络基础】章节测试4 网络层

R1与R2是一个自治系统中采用RIP路由协议的两个相邻路由器,R1的路由表如图(a)所示。如果R1收到R2发送的如图(b)所示的(V,D)报文,更新之后的R1的4个路由表项的距离从上到下依次为0、4、4、2,那么图 (b)中a、b、c、d 可能的数据一个是( C )。 A. 1、2、2、1 B. 2、2、3、1…

Java 核心技术 卷I 第2章 Java程序设计环境

第2章 Java程序设计环境 2.1 安装Java开发工具包 2.1.1 下载JDK www.oracle.com/technetwork/java/javase/downloads Java术语 2.1.2 设置JDK 下载JDK之后&#xff0c;需要安装这个开发包并明确要在哪里安装&#xff0c;后面还会需要这个信息. 指/opt/jdk1.8.0_31/bin或c…

从零开始Vue3+Element Plus后台管理系统(十四)——PDF预览和打印

其实我常常会纠结今天要写什么内容。 因为希望能够保持每日更新&#xff0c;所以要写的内容不能太难——最好是半天可以搞出demo并且输出文章&#xff0c;所以很多东西浅尝辄止&#xff0c;并没有深入研究&#xff0c;还写出了一些bug &#x1f41b; 今天又浅浅的研究了下在V…

这还只是阿里20K+测试岗面试题,看的我冷汗直流.....

朋友入职已经两周了&#xff0c;整体工作环境还是非常满意的&#xff01;所以这次特意抽空给我写出了这份面试题&#xff0c;而我把它分享给伙伴们&#xff0c;面试&入职的经验&#xff01; 大概是在3月中的时候他告诉我投递了阿里巴巴并且简历已通过&#xff0c;3月23经过…

python类型注释

目录 为什么需要类型注解 什么是类型注解 联合注解 使用注解时的注意点 为什么需要类型注解 看下图&#xff0c;很精炼&#xff1b; 什么是类型注解 Python类型注释是指在变量、函数参数、返回值等位置添加类型信息的一种语法&#xff0c;其目的是提高代码的可读性和可维护…

monkey测试方法及命令

1、查询测试包信息 # 查看已连接设备 adb devices # 带uuid查询包含test的第三方apk包 adb -s W21112003057 shell pm list package -3 | grep test # 清空logcat adb -s W21112003057 logcat -c # 启动app&#xff0c;通过日志查看安装包信息 adb -s W21112003057 logcat…

史上最全!全领域网络安全拓扑图(118页)

大家好&#xff0c;我是老杨。 前几天发了一篇OSPF的文章&#xff0c;助理发到群里和大家讨论。 好几个小友表示&#xff0c;绘制拓扑的才是最高境界&#xff0c;并且想看些拓扑图案例。 其实拓扑图案例老杨也分享过不少了。 可以看看这些往期文章&#xff0c;《超干货&…

【送书福利-第四期】从程序员到架构师:大数据量、缓存、高并发、微服务、多团队协同等核心场景实战书籍

大家好&#xff0c;我是洲洲&#xff0c;欢迎关注&#xff0c;一个爱听周杰伦的程序员。关注公众号【程序员洲洲】即可获得10G学习资料、面试笔记、大厂独家学习体系路线等…还可以加入技术交流群欢迎大家在CSDN后台私信我&#xff01; 送书福利-第四期 一、前言二、书籍介绍抽…

KY111 日期差值

1.题目&#xff1a; 2.分析&#xff1a; 1. 分别求出每一个日期与0000年0月1日距离的天数 2. 两个距离天数相减即可得到两个日期相差的天数 3.我的代码&#xff1a; #include <iostream> using namespace std;class Date { public:Date(int year 1, int month 1, …

java学习:字面量,基本语句

一、字面量 1.字面量的类型 Java字面量的类型其实跟 c 的有点相似&#xff0c;有一点不一样的就是&#xff0c;Java有个null类型&#xff0c;注意这个没有大写 2.特殊字面量 \t 是制表符&#xff0c;它的作用就是补齐一个字符串到8位&#xff0c;这样就会使输出结果变得美观…

【arxiv】关于 SAM 的论文扫读(一)

文章目录 一、阴影检测二、弱监督下的隐蔽物体分割&#xff1a;基于SAM的伪标签和多尺度特征分组三、Instruct2Act&#xff1a;利用大型语言模型将多模态指令映射到机器人动作四、OR-NeRF: Object Removing from 3D Scenes Guided by Multiview Segmentation with Neural Radia…

Lucene(5):索引维护

1 需求 管理人员通过电商系统更改图书信息&#xff0c;这时更新的是关系数据库&#xff0c;如果使用lucene搜索图书信息&#xff0c;需要在数据库表book信息变化时及时更新lucene索引库。 2 添加索引 调用 indexWriter.addDocument&#xff08;doc&#xff09;添加索引。 参…

[Data structure]环形链表

⭐作者介绍&#xff1a;大二本科网络工程专业在读&#xff0c;持续学习Java&#xff0c;努力输出优质文章 ⭐作者主页&#xff1a;逐梦苍穹 ⭐所属专栏&#xff1a;数据结构。数据结构专栏主要是在讲解原理的基础上拿Java实现 ⭐如果觉得文章写的不错&#xff0c;欢迎点个关注一…

文心一言 VS chatgpt (21)-- h264编码一帧数据的流程是怎样的?

h264编码一帧数据的流程是怎样的&#xff1f; 文心一言&#xff1a; H.264编码将一帧数据分成多个块&#xff0c;其中每个块可以单独进行编码。编码的过程包括预测、变换和量化等步骤。 具体流程如下&#xff1a; 1.帧内预测&#xff1a;对一帧视频进行编码&#xff0c;首先…

什么是网络编程

目录 一、什么是网络编程&#xff1f; 二、协议 1.用户数据报协议(User Datagram Protocol) 2.TCP协议 TCP三次握手过程 三、实例 1.UDP通信程序 实现步骤 TCP接收数据 四、TCP协议和UDP协议的区别和联系 一、什么是网络编程&#xff1f; 1.在网络通信协议下&#xf…

Qt编程基础 | 常用控件 | 组合框

一、组合框 1.1、定义 QComboBox提供了一种向用户呈现选项列表的方式&#xff0c;以占用最少的屏幕空间。 组合框是一个显示当前项目的选择小部件&#xff0c;可以弹出可选择项目的列表。 组合框可以是可编辑的&#xff0c;允许用户修改列表中的每个项目。 QComboBox 除了显示…

四、IOC容器(3)

一、IOC操作Bean管理&#xff08;外部属性文件&#xff09; 1.直接配置数据库信息 配置德鲁伊连接池引入德鲁伊连接池依赖jar包 <!--配置连接池--> <bean id"dataSource" class"com.alibaba.druid.pool.DruidDataSource"><property name&…

深度学习神经网络学习笔记-多模态方向-10-Neural Voice Cloning with a Few Samples

摘要 语音克隆是个性化语音接口非常需要的功能。我们介绍了一个神经语音克隆系统&#xff0c;该系统仅从少数音频样本中学习合成一个人的声音。我们研究了两种方法:说话人适应和说话人编码。说话人自适应是基于多说话人生成模型的微调。说话人编码是基于训练一个单独的模型来直…

GitLab CI/CD

CI/CD 简介 CI/CD 简单来说就是可以自动化编译、测试、打包我们的代码。 GitLab CICD的使用 首先需要安装gitlab-runner。 在GitLab 中&#xff0c;runners 是运行 CI/CD 作业的代理。我们的对代码的作业都是在runner上去执行的。我们可以在本地、服务器、等任意一个联网设…

chatgpt赋能Python-python_chat

Python Chat: 使用Python编程语言打造聊天应用 在当今数字化的时代&#xff0c;人们需要有一种跨越地域和时间的即时通讯方式&#xff0c;这就是聊天应用的用武之地。Python编程语言因其易读易写的特性&#xff0c;和广泛的社区支持成为了许多开发者的首选。Python Chat是一款…