Kernel Packet Traveling Diagram

本文详细解析了Linux内核中网络包的处理流程,包括IPchains和Iptables的工作机制,以及在网络包从输入到输出整个过程中涉及的关键操作,如连接跟踪(conntrack)、地址转换(NAT)等。
摘要由CSDN通过智能技术生成

源:http://mailman.ds9a.nl/pipermail/lartc/2002q2/004245.html

以上为linux中TC(Traffic Control)控制部分,和网络包在内核中的走向,下面是一个图。

 


这个图。我觉得,真是太经典了!

当然这个图和现在的kernel还是有点出入的,

在linux-2.6.36中。

 ip_forward_finish() -->return dst_output(skb);--->ip_output()

然后是POSTOUTING是

ip_output()-->NF_IP_POSTOUTING-->ip_finish_output()这样处理过程

 

如果是ip_gre 活ip_ip协议的话,那么是在ip_local_deliver_finish内,调用相应的handler函数,去掉gre/ip头后处理完成后再调用netif_rx()函数。相信在代码中都是一目了然的。代码内核版本为:2.6.36

 

发送流程:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值