首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux处理数据包过程

如果不是流入本机的,而是要转发给其他主机的,则必然涉及到另一个流出网卡,此时数据包必须从流入网卡完整地转发给流出网卡,这要求Linux主机能够完成这样的转发。...但Linux主机默认未开启ip_forward功能,这使得数据包无法转发而被丢弃。...Linux主机和路由器不同,路由器本身就是为了转发数据包,所以路由器内部默认就能在不同网卡间转发数据包,而Linux主机默认则不能转发。...如果Linux主机有多块网卡,如果不开启数据包转发功能,则这些网卡之间是无法互通的。...例如eth0是172.16.10.0/24网段,而eth1是192.168.100.0/24网段,到达该Linux主机的数据包无法从eth0交给eth1或者从eth1交给eth0,除非Linux主机开启了数据包转发功能

1.8K40

linux | 网络数据包softirq 软中断与CPU

Linux 在每个 CPU 上会创建一个 ksoftirqd 内核线程。 softirqs 是在 Linux 内核编译时就确定好的,例如网络收包对应的 NET_RX_SOFTIRQ 软中断。...event PIW: 0 0 Posted-interrupt wakeup event heidsoft@heidsoft-dev:~$ /research/linux...NAPI 或新 API 的编写是为了更有效地处理传入卡的数据包。硬中断是昂贵的,因为它们不能被中断。即使有中断 合并(稍后详细描述),中断处理程序将独占一个 CPU 内核 完全地。...NAPI 的设计允许驱动程序进入轮询模式而不是被 为每个需要的数据包接收硬中断。在正常操作下,会引发初始硬中断或 IRQ,然后是 SoftIRQ 处理程序 它使用 NAPI 例程轮询卡。.../about-linux-smp_affinity https://web.archive.org/web/20200225050436/http://blog.yufeng.info/archives

2.6K20
您找到你想要的搜索结果了吗?
是的
没有找到

Linux内核网络udp数据包发送(一)

本系列文章1-4,来源于陈莉君老师公众号“Linux内核之旅” 1....前言 本文首先从宏观上概述了数据包发送的流程,接着分析了协议层注册进内核以及被socket的过程,最后介绍了通过 socket 发送网络数据的过程。 2....数据包发送宏观视角 从宏观上看,一个数据包从用户程序到达硬件网卡的整个过程如下: 使用系统调用(如 sendto,sendmsg 等)写数据 数据穿过socket 子系统,进入socket 协议族(protocol...family)系统 协议族处理:数据穿过协议层,这一过程(在许多情况下)会将数据(data)转换成数据包(packet) 数据穿过路由层,这会涉及路由缓存和 ARP 缓存的更新;如果目的 MAC 不在...总结 了解Linux内核网络数据包发送的详细过程,有助于我们进行网络监控和调优。本文只分析了协议层的注册和通过 socket 发送数据的过程,数据在传输层和网络层的详细发送过程将在下一篇文章中分析。

3.9K51

Linux内核网络UDP数据包发送(四)——Linux netdevice 子系统

Linux 支持流量控制(traffic control)的功能,此功能允许系统管理员控制数据包如何从机器发送出去。流量控制系统包含几组不同的 queue system,每种有不同的排队特征。...可以将 qdisc 视为调度程序, qdisc 决定数据包的发送时间和方式。 Linux 上每个 device 都有一个与之关联的默认 qdisc。...当 flow 的所有 outstanding(需要确认的)数据包都已确认时,TCP 协议层将设置此标志。当发生这种情况时,内核可以为此数据包选择不同的 TX 队列。...include/linux/netdevice.h: /* * Returns a Tx hash for the given packet when dev->real_num_tx_queues...Reference: https://blog.packagecloud.io/eng/2017/02/06/monitoring-tuning-linux-networking-stack-sending-data

3.1K11

ICMP数据包分析_Wireshark数据包分析实战

抓包分析软件 四.ICMP协议的封装格式 (1)Type 类型值,标识ICMP分组类型 (2)Code 代码值,标识ICMP分组类型的某一种具体分组 (3)Checksum 校验和,用于检验数据包是否完整或是否被修改...当同时与多个目的通信时,通过本字段来区分 (5)Sequence Number 序列号,标识本地到目的的数据包序号,一般从序号1开始 五.实验内容及步骤 1)ping 和Traceroute实验 (1...把不同类型报文填入 1)R1路由器上f0/0的第一次探测UDP数据包信息(TTL=1) 2)R2利用ICMP协议返回的TTL超时报文结构(type=11,code=0)...3)R1路由器上f0/0的第二次UDP数据包信息(TTL=2) 4)R2路由器上f0/1的第二次UDP数据包信息(TTL=1) 5)R3路由器上利用ICMP协议返回端口不可达报文的结构

1.1K10

数据包扩展

数据包扩展 HTTP和HTTPS的区别 图片 HTTPS协议需要CA申请证书,一般免费的证书很少,收费 HTTP协议运行在TCP之上,所有传输的内容都是明文,HTTPS运行在SSL/TLS之上,SSL...所有的传输的内容都是经过加密的 HTTP和HTTPS使用的连接方式不同,所使用的端口也不一样 HTTP是80 HTTPS是443 HTTPS可以有效方式运营商劫持 HTTP通信过程 HTTP通信过程建立连接-->发送请求数据包...-->返回数据响应包-->关闭连接 浏览器建立与web服务器之间的连接 浏览器将请求数据包打包(生成请求数据包)发送到web服务器 web服务器将处理结果打包(生成响应数据包)发送到浏览器 web服务器关闭连接...建立通信 服务器使用KEY对数据进行对称加密并返回给客户端 客户端使用相同的秘钥解密 HTTPS缺点: HTTPS 需要更多的服务器资源,也会导致成本的升高 Request请求数据包的数据格式 Request...Response响应数据包格式 一个响应由四个部分组成;状态行、响应头标、空行、响应数据。

52720

Linux BSP实战课(网络篇):数据包的发送过程

本文将介绍在Linux系统中,以一个UDP包的接收过程作为示例,介绍数据包是如何一步一步从应用程序到网卡并最终发送出去的。 socket层 socket(...)...的钩子 NF_INET_LOCAL_OUT:netfilter的钩子,可以通过iptables来配置怎么处理该数据包,如果该数据包没被丢弃,则继续往下走 dst_output_sk:该函数根据skb里面的信息...从sendto函数的帮助文件里面看到这样一句话:(Normally, this does not occur in Linux....这里的device queue应该指的是Traffic Control里面的queue,说明在linux里面,默认的SO_SNDBUF值已经够queue用了,疑问的地方是,queue的长度和个数是可以配置的...txqueuelen: 很多地方都说这个是控制qdisc里queue的长度的,但貌似只是部分类型的qdisc用了该配置,如linux默认的pfifo_fast。

40220

Linux BSP实战课(网络篇):数据包的接收过程

本文将介绍在Linux系统中,以一个UDP包的接收过程作为示例,介绍数据包是如何一步一步从网卡传到进程手中的。 网卡到内存 网络接口卡必须安装与之匹配的驱动程序才能正常工作。...当相应的网卡接收到数据包时,网络模块将调用相应的驱动程序来处理数据。 下图展示了数据包(packet)如何进入内存,并被内核的网络模块开始处理: 1:外部网络传入的数据包会进入物理网卡。...8:net_rx_action函数会调用网卡驱动中的poll函数,逐个处理数据包。 9:在poll函数中,驱动程序会逐个读取网卡写入内存的数据包,该数据包的格式只有驱动程序知道。...上的函数 NF_INET_PRE_ROUTING:netfilter放在协议栈中的钩子,可以通过iptables来注入一些数据包处理函数,用来修改或者丢弃数据包,如果数据包没被丢弃,将继续往下走 routing...如果socket上设置了过滤条件且该数据包不满足条件,则该数据包也会被丢弃。在Linux中,每个socket都可以像tcpdump中一样定义过滤条件,不满足条件的数据包将被丢弃。

30220

数据包络分析(DEA)

1.概述 数据包络分析方法(Data Envelopment Analysis,DEA)是评价多输入指标和多输出指标的较为有效的方法,将多投入与多产出进行比较,得到效率分析,可广泛使用于业绩评价。...数据包络分析是一种具有相同类型决策单元进行绩效评价的方法(相同类型是指这类决策单元有相同性质的投入和产出。比如说医院投入的是医护人员面积,床位数,医疗设施等等,产出的是门诊病人人次,住院人次。...数据包络分析DEA时,首先需要分析综合效益值θ,即首先判断DMU是否有DEA有效,如果有效,则说明该DMU较优,反之说明‘非DEA有效’。...投入冗余投入过多,需要减少多少才更优(松驰变量S-)产出不足产出过少,需要增加多少才更优(松驰变量S+) 数据包络分析DEA时,首先需要分析综合效益值θ,即首先判断DMU是否有DEA有效,如果有效

4K20

数据包络分析教程

[g4uwywfvci.png] 数据包络分析(Data Envelopment Analysis,也称DEA)是一种用于进行前沿分析的非参数方法。...为什么数据包络分析这么有趣?...数据包络分析的描述和假设 [8wfuvxwfxg.jpeg] 正如我们前面所讨论的,DEA是一种被发明用来衡量商业生产力的方法。因此,它的一些观点来自于在这种背景下衡量生产力的方法。...此外,数据包络分析它假设:特征值可以作为非负权重的加权总和被线性组合起来,并形成输入和输出之间的比率,以测量每条记录的效率。为了让一个记录变得有效,它必须对于被提供的输入给予我们一个“良好”的输出。...数据包络分析不是在我们运行分析之前设置特征值的权重然后决定它们的重要度,而是从数据来估量它们。此外,每个记录的权重都是不一样的!

3.4K71

Linux内核网络UDP数据包发送(三)——IP协议层分析

前言 Linux内核网络 UDP 协议层通过调用 ip_send_skb 将 skb 交给 IP 协议层,本文通过分析内核 IP 协议层的关键函数来分享内核数据包发送在 IP 协议层的处理,并分享了监控...如果 nf_hook 返回 1,则表示允许数据包通过,并且调用者应该自己发送数据包。...出于讨论目的,我们假设 nf_hook 返回 1,表示调用者(在这种情况下是 IP 协议层)应该自己发送数据包。 3.2 目的(路由)缓存 dst 代码在 Linux 内核中实现协议无关的目标缓存。...总结 Linux内核网络数据包发送时,主要用到 ip_send_skb、 ip_local_out、ip_output、ip_finish_output、ip_finish_output2、 dst_neigh_output...等函数,本文通过分析这些函数来分享Linux内核数据包发送在 IP 层的处理,并对 IP 层进行了数据监控。

2.9K21

Linux内核网络udp数据包发送(二)——UDP协议层分析

前言 本文分享了Linux内核网络数据包发送在UDP协议层的处理,主要分析了udp_sendmsg和udp_send_skb函数,并分享了UDP层的数据统计和监控以及socket发送队列大小的调优。...而辅助消息允许在每个数据包级别设置 TTL 和 TOS 值。Linux 内核会使用一个数组将 TOS 转换为优先级,后者会影响数据包如何以及何时从 qdisc 中发送出去。...支持该特性的网卡可以处理数据 被分散到多个 buffer 的数据包;内核不需要花时间将多个缓冲区合并成一个缓冲区中。...接下来看看如何在 Linux 内核中监视和调优 UDP 协议层。 4....总结 本文重点分析了数据包在传输层(UDP协议)的发送过程,并进行了监控和调优,后面数据包将到达 IP 协议层,下次再分享,感谢阅读。

5.4K51
领券