Linux内核网络

文章目录

前言

你好,我是醉墨居士,因为Linux内核涉及的内容极多,我们初学者如果一上来就开始深挖细节,很有可能会在Linux内核代码的茫茫大海之中迷失自我。本篇博客希望可以帮助大家先有个全局的视野,剩余的细节内容,根据沿着全局的脉络去学习,可能会有意想不到的效果🫠

网络协议栈

图解
功能

应用层负责为上层应用程序提供用户接口

传输层负责端到端通信,数据的分割与重组,多路复用与解复用

网络层负责路由选择,数据的分组与重组,转发分组报文

链路层负责错误检测与纠正,帧同步,处理物理地址

物理层负责在网络中传输原始的比特流

发送Linux内核网络数据包

图解
流程

1.应用协议栈处理:对用户数据进行封装成应用数据

2.CPU Copy:CPU参与将用户空间的数据拷贝到内核的套接字缓冲区中

3.协议栈处理:将套接字缓冲区中的应用数据送给Linux内核网络协议栈进行封包后放入sk_buff

4.建立DMA映射:表示sk_buff中的数据已经装载完毕,设置sk_buff的地址和长度等

5.DMA Copy:通过DMA方式将sk_buff中的数据通过Rx Ring buffer拷贝到网卡的Rx FIFO

6.发送数据:通过有线或者无线的方式将数据发送到网络中

接收Linux内核网络数据包

图解
流程

1.接收数据:通过有线或者无线的方式接收网络中的数据

2.DMA Copy:通过DMA方式将网卡的Tx FIFO中的数据通过Tx Ring Buffer拷贝到sk_buff

3.硬件中断IRQ:跳转到对应IRQ的中断服务例程(ISR)来处理该事件

4.软中断:驱动程序通过软中断执行对应的软中断处理程序

5.协议栈处理:将sk_buff中的数据通过Linux内核网络协议栈进行拆包放入套接字缓冲区

6.CPU Copy:CPU参与将内核的套接字缓冲区拷贝到用户空间

7.应用协议栈处理:对应用数据解封装成用户数据

最后

我是醉墨居士,这篇博客我们大概梳理了一下Linux网络传输的总体流程😎

如果有问题可以及时通知我,私聊,评论都行哈🤗

相关推荐
少妇的美梦16 小时前
logstash教程
运维
chen94516 小时前
k8s集群部署vector日志采集器
运维
chen94516 小时前
aws ec2部署harbor,使用s3存储
运维
轻松Ai享生活21 小时前
5 节课深入学习Linux Cgroups
linux
白帽黑客沐瑶21 小时前
【网络安全就业】信息安全专业的就业前景(非常详细)零基础入门到精通,收藏这篇就够了
网络·安全·web安全·计算机·程序员·编程·网络安全就业
christine-rr21 小时前
linux常用命令(4)——压缩命令
linux·服务器·redis
三坛海会大神5551 天前
LVS与Keepalived详解(二)LVS负载均衡实现实操
linux·负载均衡·lvs
東雪蓮☆1 天前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs
qq_264220891 天前
LVS负载均衡群集和LVS+Keepalived群集
运维·负载均衡·lvs
树码小子1 天前
Java网络编程:(socket API编程:TCP协议的 socket API -- 回显程序的服务器端程序的编写)
java·网络·tcp/ip