Linux进阶篇:iptables详细教程:概念&作用与使用方法

云计算练习生 2024-07-20 08:07:03 阅读 64

Linux iptables详细教程:概念&作用与使用方法

一、前言

在Linux系统中,iptables是一种非常重要的防火墙工具,它可以帮助我们管理网络流量,保护系统安全。本教程将详细介绍iptables的概念、作用以及使用方法,帮助您更好地理解和掌握这一强大的工具。

在这里插入图片描述

二、iptables概念

2.1. 什么是iptables?

iptables是Linux系统中的一个用户空间工具,用于配置内核提供的IPv4和IPv6包过滤功能。它允许系统管理员根据预定义的规则对网络流量进行控制,从而实现对系统的保护。

2.2. iptables的组成

iptables主要由以下几个部分组成:

表(Table):iptables中的表是一组规则链的集合,用于存储特定类型的规则。常见的表有filter、nat、mangle和raw。链(Chain):链是一组按顺序排列的规则,用于对数据包进行处理。常见的链有INPUT、OUTPUT、FORWARD、PREROUTING和POSTROUTING。规则(Rule):规则是iptables中的基本单位,用于定义如何处理数据包。规则包括匹配条件和目标动作,当数据包满足匹配条件时,将执行目标动作。

在这里插入图片描述

三、iptables的作用

3.1. 包过滤

iptables可以根据预定义的规则对数据包进行过滤,允许或拒绝特定来源、目的地或端口的网络流量。这有助于防止未经授权的访问,提高系统安全性。

3.2. 网络地址转换(NAT)

iptables支持网络地址转换功能,可以将私有网络地址转换为公共网络地址,或者将公共网络地址转换为私有网络地址。这有助于实现内外网之间的通信,节省公共IP资源。

3.3. 数据包修改

通过mangle表,iptables可以对数据包进行修改,如更改数据包的TTL值、优先级等。这有助于实现对网络流量的优化和控制。

在这里插入图片描述

四、iptables使用方法

4.1. 查看iptables规则

要查看当前系统中的iptables规则,可以使用以下命令:

sudo iptables -L 后面还有很多内容这里只截取一部分

在这里插入图片描述

这将显示filter表中的所有链及其规则。

4.2. 添加iptables规则

要添加一条iptables规则,可以使用以下命令:

sudo iptables -A 链名 -条件 -j 动作

例如,要允许来自192.168.1.0/24网段的所有流量,可以使用以下命令:

sudo iptables -A INPUT -s 192.168.1.0/24 -j ACCEPT

在这里插入图片描述

在这里插入图片描述

4.3. 删除iptables规则

要删除一条iptables规则,可以使用以下命令:

sudo iptables -D 链名 规则编号

例如,要删除INPUT链中的第一条规则,可以使用以下命令:

sudo iptables -D INPUT 1 删除上面创建的规则

在这里插入图片描述

4.4. 修改iptables规则

要修改一条iptables规则,可以先删除原规则,然后添加新规则。例如,要将INPUT链中的第一条规则更改为拒绝来自192.168.1.0/24网段的所有流量,可以使用以下命令:

sudo iptables -D INPUT 1

sudo iptables -A INPUT -s 192.168.1.0/24 -j DROP

在这里插入图片描述

在这里插入图片描述

4.5 开放端口

如果做了WEB服务器,开启80端口

在这里插入图片描述

如果做了FTP服务器,开启21端口

在这里插入图片描述

查看上面开放的端口

在这里插入图片描述

禁用不安全的端口

在这里插入图片描述

4.6 保存iptables规则

要保存当前系统中的iptables规则,可以使用以下命令:

sudo iptables-save > File.bak

在这里插入图片描述

查看保存iptables规则的文件,后面还有很多,只截取一部分

在这里插入图片描述

这将把当前的iptables规则保存到指定文件中,以便在系统重启后恢复。

五、总结

本教程详细介绍了iptables的概念、作用以及使用方法,希望能帮助您更好地理解和掌握这一强大的Linux防火墙工具。通过熟练使用iptables,您可以有效地管理网络流量,提高系统安全性。



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。