0

0

如何在Linux中限制网络访问 Linux iptables用户过滤

P粉602998670

P粉602998670

发布时间:2025-09-01 11:14:01

|

809人浏览过

|

来源于php中文网

原创

答案:iptables是Linux中基于表、链、规则的防火墙工具,通过命令如-A、-I、-D管理流量规则,支持按IP、端口、协议限制访问,规则按顺序匹配且需保存以防重启丢失,firewalld为其上层更易用的管理工具。

如何在linux中限制网络访问 linux iptables用户过滤

简单来说,在Linux中限制网络访问,你可以使用

iptables
,它就像一个防火墙,允许你设置规则来控制哪些流量可以进出你的系统。
iptables
非常强大,但配置起来也比较复杂,需要理解它的基本概念和命令。

解决方案

  1. 理解

    iptables
    的基本结构:
    iptables
    基于表(tables)、链(chains)和规则(rules)工作。

    • 表 (Tables):
      filter
      (默认,用于过滤数据包),
      nat
      (用于网络地址转换),
      mangle
      (用于修改数据包),
      raw
      (用于配置数据包的连接追踪)。
    • 链 (Chains):
      INPUT
      (进入系统的数据包),
      OUTPUT
      (离开系统的数据包),
      FORWARD
      (通过系统转发的数据包)。
    • 规则 (Rules): 定义如何处理符合特定条件的数据包(例如,允许或拒绝)。
  2. 常用的

    iptables
    命令:

    • iptables -L
      : 列出当前规则。
    • iptables -A
      : 在链的末尾添加一条规则。
    • iptables -I
      : 在链的开头插入一条规则。
    • iptables -D
      : 删除一条规则。
    • iptables -F
      : 清空链中的所有规则。
    • iptables -P
      : 设置链的默认策略(例如,
      ACCEPT
      DROP
      )。
    • iptables -S
      : 以更易读的格式显示规则。
  3. 限制特定 IP 地址访问:

    # 阻止来自 IP 地址 192.168.1.100 的所有流量
    iptables -A INPUT -s 192.168.1.100 -j DROP
    
    # 允许来自 IP 地址 192.168.1.100 的 SSH 访问 (端口 22)
    iptables -A INPUT -s 192.168.1.100 -p tcp --dport 22 -j ACCEPT
  4. 限制特定端口的访问:

    # 阻止所有到端口 80 (HTTP) 的流量
    iptables -A INPUT -p tcp --dport 80 -j DROP
    
    # 允许到端口 80 的流量来自特定 IP 地址
    iptables -A INPUT -s 192.168.1.100 -p tcp --dport 80 -j ACCEPT
  5. 限制特定协议的访问:

    # 阻止所有 ICMP (ping) 流量
    iptables -A INPUT -p icmp -j DROP
  6. 保存

    iptables
    规则:
    iptables
    规则在系统重启后会丢失,你需要保存它们。

    • Debian/Ubuntu:
      sudo apt-get install iptables-persistent
      , 然后
      sudo netfilter-persistent save
    • CentOS/RHEL:
      sudo yum install iptables-services
      , 然后
      sudo systemctl enable iptables
      ,
      sudo systemctl start iptables
      , 最后
      sudo iptables-save > /etc/sysconfig/iptables

iptables
规则的优先级是怎样的?

iptables
按照规则在链中的顺序进行匹配。第一条匹配的规则生效,后续规则不再评估。因此,规则的顺序至关重要。通常,更具体的规则(例如,允许特定 IP 地址访问特定端口)应该放在更通用的规则(例如,阻止所有访问)之前。

宣小二
宣小二

宣小二:媒体发稿平台,自媒体发稿平台,短视频矩阵发布平台,基于AI驱动的企业自助式投放平台。

下载

如何查看和删除特定的

iptables
规则?

查看规则,可以使用

iptables -L -n -v
-n
选项会显示 IP 地址和端口号,而不是尝试进行 DNS 反向查找,
-v
显示更详细的信息。

删除规则,最简单的方法是使用行号:

  1. iptables -L --line-numbers
    : 显示规则及其对应的行号。
  2. iptables -D INPUT <行号>
    : 删除
    INPUT
    链中指定行号的规则。

例如,要删除

INPUT
链中行号为 3 的规则,可以执行
iptables -D INPUT 3

iptables
firewalld
有什么区别,我应该选择哪个?

iptables
是一个更底层的防火墙管理工具,而
firewalld
是一个更高级的、动态的防火墙管理器,它构建在
iptables
之上。
firewalld
使用区域 (zones) 的概念来管理规则,更容易配置和管理。

选择哪个取决于你的需求和偏好。如果你需要精细的控制和对

iptables
有深入的了解,那么
iptables
可能更适合你。如果你需要一个更易于使用和管理的防火墙,那么
firewalld
可能是更好的选择。许多现代 Linux 发行版默认使用
firewalld

实际上,即使你使用

firewalld
,它最终也会生成
iptables
规则。
firewalld
只是提供了一个更友好的接口来管理这些规则。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1026

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

66

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

454

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

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

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

182

2023.11.24

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

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

1349

2023.06.21

如何安装LINUX
如何安装LINUX

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

704

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
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号