iptables规则下发的过程

本文探讨了iptables规则从用户态到内核态的下发过程,包括配置、下发和内核处理。首先介绍iptables的四表五链结构,然后详细阐述了规则配置、DNAT和SNAT配置示例,以及通过setsockopt的下发流程。内核通过IPT_SO_SET_REPLACE进行处理,主要涉及do_replace函数。
摘要由CSDN通过智能技术生成

 背景

        最近在学习研究Linux内核NAT处理逻辑(Linux内核NAT处理),发现要想理解NAT的处理必须弄清iptables规则在Linux 内核中是如何维护的,进而想要知道iptables规则配置从用户态到内核态,一步步是如何将iptables规则下发到内核的。

过程

        从下发流程看大致分为以下几步:

        1)用户态通过应用层CLI命令配置

        2)用户态CLI命令参数解析,转换成iptables 命令配置形式通过system下发

        3)iptables内部建立与内核socket通信,通过setsockopt向将命令下发到内核

        4) 内核sockopts(应用层和内核通信的一种方式)处理,将iptables规则存入对应的表,对应的链中。

        第一步可以有不同的实现,我们从iptables规则配置开始讲起。

iptables规则配置

        众所周知,iptables规则通过“四表五链”维护,四表:raw表,mangle表,filter表,nat表;五链对应netfilter框架中的5个hook点,即:PREROUTING、INPUT、FORWARD、OUTPUT、POSTROUTING;

 iptables命令配置参数

参数 含义、用法

-A chain

在指定链中添加一条规则
-D chain /chain rulenum 从指定链中删除匹配的规则
-I chain [rulenum] 在指定链的指定规则前插入一条规则,默认在第1条前插入
  • 26
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值