Linux系统防火墙Firewalld
目录
Firewalld概述
Firewalld和iptables的区别
Firewalld网络区域
区域介绍与概念
9个预定义区域
Firewalld数据处理流程
firewalld检查数据包的源地址的规则
Firewalld防火墙的配置方式
常用的firewall-cmd命令选项
服务管理
端口管理
Firewalld概述
- Firewalld防火墙是Centos7系统默认的防火墙管理工具,取代了之前的iptables防火墙
- Firewalld也是工作在网络层,属于包过滤防火墙
- firewalld 和 iptables 都是用来管理防火墙的工具(属于用户态)来定义防火墙的各种规则功能,内部结构都指向 netfilter 网络过滤子系统(属于内核态)来实现包过滤防火墙功能。
- firewalld 提供了支持网络区域所定义的网络连接以及接口安全等级的动态防火墙管理工具。它支持IPv4、IPv6防火墙设置以及以太网桥(在某些高级服务可能会用到,比如云计算),并且拥有两种配置模式:运行时配置与永久配置。
Firewalld和iptables的区别
Firewalld | iptables |
---|---|
是基于区域,根据不同的区域来设置不同的规则,从而保证网络的安全。与硬件防火墙的设置相类似。 | 主要是基于接口,来设置规则,从而判断网络的安全性。 |
firewalld 将配置储存在/etc/ firewalld/ ( 优先加载)和/usr/lib/ firewalld/ ( 默认的配置文件)中的各种XML文件里。 | iptables 在 /etc/sysconfig/iptables 中储存配置。 |
使用firewalld 却不会再创建任何新的规则,仅仅运行规则中的不同之处。因此firewalld可以在运行时间内,改变设置而不丢失现行连接。 | 使用iptables每一个单独更改意味着清除所有旧有的规则和从/etc/sysconfig/iptables里读取所有新的规则。 |
firewalld 防火墙类型为动态防火墙 | iptables 防火墙类型为静态防火墙 |
Firewalld网络区域
区域介绍与概念
- 区域如同进入主机的安全门,每个区域都具有不同限制程度的规则
- 可以使用一个或多个区域,但是任何一个活跃区域至少需要关联源地址或接口
- 默认情况下,public区域是默认区域,包含所有接口(网卡)
- firewalld防火墙为了简化管理,将所有网络流量分为多个区域(zone) 。然后根据数据包的源IP地址或传入的网络接口等条件将流量传入相应区域。每个区域都定义了自己打开或者关闭的端口和服务列表。
- 最终一个区域的安全程度是取决于管理员在此区域中设置的规则。
9个预定义区域
- rusted (信任区域)
- 允许所有的传入流量。
- public(公共区域)
- 允许与ssh或dhcpv6-client预定义服务匹配的传入流量,其余均拒绝。是新添加网络接口的默认区域。
- external (外部区域)
- 允许与ssh预定义服务匹配的传入流量,其余均拒绝。
- 默认将通过此区域转发的IPv4传出流量将进行地址伪装,可用于为路由器启用了伪装功能的外部网络。
- home (家庭区域)
- 允许与ssh、ipp-client、 mdns、 samba-client或dhcpv6-client预定义服务匹配的传入流量,其余均拒绝
- internal (内部区域)
- 默认值时与home区域相同。
- work (工作区域)
- 允许与ssh、ipp-client、 dhcpv6-client 预定义服务匹配的传入流量,其余均拒绝。
- dmz(隔离区域也称为非军事区域)
- 允许与ssh预定义服务匹配的传入流量,其余均拒绝。
- block (限制区域)
- 拒绝所有传入流量。
- drop (丢弃区域)
- 丢弃所有传入流量,并且不产生包含ICMP的错误响应。
Firewalld数据处理流程
- firewalld对于进入系统的数据包,会根据数据包的源IP地址或传入的网络接口等条件,将数据流量转入相应区域的防火墙规则。对应进入系统的数据包,首先检查的就是其源地址。
firewalld检查数据包的源地址的规则
- 若源地址关联到特定的区域(即源地址或接口绑定的区域有冲突),则执行该区域所制定的规则。
- 若源地址未关联到特定的区域(即源地址或接口绑定的区域没有冲突),则使用传入网络接口的区域并执行该区域所制定的规则。
- 若网络接口也未关联到特定特定的区域(即源地址或接口都没有绑定特定的某个区域),则使用默认区域并执行该区域所制定的规则。
Firewalld防火墙的配置方式
- 使用firewall-cmd 命令行工具
- 使用firewall-config 图形工具
- 编写/etc/firewalld/中的配置文件
常用的firewall-cmd命令选项
[root@localhost /]# systemctl start firewalld.service
【启动firewalld防火墙】
[root@localhost /]# firewall-cmd --get-zones
block dmz drop external home internal public trusted work
【显示所有的可用区域】
[root@localhost /]# firewall-cmd --get-default-zone
public
【显示当前默认区域】
[root@localhost /]# firewall-cmd --set-default-zone=home
success
【设置默认区域】
[root@localhost /]# firewall-cmd --get-active-zones
home
interfaces: ens33
【显示当前正在使用的区域及其对应的网卡接口】
[root@localhost /]# firewall-cmd --zone=trusted --add-interface=ens33
【为指定接口绑定区域】
The interface is under control of NetworkManager, setting zone to 'trusted'.
success
[root@localhost /]# firewall-cmd --get-zone-of-interface=ens33
trusted
【显示指定接口绑定的区域】
[root@localhost /]# firewall-cmd --remove-interface=ens33 --zone=trusted
The interface is under control of NetworkManager, setting zone to default.
success
【为指定区域删除绑定的网络接口】
[root@localhost /]# firewall-cmd --zone=trusted --change--interface=ens36
【为指定的区域更改绑定的网络接口】
[root@localhost /]# firewall-cmd --add-source=111.111.111.111 --zone=home
success
【为指定源地址绑定区域】
[root@localhost /]# firewall-cmd --list-all
【显示默认区域的其规则】
home (active)
target: default
icmp-block-inversion: no
interfaces: ens33
sources: 111.111.111.111
services: ssh mdns samba-client dhcpv6-client
ports:
protocols:
masquerade: no
forward-ports:
source-ports:
icmp-blocks:
rich rules:
[root@localhost /]# firewall-cmd --get-zone-of-source=111.111.111.111
home
【显示指定源地址绑定的区域】
[root@localhost /]# firewall-cmd --zone=home --remove-source=111.111.111.111
success
【删除指定区域绑定的源地址】
[root@localhost /]# firewall-cmd --zone=home --change-source=2.2.2.2
success
【更改指定区域绑定的源地址,更改前需先删除】
[root@localhost /]# firewall-cmd --list-all
home (active)
target: default
icmp-block-inversion: no
interfaces: ens33
sources: 2.2.2.2
services: ssh mdns samba-client dhcpv6-client
ports:
protocols:
masquerade: no
forward-ports:
source-ports:
icmp-blocks:
rich rules:
[root@localhost /]# firewall-cmd --list-all-zones
【显示所有区域及其规则】
[root@localhost /]# firewall-cmd --zone=dmz --list-all
【显示指定区域的所有规则】[root@localhost /]# firewall-cmd --get-icmptypes
address-unreachable bad-header communication-prohibited destination-unreachable echo-reply echo-request fragmentation-needed host-precedence-violation host-prohibited host-redirect host-unknown host-unreachable ip-header-bad neighbour-advertisement neighbour-solicitation network-prohibited network-redirect network-unknown network-unreachable no-route packet-too-big parameter-problem port-unreachable precedence-cutoff protocol-unreachable redirect required-option-missing router-advertisement router-solicitation source-quench source-route-failed time-exceeded timestamp-reply timestamp-request tos-host-redirect tos-host-unreachable tos-network-redirect tos-network-unreachable ttl-zero-during-reassembly ttl-zero-during-transit unknown-header-type unknown-option
【显示所有 ICMP 类型】
[root@localhost /]# firewall-cmd --zone=home --add-icmp-block=packet-too-big
success
【为指定区域设置拒绝访问的某项 ICMP 类型】
[root@localhost /]# firewall-cmd --zone=home --list-icmp-blocks
packet-too-big
【显示指定区域内拒绝访问的所有 ICMP 类型】
[root@localhost /]# firewall-cmd --zone=home --remove-icmp-block=packet-too-big
success
【删除指定区域已设置的拒绝访问的某项ICMP类型】
服务管理
[root@localhost /]# firewall-cmd --zone=home --list-services
ssh mdns samba-client dhcpv6-client
【显示指定区域内允许访问的所有服务】
[root@localhost /]# firewall-cmd --zone=home --add-service=http
success
【为指定区域设置允许访问的某项服务】
[root@localhost /]# firewall-cmd --zone=home --remove-service=mdns
success
【删除指定区域已设置的允许访问的某项服务】
[root@localhost /]# firewall-cmd --zone=home --list-services
ssh samba-client dhcpv6-client http
[root@localhost /]# firewall-cmd --add-service=ftp --add-service=http --permanent
success
[root@localhost /]# firewall-cmd --add-service={ftp,dhcp,http} --zone=internal
success
【添加ftp,dhcp,http服务到默认区域,并设置成永久生效】
[root@localhost /]# firewall-cmd --reload
success
【重新加载firewalld服务】
[root@localhost /]# firewall-cmd --list-all
trusted (active)
target: ACCEPT
icmp-block-inversion: no
interfaces: ens33
sources:
services: dhcp ftp http
ports:
protocols:
masquerade: no
forward-ports:
source-ports:
icmp-blocks:
rich rules:
【--permanent选项表示设置成永久生效,在使用时需要重启启动firewalld服务或者执行firewall-cmd --reload命令重新加载防火墙规则,才会生效】
【若不带--permanent选项,则用于设置运行时规则,但是这些规则会在系统或firewalld服务重启、停止时失效】
[root@localhost /]# firewall-cmd --runtime-to-permanent
端口管理
【允许tcp的9000端口到home区域】
[root@localhost /]# firewall-cmd --zone=home --add-port=9000/tcp
success
【允许udp的9000-9888端口到默认区域】
[root@localhost /]# firewall-cmd --add-port=9000-9888/udp
success
【为指定区域设置允许访问的某个/某段端口号(包括协议名)】
[root@localhost /]# firewall-cmd --list-all
trusted (active)
target: ACCEPT
icmp-block-inversion: no
interfaces: ens33
sources:
services: dhcp tftp ftp http
ports: 9000-9888/udp
protocols:
masquerade: no
forward-ports:
source-ports:
icmp-blocks:
rich rules:[root@localhost /]# firewall-cmd --zone=home --remove-port=9000/tcp
success
【把home区TCP的9000端口移除】
相关文章:

Linux系统防火墙Firewalld
目录 Firewalld概述 Firewalld和iptables的区别 Firewalld网络区域 区域介绍与概念 9个预定义区域 Firewalld数据处理流程 firewalld检查数据包的源地址的规则 Firewalld防火墙的配置方式 常用的firewall-cmd命令选项 服务管理 端口管理 Firewalld概述 Firewalld防火…...

STM3232 GPIO的配置寄存器(为了移植IIC)
参考 https://blog.csdn.net/qq_45539458/article/details/129481019 https://blog.csdn.net/weixin_43314829/article/details/125573448?spm1001.2014.3001.5502 https://blog.csdn.net/m0_71548440/article/details/125894236?spm1001.2014.3001.5502 正点原子mini板 stm…...

K8s的详细介绍
1.编写yaml文件的方式 2.yaml里面的内容介绍 Pod实现机制:(1)共享网络(2)共享存储 共享网络:通过Pause容器,把其他业务容器加入到Pause容器里面,让所有业务容器在同一个名称空间中,…...

JavaWeb(8)——前端综合案例2(节流和防抖)
目录 一、节流和防抖概念 🚀 二、实例演示 💘 三、需要注意的 📡 一、节流和防抖概念 🚀 二、实例演示 💘 Lodash 简介 | Lodash中文文档 | Lodash中文网 (lodashjs.com) <!DOCTYPE html> <html lang&q…...

Spring优雅的在事务提交/回滚前后插入业务逻辑
业务背景 业务那边想要统计下我们这边每天注册商户成功和失败的数量,你看看怎么给他弄下这个功能 功能实现 TransactionSynchronizationManager.registerSynchronization,发现这是spring事务提供的注册回调接口的方法。 在事务注解方法中,…...

day48-ajax+SSM分页
AjaxSSM分页 非分页版controller及html: 分页模糊查询controller: Postman测试(无网页): 分页网页: 分页网页中添加模糊查询: 分页网页中实现添加功能: (1&am…...

如何在本地环境使用 CodeQL 扫描出代码中的安全漏洞?
CodeQL 是什么? CodeQL 是用于自动执行安全检查的分析引擎。在 CodeQL 中,代码被视为数据。 安全漏洞、bug 和其他错误被建模为可针对从代码中提取的数据库执行的查询。可以运行由 Github 研究人员和社区参与者编写的标准 CodeQL 查询,也可以…...

关于领导要求logback日志时间格式要求为“年-月-日 时:分:秒,毫秒”
今天接到领导邮件要求整改系统输出日志规范,有一条要求调整输出日志时间格式为标题所述格式,例:2022-02-21 14:13:32,489 项目目前logback.xml里的配置是这样: <pattern>%d{yyyyMMdd hh:mm:ss} [%p][%c][%M][%L]-> %m%…...

软件测试--一些生命周期
目录 1.需求生命周期 2.开发生命周期 3.测试生命周期 4.缺陷声生命周期 1.需求生命周期 需求生命周期是指在软件测试过程中,需求从提出到最终完成的整个过程。它涵盖了需求的识别、分析、定义、验证和管理等阶段。 需求识别:在此阶段,项目…...

Mr. Cappuccino的第57杯咖啡——简单手写Mybatis大致原理
简单手写Mybatis大致原理 大致原理项目结构项目代码代码测试 大致原理 底层基于JDK动态代理技术实现 项目结构 项目代码 pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns…...

机房环境、动力、网络、安防,帮您提高运维效率,确保机房安全
机房作为单位的核心部门,由计算机、服务器、网络设备、存储设备等关键设备组成,智能化计算机机房这个概念在各个领域中,已经占据了很重要的地位,伴随着国家大力倡导的,东数西算,数字经济、云计算、5G大数据…...

大数据课程E1——Flume的概述
文章作者邮箱:yugongshiye@sina.cn 地址:广东惠州 ▲ 本章节目的 ⚪ 了解Ganglia的概念; ⚪ 了解Ganglia的拓扑结构和执行流程; ⚪ 掌握Ganglia的安装操作; 一、简介 1. 概述 1. Flume原本是由Cloudera公司开发的后来贡献给了Apache的一套分布式的、可…...

01.Redis实现发送验证码
学习目标: 提示:学习如何利用Redis来实现发送验证码功能 学习产出: 1. 准备pom环境 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId><…...

Vue中对组件的调用
在Vue中,你可以在一个页面中调用其他组件,以实现组件的复用和组合效果。以下是在Vue中实现调用页面组件的几种常见方法之一: 1.使用Vue的组件标签: 你可以在Vue的模板中使用已注册的组件标签,以调用和渲染其他组件。首…...

SpringCloud Gateway获取请求响应body大小
前提 本文获取请求、响应body大小方法的前提 : 网关只做转发逻辑,不修改请求、相应的body内容。 SpringCloud Gateway内部的机制类似下图,HttpServer(也就是NettyServer)接收外部的请求,在Gateway内部请求将会通过Htt…...

二叉树的层序遍历
给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点) 。 示例 1: 输入:root [3,9,20,null,null,15,7] 输出:[[3],[9,20],[15,7]]示例 2: 输入…...

Spring Boot 集成 Thymeleaf 模板引擎
Spring Boot 集成 Thymeleaf 模板引擎 1. Thymeleaf 介绍 Thymeleaf 是适用于 Web 和独立环境的现代服务器端 Java 模板引擎。 Thymeleaf 的主要目标是为开发工作流程带来优雅的自然模板,既可以在浏览器中正确显示的 HTML,也可以用作静态原型ÿ…...

如何快速找到合适的工作?
前面好几篇文章都在写面试的感悟,带大家了解了目前的一些市场行情,以及面试过程中招聘方与求职者看待面试的不同视角。 今天这篇文章写一些对大家求职面试可能更有用的几条建议: 第一,值与量的权衡 在早些年,大多数…...

Elasticsearch入门用例
快速开始 使用版本:V7.12 资料来自官方文档 本指南幫助初學者學習如何: 將數據添加到 Elasticsearch 搜索和排序數據 在搜索過程中從非結構化內容中提取字段 测试运行: http://localhost:9200 响应: {"name": &qu…...

python制作超炫流星雨表白,python好看的流星雨代码
大家好,本文将围绕python制作超炫流星雨表白展开说明,python好看的流星雨代码是一个很多人都想弄明白的事情,想搞清楚html流星雨代码可复制需要先了解以下几个事情。 本文讲述了Python代码示例:实现流星雨特效!具有很好…...

iOS数字转为图片
根据数字,转成对应的图片 - (void)viewDidLoad {[super viewDidLoad];[self testNum2String:10086]; }/// 根据数字,显示对应的图片 数字用特定的图片显示 - (void)testNum2String:(NSInteger)num {UIView *numContentView [[UIView alloc] initWithFr…...

mac cli文件管理器
背景 最近研究了一下在控制台查看文件的插件ranger, 官方的解释是:一个cli下的文件管理器。觉得效果也很酷炫,所以在此展示一下。 安装 brew install ranger配置生成 建议第一次使用的时候使用 ranger --copy-configall将会在~/.config/ranger目录输…...

不同语言操作符的优先级
看到标题,可能会心生疑惑: 这么基础且重要的操作,不同语言不应该是一致的吗? 并不一定,比如对于右移运算和加法运算,Go就与其他多数语言表现得不一致: Go: package mainimport "fmt"func main() …...

YOLOv5源码解读1.7-网络架构common.py
往期回顾:YOLOv5源码解读1.0-目录_汉卿HanQ的博客-CSDN博客 学习了yolo.py网络模型后,今天学习common.py,common.py存放这YOLOv5网络搭建的通用模块,如果修改某一块,就要修改这个文件中对应的模块 目录 1.导入python包 2.加载自…...

关于前端框架vue2升级为vue3的相关说明
一些框架需要升级 当前(202306) Vue 的最新稳定版本是 v3.3.4。Vue 框架升级为最新的3.0版本,涉及的相关依赖变更有: 前提条件:已安装 16.0 或更高版本的Node.js(摘) 必须的变更:核…...

gdb调试时查看汇编代码
在gdb中查看汇编代码,可以使用display命令或x命令。 以下是一个示例程序,我们以它为例来演示如何在gdb中查看汇编代码。 #include <stdio.h> int main() { int a 10; int b 20; int c a b; printf("c %d\n", c); return 0;…...

小研究 - JVM GC 对 IMS HSS 延迟分析(二)
用户归属服务器(IMS HSS)是下一代通信网(NGN)核心网络 IP 多媒体子系统(IMS)中的主要用户数据库。IMS HSS 中存储用户的配置文件,可执行用户的身份验证和授权,并提供对呼叫控制服务器…...

eNSP 路由器启动时一直显示 # 号的解决办法
文章目录 1 问题截图2 解决办法2.1 办法一:排除防火墙原因导致 3 验证是否成功 1 问题截图 路由器命令行一直显示 # 号,如下图 2 解决办法 2.1 办法一:排除防火墙原因导致 排查是否因为系统防火墙原因导致。放行与 eNSP 和 virtualbox 相…...

Kotlin~Facade
概念 又称门面模式,为复杂系统提供简单交互接口。 角色介绍 Facade:外观类,供客户端调用,将请求委派给响应的子系统。SubSystem:子系统,独立的子设备或子类 UML 代码实现 class Light(val name: Strin…...

服务配置文件/var/lib/systemd与/etc/systemd/
这两个目录都是用于存储 systemd 服务的配置文件。但它们的作用和用途略有不同。 /etc/systemd/system/: 这个目录存放的是系统管理员自己创建或修改的 systemd 服务配置文件。在这里的配置文件优先级更高,会覆盖默认的 systemd 配置文件。通常,我们可以…...