0

0

Linux防火墙规则如何编写_核心逻辑讲解助你快速掌握【教程】

舞夢輝影

舞夢輝影

发布时间:2025-12-15 15:21:07

|

558人浏览过

|

来源于php中文网

原创

Linux防火墙规则核心是“匹配-动作”逻辑:先定义流量特征(源/目的IP、端口、协议等),再执行ACCEPT或DROP/REJECT;iptables与nftables底层一致仅语法不同;需明确规则流向(PREROUTING→INPUT/FORWARD/OUTPUT→POSTROUTING)及各链职责,按方向匹配对应链;每条规则须完整指定协议、源地址、目标端口/类型和动作;规则自上而下匹配,首条命中即执行,顺序至关重要;默认策略为兜底但不可替代显式规则。

linux防火墙规则如何编写_核心逻辑讲解助你快速掌握【教程】

Linux防火墙规则的核心在于“匹配-动作”逻辑:先定义流量特征(源/目的IP、端口、协议等),再决定放行(ACCEPT)或拒绝(DROP/REJECT)。iptables(传统)和nftables(现代默认)底层思路一致,只是语法不同。掌握规则流向(PREROUTING → INPUT/FORWARD/OUTPUT → POSTROUTING)和链的职责,比死记命令更重要。

明确规则生效的链和时机

不是所有规则都写在INPUT里。关键看流量方向:

  • 进来的连接(如别人访问你的Web服务)→ INPUT链
  • 本机主动发出的请求(如curl外网)→ OUTPUT链
  • 本机转发的包(如做路由器)→ FORWARD链
  • PREROUTING和POSTROUTING主要用于NAT(端口映射、IP伪装),普通过滤很少用

写规则前必须想清楚这4个条件

每条有效规则都应覆盖以下要素,缺一不可:

  • 协议类型:tcp / udp / icmp / all(不建议用all,太宽泛)
  • 源地址:可以是单IP(192.168.1.100)、网段(192.168.1.0/24)或anywhere(0.0.0.0/0,慎用)
  • 目标端口(对tcp/udp)或类型(对icmp):比如--dport 22(SSH),--sport 53(DNS响应端口)
  • 动作:ACCEPT(放行)、DROP(静默丢弃)、REJECT(返回拒绝提示,适合调试)

顺序决定成败:规则从上到下逐条匹配

iptables/nftables按插入顺序执行,**第一条匹配就立即执行动作,不再往下看**。所以:

通义万相
通义万相

通义万相,一个不断进化的AI艺术创作大模型

下载
  • 通用宽松规则(如“允许所有内网流量”)要放在严格规则(如“只允许某IP连SSH”)前面
  • 默认策略(如INPUT默认DROP)是最后一道保险,但不能替代明确规则
  • iptables -L --line-numbers查看序号,用-I 3在第3行插入,-D 5删除第5行

一条实用SSH规则拆解(iptables示例)

只允许192.168.10.0/24网段通过22端口登录本机:

iptables -A INPUT -s 192.168.10.0/24 -p tcp --dport 22 -j ACCEPT
  • -A INPUT:追加到INPUT链末尾(生产环境建议用-I插入到合适位置)
  • -s 192.168.10.0/24:限制来源网段
  • -p tcp:只匹配TCP协议(SSH不用UDP)
  • --dport 22:目标端口是22(注意不是--sport,客户端源端口随机)
  • -j ACCEPT:匹配即放行

这条之后,通常跟一条默认拒绝:iptables -A INPUT -j DROP(确保其他流量被拦住)。

基本上就这些。不复杂但容易忽略——重点不是记命令,而是想清楚“谁在访问什么、走哪条路、该不该放”。先画草图(源IP→协议→端口→链→动作),再敲命令,错得少,改得快。

相关专题

更多
curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

431

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

175

2023.10.30

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

182

2023.11.24

tcp和udp的区别
tcp和udp的区别

TCP和UDP的区别,在连接性、可靠性、速度和效率、数据报大小以及适用场景等方面。本专题为大家提供tcp和udp的区别的相关的文章、下载、课程内容,供大家免费下载体验。

119

2023.07.25

udp是什么协议
udp是什么协议

UDP是OSI参考模型中一种无连接的传输层协议。本专题为大家带来udp是什么协议的相关文章,免费提供给大家。

285

2023.08.08

tcp和udp有什么区别
tcp和udp有什么区别

tcp和udp的区别有:1、udp是无连接的,tcp是面向连接的;2、udp是不可靠传输,tcp是可靠传输;3、udp是面向报文传输,tcp是面向字节流传输。想了解更多tcp相关的内容,可阅读本专题下面的相关文章。

379

2024.11.14

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1349

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

703

2023.06.29

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号