这些规则你都知道吗

在Linux系统中,防火墙是保护系统安全的核心组件,修改防火墙规则需要谨慎操作,以下详细指南涵盖主流工具(iptables、firewalld、UFW),操作前请注意:

  1. 重要备份:执行 iptables-save > /backup/iptables.rulesfirewall-cmd --runtime-to-permanent
  2. 权限要求:所有命令需 root 权限(使用 sudo
  3. 测试验证:修改后务必测试连通性

使用 iptables(传统工具,通用所有发行版)

核心概念规则链(INPUT/OUTPUT/FORWARD)

# 允许特定端口(示例:开放80端口)  
iptables -A INPUT -p tcp --dport 80 -j ACCEPT  
# 允许IP访问(示例:允许192.168.1.10访问SSH)  
iptables -A INPUT -p tcp -s 192.168.1.10 --dport 22 -j ACCEPT  
# 拒绝所有其他入站流量(必须最后执行!)  
iptables -A INPUT -j DROP  
# 删除规则(先列出带编号规则)  
iptables -L --line-numbers  
iptables -D INPUT 3  # 删除INPUT链第3条规则  
# 保存规则(依发行版选择)  
service iptables save    # RHEL/CentOS 6  
iptables-save > /etc/iptables/rules.v4  # Debian/Ubuntu  

使用 firewalld(RHEL/CentOS/Fedora 默认)

核心概念:区域(zone)与服务(service)

# 查看活动区域  
firewall-cmd --get-active-zones  
# 开放端口(示例:永久开放443端口)  
firewall-cmd --permanent --add-port=443/tcp  
# 添加服务(示例:允许HTTP服务)  
firewall-cmd --permanent --add-service=http  
# 允许IP(示例:允许192.168.1.0/24访问DNS)  
firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="192.168.1.0/24" service name="dns" accept'  
# 移除规则(将 --add 替换为 --remove)  
firewall-cmd --permanent --remove-port=8080/tcp  
# 重载配置(不中断连接)  
firewall-cmd --reload  

使用 UFW(Ubuntu/Debian 简化工具)

# 启用防火墙  
ufw enable  
# 允许服务(示例:SSH与Nginx)  
ufw allow ssh  
ufw allow 'Nginx Full'  # 开放80/443  
# 允许端口范围(示例:UDP 5000-5010)  
ufw allow 5000:5010/udp  
# 拒绝IP(示例:屏蔽203.0.113.5)  
ufw deny from 203.0.113.5  
# 删除规则(先列出编号)  
ufw status numbered  
ufw delete 2  # 删除第2条规则  

关键安全建议

  1. 最小化开放:仅暴露必要端口(如Web服务器只需80/443)
  2. 默认拒绝策略:设置 ufw default denyiptables -P INPUT DROP
  3. 日志监控:添加日志规则 iptables -A INPUT -j LOG --log-prefix "IPTABLES-DENIED: "
  4. 防锁定
    • 先允许当前SSH连接:iptables -A INPUT -p tcp --dport 22 -j ACCEPT
    • 测试后再应用新规则

测试与故障排查

  • 检查端口状态nc -zv 你的IP 端口telnet 你的IP 端口
  • 查看防火墙日志
    • iptables:dmesg | grep iptables
    • firewalld:journalctl -u firewalld
  • 临时禁用(紧急恢复):
    iptables -F  # 清空规则  
    systemctl stop firewalld  # 停止firewalld  
    ufw disable  # 禁用UFW  

引用说明

  • iptables 官方文档:https://www.netfilter.org/documentation/
  • firewalld 配置指南:https://firewalld.org/documentation/
  • UFW 手册页:man ufw(或访问 https://help.ubuntu.com/community/UFW) 基于 Linux 内核 5.x+ 及主流发行版(RHEL 8+, Ubuntu 20.04+)验证,实际操作请以您的环境为准。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/9974.html

(0)
酷番叔酷番叔
上一篇 2025年8月8日 08:53
下一篇 2025年8月8日 09:07

相关推荐

  • Linux下如何打开或运行Perl脚本?

    在Linux系统中,“打开perl”通常涉及两个核心场景:一是确认系统是否已安装Perl环境并进入交互式解释器,二是执行Perl脚本文件,以下将从环境检查、安装配置、交互式使用、脚本执行及常见问题解决五个方面详细说明,检查系统是否已安装Perl大多数Linux发行版默认会安装Perl,但部分精简系统可能未包含……

    2025年9月19日
    2300
  • Linux命令行如何安装PyCharm?

    在Linux系统中通过命令行安装PyCharm是开发者常用的方式,尤其适合服务器环境或偏好键盘操作的用户,PyCharm提供专业版(Professional)和社区版(Community)两个版本,专业版支持Web开发、科学计算等高级功能,需付费;社区版免费,适合Python基础开发,本文将详细介绍通过命令行安……

    2025年8月27日
    2700
  • Linux系统获取网速的具体原理与实现方式是什么?

    Linux系统获取网速的方式多样,既可通过命令行工具实现实时监控,也能借助图形界面直观展示,其核心均依赖于内核提供的网络统计机制,这些方法通过读取内核数据、捕获网络包或分析进程流量,满足不同场景下的网速监控需求,命令行工具:实时与精准的流量统计命令行工具是Linux网速监控的主流方式,功能覆盖接口流量、进程带宽……

    2025年9月18日
    2000
  • 在Linux系统如何下载安装exe软件?详细操作步骤是哪些?

    在Linux系统中,由于.exe文件是Windows平台的可执行文件,其底层架构(如PE格式、系统调用API)与Linux的ELF格式和系统接口不兼容,因此无法直接双击运行安装,用户可通过多种兼容方案实现.exe软件的安装与使用,以下将详细介绍具体方法及注意事项,使用兼容层运行Windows软件兼容层是模拟Wi……

    2025年9月21日
    2200
  • linux下如何开发php

    Linux系统凭借其稳定性、安全性和强大的命令行工具,成为PHP开发的主流环境之一,在Linux下开发PHP,需要搭建完整的开发环境、选择合适的工具链,并掌握配置优化和调试部署技巧,本文将从环境搭建、工具使用、配置优化到调试部署,详细讲解Linux下PHP开发的完整流程,环境搭建:LAMP与LNMP环境配置Li……

    2025年9月18日
    2300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信