news 2026/6/10 19:54:40

防火墙配置:掌握 iptables、firewalld 等工具的使用与管理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
防火墙配置:掌握 iptables、firewalld 等工具的使用与管理

防火墙配置:掌握 iptables、firewalld 等工具的使用与管理

在现代服务器安全体系中,防火墙是最基础、最关键的安全屏障之一。无论是传统的iptables,还是更现代的firewalld,都承担着“限制访问、减少攻击面、保护系统”的核心职责。

本文将从以下几个方面展开:

  • iptables 与 firewalld 的区别与适用场景
  • iptables 常用规则与管理方法
  • firewalld 的区域、服务与端口管理
  • 企业级防火墙最佳实践

1. iptables 与 firewalld 的区别

项目iptablesfirewalld
工作方式静态规则表动态规则管理
配置难度较高较低
是否支持热更新❌ 重载会中断连接✔ 支持动态更新
管理方式命令行规则区域(zone)+ 服务(service)
适用场景高度自定义、精细控制日常运维、快速配置

总结:

  • 需要精细控制 → 用iptables
  • 需要快速管理、动态更新 → 用firewalld

2. iptables 基础与常用配置

iptables 基于表(table)链(chain)工作:

  • filter:默认表,用于过滤流量
  • nat:地址转换(DNAT/SNAT)
  • mangle:修改数据包
  • raw:绕过连接跟踪

常用链:

  • INPUT:进入本机的流量
  • OUTPUT:从本机发出的流量
  • FORWARD:转发流量

2.1 查看当前规则

iptables -L -n -v

2.2 放行常用端口

放行 SSH(22)

iptables -A INPUT -p tcp --dport22-j ACCEPT

放行 HTTP/HTTPS

iptables -A INPUT -p tcp -m multiport --dports80,443-j ACCEPT

2.3 拒绝所有其他流量(默认策略)

iptables -P INPUT DROP iptables -P FORWARD DROP iptables -P OUTPUT ACCEPT

2.4 允许本地回环与已建立连接

iptables -A INPUT -i lo -j ACCEPT iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT

2.5 保存规则

CentOS 7 及以下:

serviceiptables save

Ubuntu:

iptables-save>/etc/iptables.rules

3. firewalld 使用与管理

firewalld 是基于区域(zone)的动态防火墙,支持热更新,不会中断现有连接。


3.1 常用命令

查看状态

systemctl status firewalld

启动/停止

systemctl start firewalld systemctlenablefirewalld

3.2 区域(Zone)概念

常见区域:

区域说明
public默认区域,允许最少服务
internal内网环境
trusted信任所有流量(慎用)
drop丢弃所有流量

查看当前区域:

firewall-cmd --get-active-zones

3.3 开放端口

开放 80 端口

firewall-cmd --zone=public --add-port=80/tcp --permanent firewall-cmd --reload

开放多个端口

firewall-cmd --add-port=3000-3010/tcp --permanent

3.4 开放服务(推荐方式)

firewalld 内置服务定义(如 ssh、http、https)。

开放 HTTP 服务

firewall-cmd --add-service=http --permanent firewall-cmd --reload

查看所有服务:

firewall-cmd --get-services

3.5 移除端口或服务

firewall-cmd --remove-port=80/tcp --permanent firewall-cmd --remove-service=http --permanent firewall-cmd --reload

3.6 允许特定 IP 访问

仅允许某 IP 访问 SSH

firewall-cmd --add-rich-rule='rule family="ipv4" source address="1.2.3.4" port port="22" protocol="tcp" accept'--permanent

4. iptables 与 firewalld 的组合使用建议

  • firewalld 是 iptables 的上层管理工具
  • 不建议同时启用两者,否则规则冲突难以排查
  • 若使用 firewalld,应关闭 iptables 服务

5. 企业级防火墙最佳实践

5.1 最小暴露面原则

  • 只开放业务必须端口
  • 禁用所有默认服务
  • 定期审计端口暴露情况

5.2 使用白名单策略

  • SSH 仅允许固定 IP 登录
  • 管理后台仅允许内网访问

5.3 分环境管理

环境策略
生产严格白名单
测试适度放开
开发内网访问即可

5.4 日志与审计

  • 定期查看防火墙日志
  • 监控异常访问(如暴力破解)
  • 配合 fail2ban 等工具自动封禁恶意 IP

6. 总结

掌握 iptables 与 firewalld,是系统安全加固的基础能力:

  • iptables:适合精细化控制
  • firewalld:适合动态管理与日常运维
  • 最小暴露面 + 白名单 + 审计是企业级最佳实践

通过合理配置防火墙,可以显著降低攻击面,提升系统整体安全性。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 11:12:25

AI Phone下的各类App该何去何从

一、先给结论(避免焦虑)AI Phone 不会消灭 App,但会“肢解”App。 App 将从「用户入口」退化为「能力模块」。也就是说: 入口权 → 被 AI 接管能力权 → App 仍然掌握二、AI Phone 改变了什么?(核心机制&am…

作者头像 李华
网站建设 2026/6/10 2:05:41

微观交通流仿真软件:AIMSUN_(22).交通仿真项目管理和实施

交通仿真项目管理和实施 在交通仿真项目中,有效的项目管理和实施是确保项目成功的关键。本节将详细介绍如何在AIMSUN中进行项目管理和实施,包括项目结构、数据管理、模型校准、仿真运行和结果分析等方面的内容。 项目结构 1. 项目文件组织 在AIMSUN中&am…

作者头像 李华
网站建设 2026/6/10 10:54:29

谢飞机的互联网大厂Java面试奇遇记

场景描述 在一家知名互联网大厂的面试室内,面试官刘严肃正要对面前的求职者谢飞机进行技术面试。谢飞机神情轻松,因为他听说这位面试官虽然以严厉著称,但只要答对问题,还是会给予鼓励。 第一轮提问 刘严肃: 我们先从基…

作者头像 李华
网站建设 2026/6/10 4:39:42

Docker 入门指南:从 “容器小白” 到快速上手

1. Docker发展与简介1.1 云服务与虚拟化基础1.1.1 云服务模型介绍云计算 是通过网络为用户提供可伸缩的计算资源。云服务通常分为以下几种类型:IaaS(基础设施即服务)提供虚拟化计算资源(如虚拟机、存储、网络等)。用户…

作者头像 李华
网站建设 2026/6/10 12:39:52

【小白笔记】图论(Graph Theory),“二维数组”或“矩阵”

简单来说,**图论(Graph Theory)**是数学的一个分支,专门研究“点”和“连接点的线”所组成的图形。 在图论中,这种图形被称为图(Graph)。它不是我们平常在 Excel 里看到的统计图表,而…

作者头像 李华