首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

记一次有惊无险的丢包调试经历

是时候表演真正的技术了,dropwatch 出场: shell> dropwatch -l kas Initalizing kallsyms db dropwatch> start Enabling...查询一下 Linux 源代码中 __netif_receive_skb_core 函数的定义来确认一下丢包原因: static int __netif_receive_skb_core(struct sk_buff...此外,代码里能看到调用了 kfree_skb,侧面验证了 dropwatch 的工作原理。 如何判断我们问题中丢的包协议是什么呢,是时候表演真正的技术了, systemtap 出场: #!...printf("0x%04X\n", ntohs($skb->protocol)) } // output 0x0004 顺便说一句,有了 systemtap,几乎可以为所欲为,比如替换前面提到的 dropwatch...从前面我们对 Linux 源代码的分析,skb_pfmemalloc_protocol 中支持的包 protocol 如下: #define ETH_P_ARP 0x0806 /* Address Resolution

2.1K40

手把手教你用Dropwatch诊断问题

老实说,Dropwatch 并不是什么新鲜玩意,很多年前霸爷就专门撰文介绍过它,通过它可以大概找出系统为什么会丢包,其原理就是跟踪 kfree_skb 的调用行为。...kernel kernel-2.6.32-431.23.3.el6.x86_64 kernel-debuginfo-common-x86_64-2.6.32-431.23.3.el6.x86_64 Dropwatch...本身有一个交互命令行,命令中的 kas 指的是加载对应的符号表: shell> dropwatch -l kas Initalizing kallsyms db dropwatch> start Enabling...在本例子中,Dropwatch 显示在 init_dummy_netdev 附近存在大量丢包现象,提示信息格式的大致说明是:丢包数量 drops at 函数名+偏移量 (地址)。...虽然这次纠错过程最终被证实为虚惊一场,但是相信大家在过程中已经学会了如何使用 Dropwatch

1.9K10

linux 系统 UDP 丢包问题分析思路

在开始之前,我们先用一张图解释 linux 系统接收网络报文的过程。...Linux 系统丢包 linux 系统丢包的原因很多,常见的有:UDP 报文错误、防火墙、UDP buffer size 不足、系统负载过高等,这里对这些丢包原因进行分析。...在系统层面,linux 设置了 receive buffer 可以配置的最大值,可以在下面的文件中查看,一般是 linux 在启动的时候会根据内存大小设置一个初始值。...另外一个因素是应用读取 buffer 中报文的速度,对于应用程序来说,处理报文应该采取异步的方式 包丢在什么地方 想要详细了解 linux 系统在执行哪个函数时丢包的话,可以使用 dropwatch 工具...,它监听系统丢包信息,并打印出丢包发生的函数地址: # dropwatch -l kas Initalizing kallsyms db dropwatch> start Enabling monitoring

6.8K42

Linux 系统 UDP 丢包问题分析思路

在开始之前,我们先用一张图解释 linux 系统接收网络报文的过程。...Linux 系统丢包 linux 系统丢包的原因很多,常见的有:UDP 报文错误、防火墙、UDP buffer size 不足、系统负载过高等,这里对这些丢包原因进行分析。...在系统层面,linux 设置了 receive buffer 可以配置的最大值,可以在下面的文件中查看,一般是 linux 在启动的时候会根据内存大小设置一个初始值。...另外一个因素是应用读取 buffer 中报文的速度,对于应用程序来说,处理报文应该采取异步的方式 包丢在什么地方 想要详细了解 linux 系统在执行哪个函数时丢包的话,可以使用 dropwatch 工具...,它监听系统丢包信息,并打印出丢包发生的函数地址: # dropwatch -l kas Initalizing kallsyms db dropwatch> start Enabling monitoring

14.7K31

容器网络防火墙状态异常导致丢包排查记录

图2-1 dropwatch脚本(不带backtrce打印) 图2-2 dropwatch脚本(带backtrce打印) 首先通过图2-1脚本找到丢包点的具体函数,然后找到丢包具体的地址(交叉运行stap...--all-modules dropwatch.stp -g和stap dropwatch.stp -g命令,结合/proc/kallsyms里面函数的具体地址),再把丢包地址作为判断条件,精确打印丢包点的...运行脚本stap --all-modules dropwatch.stp -g,开始复现问题,脚本打印如图2-3: 图2-3 丢包函数 正常不卡顿的时候是没有nf_hook_slow的,当出现卡顿的时候...再次运行脚本:stap dropwatch.stp -g,确认丢包地址列表,对比/proc/kallsyms符号表ffffffff8155c8b0 T nf_hook_slow,找到最接近0xffffffff8155c8b0

1.2K40

Linux - Linux内存管理

为了解决内存紧缺的问题,Linux引入了虚拟内存的概念。为了解决快速存取,引入了缓存机制、交换机制等。...要深入了解Linux内存运行机制,需要知道下面提到的几个方面。 首先,Linux系统会不时地进行页面交换操作,以保持尽可能多的空闲物理内存。...其次,Linux进行页面交换是有条件的,不是所有页面在不用时都交换到虚拟内存中,Linux内核根据“最近最经常使用”算法,仅仅将一些不经常使用的页面文件交换到虚拟内存中。...Linux虽然可以在一段时间内自行恢复,但是恢复后的系统已经基本不可用了。...Linux下可以使用文件系统中的一个常规文件或者一个独立分区作为交换空间。同时Linux允许使用多个交换分区或者交换文件。

52.1K41

Linux】--- Linux权限概念

shell 对于Linux,有相同的作用,主要是对我们的指令进行解析,解析指令给Linux内核。反馈结果在通过内核运行出结果,通过shell解析给用户。...2.3 Linux中的用户 Linux下有两种用户:超级管理员(root)、普通用户。 超级管理员(root):可以再linux系统下做任何事情,不受权限约束 普通用户:在linux下做有限的事情。...Linux具有组的概念,主要是在多人协作的时候,更好的进行权限管理!...而在Linux中不通过后缀区分文件类型!但并不是说Linux不用后缀。 那通过什么区分呢?即ls -l第一个属性列。 Linux文件类型: -:普通文件。...很简单一个道理,Linux系统不以文件后缀作为区分文件类型的依据,但并不代表gcc不需要,Linux系统 != gcc。

7610
领券