iptables处理经过的数据包的流程是什么?

iptables各个表的优先级:4个表的优先级由高到低的顺序为:raw-->mangle-->nat-->filter。

iptables利用表和链处理每个经过的数据包,具体流程(步骤)如下

数据包到达网络接口,比如 eth0。

进入 raw 表的 PREROUTING 链,这个链的作用是在连接跟踪之前处理数据包。

如果进行了连接跟踪,则进行处理。

进入 mangle 表的 PREROUTING 链,在此可以修改数据包,比如 TOS 等。

进入 nat 表的 PREROUTING 链,可以在此做DNAT,但不做过滤。

决定路由,看是交给本地主机还是转发给其它主机,即决定是否继续往内还是往外。

到了这里需要分两种不同的情况进行讨论了。

若数据包决定要转发给其它主机,这时候它会依次经过

进入 mangle 表的 FORWARD 链,这里是在第一次路由(即步骤6)决定之后,在进行最后的路由决定之前,仍然可以对数据包进行某些修改。

进入 filter 表的 FORWARD 链,这里可以对所有转发的数据包进行过滤。

进入 mangle 表的 POSTROUTING 链,这里将完成了所有的路由决定,但数据包仍然在本地主机,还可以进行某些修改。

进入 nat 表的 POSTROUTING 链,这里一般都是用来做 SNAT ,不在这里进行过滤。

进入出去的网络接口,然后进行发送。

另一种情况是,数据包就是发给本地主机的,那么它会依次穿过

进入 mangle 表的 INPUT 链,这里是在第一次路由(即步骤6)决定之后,在进行最后的路由决定之前,仍然可以对数据包进行某些修改。

进入 filter 表的 INPUT 链,这里可以对流入的所有数据包进行过滤,无论它来自哪个网络接口。

交给本地主机的应用程序进行处理。

处理完毕后进行路由决定,看该往那里发出。

进入 raw 表的 OUTPUT 链,这里是在连接跟踪处理本地的数据包之前。

连接跟踪对本地的数据包进行处理。

进入 mangle 表的 OUTPUT 链,这里可以修改数据包,但不做过滤。

进入 nat 表的 OUTPUT 链,可以对防火墙自己发出的数据做 NAT 。

再次进行路由决定。

进入 filter 表的 OUTPUT 链,可以对本地出去的数据包进行过滤。

进入 mangle 表的 POSTROUTING 链,同上一种情况的第9步(里将完成了所有的路由决定,但数据包仍然在本地主机,还可以进行某些修改。)。

进入 nat 表的 POSTROUTING 链,同上一种情况的第10步(里一般都是用来做 SNAT ,不在这里进行过滤。)。

进入出去的网络接口,然后进行发送。

相关推荐
wdfk_prog8 小时前
[Linux]学习笔记系列 -- hashtable
linux·笔记·学习
每日出拳老爷子8 小时前
【远程协助】内网 IT 运维远程协助系统的最小可用架构
运维·服务器·远程工作·流媒体·视音频
weixin_462446239 小时前
使用 Puppeteer 设置 Cookies 并实现自动化分页操作:前端实战教程
运维·前端·自动化
CheungChunChiu9 小时前
Linux 内核动态打印机制详解
android·linux·服务器·前端·ubuntu
西***634710 小时前
打破部署桎梏!编码器两大核心架构(NVR/PoE)深度解析
服务器·音视频·视频编解码
BlueBirdssh10 小时前
linux 内核通过 dts 设备树 配置pcie 控制器 各种参数和中断等, 那freeRTOS 是通过直接设置PCIe寄存器吗
linux
小目标一个亿10 小时前
Windows平台Nginx配置web账号密码验证
linux·前端·nginx
实战项目11 小时前
软件测试自动化框架的设计与实现
运维·自动化
Aotman_11 小时前
Element-UI Message Box弹窗 使用$confirm方法自定义模版内容,修改默认样式
linux·运维·前端
Elastic 中国社区官方博客11 小时前
使用 Elastic 中的 OpenTelemetry 为 Nginx 实现端到端分布式追踪的实用指南
大数据·运维·分布式·elasticsearch·搜索引擎·信息可视化·全文检索