iptables 里INPUT、OUTPUT、FORWARD 三个链(Chain)详解

iptables 里,INPUTOUTPUTFORWARD 是最核心的三个链(Chain) ,它们定义了数据包在本机处理过程中的三个关键路径。下面我会通俗地解释它们的含义和作用:


🔁 总体概念:什么是链(Chain)?

iptables 把数据包的处理过程分为多个"链",每条链就是一组规则,规则之间按顺序匹配。三大最常用的链如下:

链名称 作用方向 数据包路径
INPUT 进入本机 外部数据包 → 本地程序
OUTPUT 从本机发出 本地程序 → 外部网络
FORWARD 本机转发(不处理) 外部设备 → 外部设备(经由本机)

📥 1. INPUT 链

作用:控制访问本机的网络流量

  • 只要是别人访问你(比如你开了一个 web 服务,别人访问你的 80 端口),就会经过 INPUT 链。

  • 适用于:SSH、HTTP、HTTPS、Ping 等所有入站连接

示例:

bash 复制代码
iptables -A INPUT -p tcp --dport 22 -j ACCEPT

允许其他主机访问本机的 22 端口(SSH)。


📤 2. OUTPUT 链

作用:控制本机发出的流量

  • 当你在本机执行 curl、ping、apt-get、wget、ssh 等命令时,这些"出站"请求都会经过 OUTPUT 链。

示例:

bash 复制代码
iptables -A OUTPUT -p tcp --dport 80 -j ACCEPT

允许本机访问外部 HTTP(80 端口)网站。


🔀 3. FORWARD 链

作用:控制"路由转发"流量(本机作为中转,不是源也不是目的)

  • 本机如果做了网关、路由器、NAT、VPN、Docker 桥接等转发行为,就会用到 FORWARD 链。

  • 比如一个包从网卡 eth0 进来,经由本机,从网卡 eth1 转出去,就会用到 FORWARD 链。

示例:

bash 复制代码
iptables -A FORWARD -s 192.168.1.0/24 -d 10.0.0.0/24 -j ACCEPT

允许本机转发来自 192.168.1.* 到 10.0.0.* 的流量。


🧠 总结对比

链名称 流量方向 是否发给本机 是否来自本机 示例
INPUT 入站流量 ✅ 是 ❌ 否 别人访问你
OUTPUT 出站流量 ❌ 否 ✅ 是 你访问别人
FORWARD 转发流量 ❌ 否 ❌ 否 本机充当中转(如路由器)
相关推荐
尼古拉斯·纯情暖男·天真·阿玮1 天前
实验四 恶意软件实验
网络·安全·智能路由器
CC-NX1 天前
计算机网络:实验一局域网设计及仿真
计算机网络·智能路由器·packet tracer
Godspeed Zhao1 天前
现代智能汽车中的无线技术23——Wi-Fi(11)
网络·汽车·智能路由器
软件小滔2 天前
我使用MAC WiFi Explorer Pro完成了一次家庭网络“大扫除”
网络·macos·智能路由器·mac·应用推荐·wifi explorer
zbtlink2 天前
一楼到四楼,如何实现Wi-Fi信号全覆盖?不同方案详解
网络·智能路由器
zbtlink2 天前
怎么知道自己家里适合什么样的路由器?
网络·智能路由器
网安小白的进阶之路3 天前
B模块 安全通信网络 第二门课 核心网路由技术-2-BGP-邻居-全互联
网络·安全·智能路由器
Godspeed Zhao3 天前
现代智能汽车中的无线技术20——Wi-Fi(8)
网络·汽车·智能路由器
MM_MS4 天前
Halcon小案例--->路由器散热口个数(两种方法)
人工智能·算法·目标检测·计算机视觉·视觉检测·智能路由器·视觉
weixin_443290694 天前
【华为HCIA路由交换认证指南】第四章 管理华为设备
华为·智能路由器