0

0

firewalld 添加 permanent rule 后 reboot 失效的 --permanent --reload 坑

冰川箭仙

冰川箭仙

发布时间:2026-01-19 18:10:03

|

881人浏览过

|

来源于php中文网

原创

firewalld 添加 permanent rule 后重启失效的根本原因是仅执行 --permanent 未执行 --reload,导致规则写入配置文件但未同步至运行时;正确做法是先 --permanent 再 --reload。

firewalld 添加 permanent rule 后 reboot 失效的 --permanent --reload 坑

firewalld 添加 permanent rule 后重启失效,根本原因不是规则没加成功,而是 只执行了 --permanent 操作,却没触发永久配置的真正生效。--permanent 只是把规则写进配置文件(如 /etc/firewalld/zones/public.xml),但不会自动加载到运行时(runtime)中,更不会在 reboot 后自动应用——firewalld 服务启动时默认只加载 runtime 状态,除非明确启用持久化加载逻辑。

✅ 正确添加 permanent rule 的两步必须都做

添加永久规则后,必须显式 reload 才能让 firewalld 重新读取配置文件并同步 runtime 状态:

  • ✗ 错误写法(仅永久): firewall-cmd --permanent --add-port=8080/tcp → 规则已存盘,但当前防火墙不放行,重启后也不生效
  • ✓ 正确写法(永久 + 重载): firewall-cmd --permanent --add-port=8080/tcp && firewall-cmd --reload
  • --reload 会:① 从磁盘重新加载所有 zone 配置;② 将 permanent 状态完全覆盖 runtime;③ 不中断已有连接(相比 restart 更安全)

⚠️ reboot 失效的常见连带原因

即使加了 --permanent 和 --reload,reboot 后仍失效,可能是以下情况之一:

  • firewalld 服务未设为开机自启:运行 systemctl is-enabled firewalld,若返回 disabled,需执行 systemctl enable firewalld
  • SELinux 或其他防火墙冲突:如 iptables-services 仍在运行,会覆盖 firewalld 规则;检查 systemctl status iptables 并禁用:systemctl disable iptables
  • zone 配置被覆盖或误删:/etc/firewalld/zones/ 下的 xml 文件被手动编辑出错,或被 ansible/salt 等工具重置;建议用 firewall-cmd --list-all --permanent 核对磁盘配置是否与预期一致

? 验证 permanent rule 是否真生效

不要只信命令返回 success,要分层验证:

百度MCP广场
百度MCP广场

探索海量可用的MCP Servers

下载
  • 查磁盘配置:firewall-cmd --list-all --permanent(看输出里是否有你加的端口/服务)
  • 查运行时状态:firewall-cmd --list-all(应与 --permanent 输出一致,否则 reload 没成功)
  • 模拟重启影响:systemctl restart firewalld && firewall-cmd --list-all(等效于 reboot 后的首次状态)
  • 确认服务自启:systemctl is-active firewalld(重启后应为 active)

? 小技巧:避免漏 reload 的习惯写法

日常操作建议统一用函数封装,例如在 ~/.bashrc 中添加:

fwadd() { firewall-cmd --permanent "$@" && firewall-cmd --reload; }

之后直接用 fwadd --add-port=8080/tcp,一气呵成,不再手抖忘 reload。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1885

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2087

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1017

2024.11.28

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

11

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

75

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

109

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

152

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

79

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

44

2026.01.15

热门下载

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

精品课程

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

共48课时 | 7.4万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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