Linux防火墙-4表5链
作者介绍:简历上没有一个精通的运维工程师。希望大家多多关注作者,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。

我们经过上小章节讲了Linux的部分进阶命令,我们接下来一章节来讲讲Linux防火墙。由于目前以云服务器为主,而云服务器基本上就不会使用系统自带的防火墙,而是使用安全组来代替了防火墙的功能,可以简单理解安全组就是web版的防火墙,我们主要从以下几个方面来讲解Linux防火墙:
Linux防火墙-什么是防火墙
Linux防火墙-4表5链(本章节)
Linux防火墙-filter表
Linux防火墙-nat表
Linux防火墙-常用命令
Linux防火墙-案例(一)
Linux防火墙-案例(二)
Linux防火墙-小结
我们上一节讲了门卫手里的小本本记录着很多规则,这些规则如果没有统一的规范来管理,就会显得很混乱,如果真有人来访无法快速找到规则,如果规则有冲突怎么办?今天我们就来讲防护墙里面的4表5链,可以通过它来管理所有的小本本里面的规则。
4表
-
raw 表
-
作用:主要用于决定是否对数据包进行状态跟踪的豁免处理。
-
场景示例:在某些情况下,一些特殊的网络应用程序或者服务需要快速处理大量的数据包,并且不希望这些数据包受到 netfilter 状态跟踪机制的影响(因为状态跟踪可能会消耗一定的系统资源和时间),此时就可以在 raw 表中设置相应的规则,将这些特定的数据包标记为不受状态跟踪处理。例如,一些高性能的网络测试工具或者实时性要求极高的网络通信应用,就可以通过 raw 表来优化其网络性能。
-
-
mangle 表
-
作用:用于对数据包进行修改、标记等操作,以便后续的处理和分类。
-
场景示例:企业网络中可能需要对不同类型的网络流量进行区分和标记,以便进行不同的处理策略。例如,可以使用 mangle 表对来自特定部门的网络流量进行标记,然后在后续的网络设备中根据这些标记进行流量整形(如限制带宽或优先处理)。另外,还可以在 mangle 表中修改数据包的 IP 头部的某些字段,如 TTL(Time To Live)值,以满足特定的网络拓扑或性能需求。
-
-
nat 表
-
作用:主要负责网络地址转换相关的操作,包括源地址转换(SNAT)和目的地址转换(DNAT)。
-
场景示例:在企业网络中,当内部使用私有 IP 地址的设备需要访问外部网络时,就需要使用 SNAT 将内部设备的私有 IP 地址转换为公共 IP 地址。例如,一个公司内部有多个员工同时访问互联网,通过在 nat 表中设置 SNAT 规则,将他们的私有 IP 地址转换为公司的公共 IP 地址,这样就可以实现多个设备共享一个公共 IP 地址上网。而对于外部网络访问内部服务器的情况,就需要使用 DNAT 将外部网络请求的目标 IP 地址(通常是公共 IP 地址)转换为内部服务器的私有 IP 地址,实现内部服务器的对外提供服务。
-
-
filter 表
-
作用:主要用于过滤数据包,决定是否允许数据包通过或者丢弃。
-
场景示例:这是最常用的一个表,用于实现基本的防火墙功能。例如,在企业网络中,可以在 filter 表的 INPUT 链中设置规则,阻止来自特定 IP 地址或者特定端口的数据包进入内部网络,以保护内部系统的安全。同时,也可以在 OUTPUT 链中设置规则,限制内部系统向外发送某些类型的数据包,防止敏感信息泄露或者恶意软件传播。在 FORWARD 链中,可以根据企业的网络安全策略,决定是否允许转发某些数据包,实现对网络流量的精细控制。
-
5链
-
INPUT 链
-
作用:用于处理进入本地系统的数据包。
-
场景示例:当其他设备发送数据到本地 Linux 系统时,这些数据包在经过网络协议栈的初步处理后,会进入 INPUT 链进行进一步的过滤和决策。比如,当你在本地系统上运行一个 Web 服务器,外部用户通过浏览器访问该服务器时,其发送的 HTTP 请求数据包就会进入 INPUT 链。如果 INPUT 链中的规则允许该数据包通过,那么系统才会将其传递给相应的 Web 服务器应用程序进行处理;如果规则阻止了该数据包,那么它就会被丢弃。
-
-
OUTPUT 链
-
作用:主要处理本地系统产生的向外发送的数据包。
-
场景示例:当本地系统中的应用程序(例如浏览器)发起一个网络请求时,该请求数据包在系统内部经过一系列准备工作后,会进入 OUTPUT 链。在 OUTPUT 链中,可以根据需要对这些数据包进行过滤和修改。比如,企业内部的安全策略可能要求所有从本地系统发出的数据包都必须添加一个特定的标识字段,那么就可以在 OUTPUT 链中设置相应的规则来实现这一功能。当数据包在 OUTPUT 链中完成处理后,才会被发送到网络上。
-
-
FORWARD 链
-
作用:负责处理需要转发的数据包,即那些不是本地系统的目标数据包,但需要通过本地系统转发到其他设备的数据包。
-
场景示例:在一个作为网络中间设备(如路由器或具备路由功能的 Linux 系统)的场景中,当接收到一个数据包,并且根据路由规则判断该数据包的目标地址不是本地系统本身,而是要转发到其他网络设备时,这个数据包就会进入 FORWARD 链。在 FORWARD 链中,可以根据设定的规则决定是否允许转发该数据包。例如,在一个企业网络中,为了防止内部网络中的某些恶意设备通过转发数据包进行攻击,可以在 FORWARD 链中设置规则,只允许特定源地址和目标地址的数据包进行转发。
-
-
PREROUTING 链
-
作用:在数据包进入路由决策之前进行处理。
-
场景示例:当一个数据包刚刚进入 Linux 系统的网络接口时,在进行路由判断(即确定数据包的目标地址以及应该将其发送到哪个网络接口)之前,会先进入 PREROUTING 链。在这个链中,可以进行一些数据包的修改和转换操作。比如,网络地址转换(NAT)功能中的目的地址转换(DNAT)通常就在 PREROUTING 链中实现。例如,企业内部的服务器使用私有 IP 地址,通过在 PREROUTING 链中设置 DNAT 规则,可以将来自外部网络的访问请求的目标地址转换为内部服务器的私有 IP 地址,从而实现外部网络对内部服务器的访问。
-
-
POSTROUTING 链
-
作用:在数据包经过路由决策并且即将离开本地系统时进行处理。
-
场景示例:当本地系统已经完成对数据包的处理,并且根据路由规则确定了数据包的发送出口时,在数据包离开系统之前会进入 POSTROUTING 链。在这个链中,常见的操作是进行源地址转换(SNAT)。例如,在一个企业网络中,内部多个设备使用私有 IP 地址共享一个公共 IP 地址访问外部网络时,就可以在 POSTROUTING 链中设置 SNAT 规则,将内部设备的私有 IP 地址转换为公共 IP 地址,使得数据包能够顺利发送到外部网络。
-
表与链的关联
- raw 表:关联 PREROUTING 和 OUTPUT 链,在这些链中对数据包进行状态跟踪豁免处理等操作。
- filter 表:与 INPUT、FORWARD 和 OUTPUT 链相关,在这些链中依据防火墙规则对数据包进行过滤。
- nat 表:涉及 PREROUTING、OUTPUT 和 POSTROUTING 链,主要负责网络地址转换相关操作,如目的地址转换(DNAT)在 PREROUTING 链进行前期处理,源地址转换(SNAT)在 OUTPUT 和 POSTROUTING 链分步完成。
- mangle 表:涵盖 PREROUTING、INPUT、FORWARD、OUTPUT 和 POSTROUTING 链,在各链中实现数据包的修改、标记等,以满足不同阶段的网络处理需求。
总结
1.我们平时常用的表就是nat表和filter表
2.filter表其实就是一般而言的防火墙功能,用于控制普通流量的进出。
3.net表则主要用户控制网络地址转换,实际上功能就是和我们的路由器功能差不多。

相关文章:
Linux防火墙-4表5链
作者介绍:简历上没有一个精通的运维工程师。希望大家多多关注作者,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。 我们经过上小章节讲了Linux的部分进阶命令,我们接下来一章节来讲讲Linux防火墙。由于目前以云服务器为主&#x…...
(最新已验证)stm32 + 新版 onenet +dht11+esp8266/01s + mqtt物联网上报温湿度和控制单片机(保姆级教程)
物联网实践教程:微信小程序结合OneNET平台MQTT实现STM32单片机远程智能控制 远程上报和接收数据——汇总 前言 之前在学校获得了一个新玩意:ESP-01sWIFI模块,去搜了一下这个小东西很有玩点,远程控制LED啥的,然后我就想…...
无环SLAM系统集成后端回环检测模块(loop):SC-A-LOAM以及FAST_LIO_SLAM
最近在研究SLAM目标检测相关知识,看到一篇论文,集成了SC-A-LOAM作为后端回环检测模块,在学习了论文相关内容后决定看一下代码知识,随后将其移植,学习过程中发现我找的论文已经集成了回环检测模块,但是我的另…...
速盾:视频开cdn合适还是视频点播合适?
在选择视频服务时,许多企业和个人面临了一个重要的决策,那就是选择是使用开CDN(内容分发网络)还是使用视频点播服务。这两种选择都有各自的优势和适用场景,因此在做出决定之前,我们需要仔细评估自身的需求和…...
Mac电脑安装FFmpeg和卸载FFmpeg
Mac电脑安装FFmpeg 在Mac上安装FFmpeg有几种方法,以下是通过Homebrew安装的最简单方法: 1. 使用Homebrew安装FFmpeg 如果你已经安装了Homebrew,可以通过以下命令来安装FFmpeg: 打开终端 (Terminal)。更新Homebrew:…...
数据结构:栈 及其应用
逻辑结构: 栈(Stack)是一种遵循后进先出(LIFO, Last In First Out)原则的有序集合 (受限的线性表)。这种数据结构只允许在栈顶进行添加(push)或删除(pop&…...
批量发送邮件:性能优化与错误处理深度解析
目录 一、批量发送邮件的基础概述 1.1 批量发送邮件的定义 1.2 邮件发送流程 二、性能优化策略 2.1 发送速率控制 2.2 队列管理 2.3 动态IP池管理 2.4 智能调度 三、错误处理机制 3.1 暂时性发送错误处理 3.2 永久性发送错误处理 3.3 邮件反馈收集与分析 四、案例…...
STM32原理知识查询表
本篇文章主要收录单片机学习过程中的各种知识点原理,如果后面遇到了比较具体的应用,也会有专门的配套实践过程。 2024.09.27单片机的两种看门狗原理解析 持续待更新。。。。。...
从 Kafka 到 WarpStream: 用 MinIO 简化数据流
虽然 Apache Kafka 长期以来一直是流数据的行业标准,但新的创新替代方案正在重塑生态系统。其中之一是 WarpStream,它最近在 Confluent 的所有权下进入了新的篇章。此次收购进一步增强了 WarpStream 提供高性能、云原生数据流的能力,巩固了其…...
【Gitee自动化测试4】本地Git分支的增删查,本地Git分支中文件的增删查,本地文件的暂存/提交,本地分支的推送
一、流程 本地创建分支,设定连接什么云分支本地创建文件,暂存、提交–>本地分支本地分支推送所有修改–>云仓库 二、分支概念 在版本回退里,每次提交,git都把它们串成一条时间线,这条时间线可以理解为是一个分…...
vue-baidu-map的基本使用
前言 公司项目需求引入百度地图,由于给的时间比较短,所以就用了已经封装好了的vue-baidu-map 一、vue-baidu-map是什么? vue-baidu-map是基于vue.js封装的百度地图组件(官方文档) 二、使用步骤 1.下载插件 //我下载的版本 npm install …...
策略路由控制选路
🐣个人主页 可惜已不在 🐤这篇在这个专栏 华为_可惜已不在的博客-CSDN博客 🐥有用的话就留下一个三连吧😼 目录 一、 实验拓扑 二、 实验简述 三、 实验配置 配置路由信息 配置控制选路 四、 实验验证 一、 实验…...
【数据结构和算法实践-排序-快速排序】
数据结构和算法实践-排序-归并排序 题目My Thought代码示例JAVA-8 题目 排序 My Thought 然后再进行递归,递归要注意两个方面: 一、自我调用 二、终止条件:即函数边界 注意点:树、递归* 代码示例 JAVA-8 public class QuickSo…...
测试面试题:请你分别介绍一下单元测试、集成测试、系统测试、验收测试、回归测试
单元测试:完成最小的软件设计单元(模块)的验证工作,目标是确保模块被正确的编码集成测试:通过测试发现与模块接口有关的问题系统测试:是基于系统整体需求说明书的黑盒类测试,应覆盖系统所有联合…...
回归预测合集|基于灰狼优化21个机器学习和深度学习的数据回归预测Matlab程序 多特征输入单输出
回归预测合集|基于灰狼优化21个机器学习和深度学习的数据回归预测Matlab程序 多特征输入单输出 文章目录 一、清单二、实验结果三、核心代码四、代码获取五、总结 一、清单 基于灰狼优化BP神经网络的数据预测Matlab程序GWO–BP 基于灰狼优化卷积神经网络的数据预测Matlab程序G…...
html/css怎么禁用浏览器自动填写
<input type"text" name"username" autocomplete"off"> <input type"password" name"password" autocomplete"new-password">或者vue: <el-input type"text" v-model"…...
信息安全工程师(22)密码学网络安全应用
前言 密码学在网络安全中的应用极为广泛且深入,它通过多种技术手段确保数据的机密性、完整性和真实性。 一、数据加密 对称加密: 定义:使用相同的密钥进行加密和解密的过程。特点:加密和解密速度快,适用于大数据量的加…...
算法打卡:第十一章 图论part08
今日收获:拓扑排序,dijkstra算法 算法讲解部分均来源于代码随想录 1. 拓扑排序 基础知识: (1)应用场景:给出有向图,将有向图转换为线性的排序就叫拓扑排序(如果图中有环则存在循…...
2024年Gartner主存储平台魔力象限报告 | 华为从领导者象限滑落到挑战者象限
魔力象限报告对比 本周Gartner发布了2024年主存储平台魔力象限报告,主存储用户正在采用平台原生服务功能来实现混合 IT 运营。I&O 领导者应利用这项研究来为任务关键型应用程序规划和执行现代且有弹性的存储基础设施平台。 本次报告中共有10家厂商入选…...
[Python学习日记-31] Python 中的函数(上)
[Python学习日记-31] Python 中的函数(上) 简介 语法定义 函数的参数 简介 引子: 你是某公司的一个高级程序员,现在老板让你写一个监控程序,需要24小时全年无休的监控公司网站服务器的系统状况,当 CPU、…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...
练习(含atoi的模拟实现,自定义类型等练习)
一、结构体大小的计算及位段 (结构体大小计算及位段 详解请看:自定义类型:结构体进阶-CSDN博客) 1.在32位系统环境,编译选项为4字节对齐,那么sizeof(A)和sizeof(B)是多少? #pragma pack(4)st…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
高危文件识别的常用算法:原理、应用与企业场景
高危文件识别的常用算法:原理、应用与企业场景 高危文件识别旨在检测可能导致安全威胁的文件,如包含恶意代码、敏感数据或欺诈内容的文档,在企业协同办公环境中(如Teams、Google Workspace)尤为重要。结合大模型技术&…...
sqlserver 根据指定字符 解析拼接字符串
DECLARE LotNo NVARCHAR(50)A,B,C DECLARE xml XML ( SELECT <x> REPLACE(LotNo, ,, </x><x>) </x> ) DECLARE ErrorCode NVARCHAR(50) -- 提取 XML 中的值 SELECT value x.value(., VARCHAR(MAX))…...
从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...
【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...
3403. 从盒子中找出字典序最大的字符串 I
3403. 从盒子中找出字典序最大的字符串 I 题目链接:3403. 从盒子中找出字典序最大的字符串 I 代码如下: class Solution { public:string answerString(string word, int numFriends) {if (numFriends 1) {return word;}string res;for (int i 0;i &…...
实现弹窗随键盘上移居中
实现弹窗随键盘上移的核心思路 在Android中,可以通过监听键盘的显示和隐藏事件,动态调整弹窗的位置。关键点在于获取键盘高度,并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...
