在《网络中断下半部处理》一文中介绍过,当网卡接收到网络数据包后,会由网卡驱动通过调用 netif_rx 函数把数据包添加到待处理队列中,然后唤起网络中断下半部处理。...而网络中断下半部处理由 net_rx_action 函数完成的,其主要功能就是从待处理队列中获取一个数据包,然后根据数据包的网络层协议类型来找到相应的处理接口来处理数据包。...处理IP数据包 通过上面的分析,我们知道当内核接收到一个 IP 数据包后,会调用 ip_rcv 函数处理这个数据包,下面我们来分析一下 ip_rcv 函数的实现: int ip_rcv(struct...设置好数据包的路由缓存后,就调用路由缓存的 input 方法处理数据包。...tcp_v4_rcv, /* TCP handler */ IPPROTO_TCP, /* protocol ID */ ... }; 所以,当接收到一个
大家好,我是「云舒编程」,今天我们来聊聊Linux是怎么从网络上接收数据包的。...通过本文你可学到: Linux 是怎么发送数据包到网络上的 Linux 是怎么从网络上接收数据包的 软中断、硬中断 Linux 是怎么从网络上接收数据包的 整体流程: 系统初始化时,网卡驱动程序会向内核申请一块内存...中断本质上是一种特殊的电信号,由硬件设备发向CPU,CPU接收到中断后,会马上向操作系统反映此信号的到来,然后就由操作系统负责处理这些新到来的数据。...❝ Linux设计为硬中断在哪个CPU上被响应,那么软中断也是在这个 CPU 上处理的。...参考资料 深入理解Linux网络技术内幕(文中的图大部分来自该书) Linux内核源码剖析:TCP/IP实现
本文将介绍在Linux系统中,以一个UDP包的接收过程作为示例,介绍数据包是如何一步一步从网卡传到进程手中的。 网卡到内存 网络接口卡必须安装与之匹配的驱动程序才能正常工作。...内核的网络模块 软中断会触发内核网络模块中的软中断处理函数,后续流程如下: 7:在操作系统内核中,存在一个专门处理软中断的进程,称为ksoftirqd。...如果socket上设置了过滤条件且该数据包不满足条件,则该数据包也会被丢弃。在Linux中,每个socket都可以像tcpdump中一样定义过滤条件,不满足条件的数据包将被丢弃。...两种情况都能正常的接收到相应的数据包。...结束语 了解数据包的接收流程有助于帮助我们搞清楚我们可以在哪些地方监控和修改数据包,哪些情况下数据包可能被丢弃,为我们处理网络问题提供了一些参考,同时了解netfilter中相应钩子的位置,对于了解iptables
Linux 网络架构 Linux 网络初始化 网络设备子系统初始化 网卡驱动初始化 协议栈初始化 数据包的接收过程 硬中断处理 ksoftirqd 软中断处理 协议栈处理 应用层处理 总结 这里深度理解一下在...Linux下网络包的接收过程,为了简单起见,我们用udp来举例,如下: int main(){ int serverSocketFd = socket(AF_INET, SOCK_DGRAM,...Linux 网络架构 在Linux内核实现中,链路层协议靠网卡驱动来实现,内核协议栈来实现网络层和传输层。内核对更上层的应用层提供socket接口来供用户进程访问。...数据包的接收过程 硬中断处理 首先当数据帧从网线到达网卡,网卡在分配给自己的 ringBuffer 中寻找可用的内存位置,找到后 DMA 会把数据拷贝到网卡之前关联的内存里。...FEC_DEFAULT_IMASK, fep->hwp + FEC_IMASK); } return done; } fec_enet_rx->fec_enet_rx_queue 然后进入 GRO 处理,流程如下
最近要给团队做一个长期的内部分享,主题就是Linux内核中数据包的处理流程。 这几天抽空画了一部分流程图。...内核网络模块非常复杂,完整的流程图需要慢慢完善,以后会借内部分享的机会不断完善这个流程图,欢迎大家指正和提出宝贵意见。
HTTP报文添加TcpHeader,并进行CPU copy写入套接字发送缓冲区,每个套接字会分别对应一个Send-Q(发送缓冲区队列)、Recv-Q(接收缓冲区队列),可以通过ss -nt语句获取当前的套接字缓冲区的状态...在真实创建的时候会设置大小2048*2=4096,因为linux除了要考虑用户的应用层数据,还需要考虑linux自身数据结构的开销-协议头部、指针、非线性内存区域结构等... sk_buff结构中通过sk_wmem_queued...标识发送缓冲区已经使用的内存大小,并在发包时检查当前缓冲区大小是否小于SO_SENDBUF指定的大小,如果不满足则阻塞当前线程,进行睡眠,等待发送窗口中有包被ACK后触发内存free的回调函数唤醒后继续尝试发送; 接收窗口...RCV.WND ---->| ----|------------|------------------|------|---- RCV.NXT 复制代码 接收窗口主要分为...3部分: RCV.USER 为积压的已经收到但尚未被用户进程通过read等系统调用获取的网络数据包;当用户进程获取后窗口的左端会向右移动,并触发回调函数将该数据包的内存free掉; RCV.WND 为未使用的
上周在一次偶然的谈话中,我无意中听到一位同事说:Linux的网络堆栈太慢了!你不能指望它在每个核每秒处理超过5万个数据包! 这引起了我的思考。...虽然我同意每个核50kpps可能是任何实际应用程序的极限,但Linux网络栈能做什么呢?让我们换个说法,让它更有趣: 在Linux上,写一个每秒接收100万个UDP数据包的程序有多难?...对于原始的发送和接收,将传递多少数据包?...使用多个线程从一个套接字接收数据不是最优的。 SO_REUSEPORT 幸运的是,Linux中最近添加了一个解决方案:SO_REUSEPORT标志。...虽然我们已经展示了在Linux机器上接收1Mpps在技术上是可能的,但应用程序并没有对接收到的数据包进行任何实际处理——它甚至没有查看流量的内容。
当向外界主机发送数据时,在它从网卡流入后需要对它做路由决策,根据其目标决定是流入本机数据还是转发给其他主机,如果是流入本机的数据,则数据会从内核空间进入用户空间(被应用程序接收、处理)。...但Linux主机默认未开启ip_forward功能,这使得数据包无法转发而被丢弃。...Linux主机和路由器不同,路由器本身就是为了转发数据包,所以路由器内部默认就能在不同网卡间转发数据包,而Linux主机默认则不能转发。...如果Linux主机有多块网卡,如果不开启数据包转发功能,则这些网卡之间是无法互通的。...例如eth0是172.16.10.0/24网段,而eth1是192.168.100.0/24网段,到达该Linux主机的数据包无法从eth0交给eth1或者从eth1交给eth0,除非Linux主机开启了数据包转发功能
此时客户端会变成 SYN-SENT 状态 服务器接收到客户端的数据包之后,通过标志位判断出了客户端想要建立连接。...发送完一个数据包之后,不用等待 ACK 的返回,会直接继续发送下一个包,这就是滑动窗口。 但是这样会有一个问题,应用程序发送包发送的过于频繁,导致服务器接收不过来了。...而对于接收方也是一样的,接收方收到消息之后,会将数据存储在 Buffer 中,然后在 Buffer 中对收到的数据进行重组,还原成最初的应用程序发送的数据。...这个数字越大,则说明接收方的缓冲区越大,能够接收更多的数据。接收方会在确认应答的时候,将自己的剩余窗口大小写入,随ACK一起发送给发送方。...所以发送方会定期的向接收方发送窗口探测的数据段。 好了,关于数据包的发送就介绍到这里。之后有机会再聊聊 TCP 的拥塞控制相关的东西。
文件说明及下载 4.1 文件说明 4.2 文件下载 ---- 1.概述 在上一个博文 [Matlab] Simulink 串口接收详解1 中,讲了一下Serial Precive模块的简单用法,但是有时候我们接收的数据是具有复杂定义的数据包...Data Type Conversion模块设置 还是一次接收一个16字节的uint8数组,实际代表了2个double的数据。...文件说明及下载 4.1 文件说明 QtSerialSend 文件夹: Qt写的串口发送程序; recCom.mdl:Matlab串口接收程序; recCom_Union.mdl:Matlab串口接收程序...,用S-Function进行解析; DataType.h : 定义发送和接收的数据类型,被unPackData_Q.c调用; unPackData_Q.c:用C语言写的S-Function函数,编译后变成...4.2 文件下载 稍后我会上传这些资料到下载区: Matlab接收程序下载:https://download.csdn.net/download/humanking7/10510716 Qt发送程序下载
代码实现话说回来,如果想要真正实地的发送 DNS 协议首先就是了解数据包的结构。DNS 数据包中有报文头部和报文内容两部分,报文头部内容如下:其中前三行是报文头部,后边是报文内容。...有了头部和数据内容的初始化,我们换需要根据两个内容合成一个数据包内容,就有以下代码:int dns_build_requestion(const struct dns_header *header, struct...图中是一个 dns 的数据包情况,两个发送询问 s19.cnzz.com 另一个返回数据包。...我们先看发送数据包的头部:数据包是应用层的数据,所以在数据包内容最下方,上述图片是协议头部,跟我的结构体一摸一样,其中 id 是 0x1209,flags 是 0x0100 , questions 是
此时客户端会变成 SYN-SENT 状态 服务器接收到客户端的数据包之后,通过标志位判断出了客户端想要建立连接。...发送完一个数据包之后,不用等待 ACK 的返回,会直接继续发送下一个包,这就是滑动窗口。 但是这样会有一个问题,应用程序发送包发送的过于频繁,导致服务器接收不过来了。...而对于接收方也是一样的,接收方收到消息之后,会将数据存储在 Buffer 中,然后在 Buffer 中对收到的数据进行重组,还原成最初的应用程序发送的数据。...这个数字越大,则说明接收方的缓冲区越大,能够接收更多的数据。接收方会在确认应答的时候,将自己的剩余窗口大小写入,随ACK一起发送给发送方。 如果发送方接收到的大小为0,那么此时就会停止发送数据。...所以发送方会定期的向接收方发送窗口探测的数据段。 好了,关于数据包的发送就介绍到这里。之后有机会再聊聊 TCP 的拥塞控制相关的东西。
一、UDP 协议 C# UdpClient乱序接收数据包丢失的问题 Socket ReceiveBufferSize 利用UdpClient收发文件,走Udp协议,发送端只管发送数据包,接收端负责接收数据...,测试中发现,按每块1298字节发送数据包时,接收端在接收共8块时出现了部分数据包的丢失,分析可能是数据突然集中到达超出Socket接收缓冲区大小,造成数据覆盖丢失,因为默认Socket缓冲区大小为8192...字节,每块数据1298字节再加上我在实验程序中自定义的数据包头信息,每块数据大小在1472字节,8块共计11776字节,远超出了8192,会造成数据丢失。...接收端在乱序接收文件过程中,对突然集中到达的数据包处理不及时,造成缓冲区大小不够存储这些数据包,发生数据包的丢失,因而【如果要传送大文件,或在使用高带宽或高滞后时间连接(如卫星宽带提供程序),请考虑增加缓冲区的大小
前言 Linux 开发时,经常会遇到串口通信来完成两个设备之间的交互。...接收方在接收到开始序列时开始收集数据,直到接收到结束序列为止。这种方法虽然简单明了,但需要接收方对每个字符进行判断,这会消耗 CPU 资源,增加能耗。...接收中断与超时判断: 当串口接收到数据时,会触发接收中断。...一旦接收到空闲中断,我们就可以认为已经接收到了一帧完整的数据。 接收中断 我们先理解下接收中断,当接收方接收到数据时,就会触发接收中断。 举例:某中断寄存器的如下图所示。...tls_uart_write(TLS_UART_1, rx_fifo_buf, rx_len); // 发送 } } } } 小结 STM 32 串口通信功能在linux
Linux Linux启动流程(了解) 加载BIOS(Basic Input Output System):BIOS是系统启动时加载的第一个软件。
Linux 的账号验证程序是 login,login 会接收 mingetty 传来的用户名作为用户名参数。...点击下载 DefaultPrimarySuccessInfoWarningDanger 图形模式与文字模式的切换方式 Linux预设提供了六个命令窗口终端机让我们来登录。...Linux 关机 在linux领域内大多用在服务器上,很少遇到关机的操作。毕竟服务器上跑一个服务是永无止境的,除非特殊情况下,不得已才会关机。...正确的关机流程为:sync > shutdown > reboot > halt 关机指令为:shutdown ,你可以man shutdown 来看一下帮助文档。
对于UDP包来说,会被放到用户socket的接收队列中。 我们从上面这张图中已经从整体上把握到了Linux对数据包的处理过程。但是要想了解更多网络模块工作的细节,我们还得往下看。...二 Linux启动 Linux驱动,内核协议栈等等模块在具备接收网卡数据包之前,要做很多的准备工作才行。...只有这些都Ready之后,我们才能真正开始接收数据包。那么我们现在来看看这些准备工作都是怎么做的。...等下次网卡再有硬中断过来的时候再处理剩下的接收数据包。其中budget可以通过内核参数调整。...上面我们说完了整个Linux内核对数据包的接收和处理过程,最后把数据包放到socket的接收队列中了。那么我们再回头看用户进程调用recvfrom后是发生了什么。
每次打开 Linux PC 时,它都会经历一系列阶段,然后最终显示提示输入用户名或密码的登录屏幕。每个 Linux 发行版在典型的启动过程中都会经历 4 个不同的阶段。...每次打开 Linux PC 时,它都会经历一系列阶段,然后最终显示提示输入用户名或密码的登录屏幕。每个 Linux 发行版在典型的启动过程中都会经历 4 个不同的阶段。...但是请注意,有时MBR可以位于Linux的Live USB或DVD安装中。 Linux 中有 3 种主要类型的引导加载程序:LILO、GRUB和GRUB2。...GRUB 的主要目标是将 Linux 内核加载到主内存中。 3. 内核初始化 内核是任何 Linux 系统的核心。它将 PC 的硬件与底层进程连接起来。内核控制 Linux 系统上的所有进程。...此时,系统会提示您输入用户名和密码,然后您就可以进入 Linux 系统。
主机加电自检,加载BIOS硬件信息 读取MBR的引导文件(GRUB、LILO) 引导Linux内核 运行第一个进程init(进程号永远为1), 进入相应的运行级别 运行终端,输入用户名和密码 开机自检,...MBR引导,加载grub菜单,在grub菜单里面加载kernel,启动init进程,init是Linux系统启动时第一个启动的进程,init读取inittab文件,先执行/etc/rc.d/rc.sysinit
领取专属 10元无门槛券
手把手带您无忧上云