记一次 某智能制造MES系统CPU 爆高分析
一:背景
1. 讲故事
前段时间有位朋友找到我,说他 docker 中的web服务深夜cpu被打满,让我帮忙看一下,很多朋友问docker中怎么抓dump,我一般都推荐使用procdump这款自动化工具,谁用谁知道,有了 dump 之后,接下来就是分析了。
二:WinDbg 分析
1. cpu 真的爆高吗
有很多朋友问 linux 上的dump可以用 windbg 分析吗?这里统一回复下,是可以的,现在的 WinDbg 可以全平台分析,不信看下图:
不过有一点吐槽的是,Linux 不是微软的,所以在 操作系统层级 上的调试支持是不够的,也不是 WinDbg 能力所触及范围之内,所以相比 Windows 有很多的不便。
接下来我们用!tp看一下当前的 cpu 到底是多少?
0:000> !tpCPU utilization: 393 %Worker Thread: Total: 19 Running: 5 Idle: 10 MaxLimit: 32767 MinLimit: 4Work Request in Queue: 0--------------------------------------Number of Timers: 4--------------------------------------Completion Port Thread:Total: 0 Free: 0 MaxFree: 8 CurrentLimit: 0 MaxLimit: 1000 MinLimit: 4从卦中看当前的cpu=393%,这表示什么意思呢?在Linux上是这样的,一个核占用 100%,可以理解成当前有 4 个核被打满。
那当前 docker 中给了多少 cpu 核呢?在 Windows 平台上可以用!cpuid,在 Linux 上肯定用不了了,没关系,熟悉 CLR 的朋友应该知道,ServerGC 的heap个数默认按照cpu 的个数来的,也就是说当前多少个heap,也就有多少个 cpu core。
有了这个思路,使用!eeversion来看下 gc 模式吧。
0:000> !eeversion4.700.21.56803 (3.x runtime)4.700.21.56803 @Commit: 28bb6f994c28bc91f09bc0ddb5dcb51d0f066806Server mode with 4 gc heapsSOS Version: 7.0.8.10101 retail build从卦中的Server mode with 4 gc heaps来看,当前docker使用 4 个 cpu 核,所以393%就表示了当前被完全打满。
2. 为什么会被打满
一般来说cpu的跌宕起伏都是由 thread 诱发的,一个好的思路就是看下此时各个线程都在做什么,可以使用~*e !clrstack观察,经过仔细对比发现有 4 处 SqlDataReader 貌似在读什么东西,刚好对应到了 CPU 核数,输出如下:
0:000> ~*e !clrstackOS Thread Id: 0x3f89 (24)Child SP IP Call Site00007F9FA14A0628 00007fa4803e2a93 System.Data.SqlClient.TdsParser.TrySkipValue(System.Data.SqlClient.SqlMetaDataPriv, Int32, System.Data.SqlClient.TdsParserStateObject) [/_/src/System.Data.SqlClient/src/System/Data/SqlClient/TdsParser.cs @ 4399]00007F9FA14A0640 00007fa47f9a5e03 System.Data.SqlClient.TdsParser.TrySkipRow(System.Data.SqlClient._SqlMetaDataSet, Int32, System.Data.SqlClient.TdsParserStateObject) [/_/src/System.Data.SqlClient/src/System/Data/SqlClient/TdsParser.cs @ 4334]00007F9FA14A0670 00007fa4803d2fba System.Data.SqlClient.SqlDataReader.TryCleanPartialRead() [/_/src/System.Data.SqlClient/src/System/Data/SqlClient/SqlDataReader.cs @ 760]00007F9FA14A0690 00007fa47f99e424 System.Data.SqlClient.SqlDataReader.TryReadInternal(Boolean, Boolean ByRef) [/_/src/System.Data.SqlClient/src/System/Data/SqlClient/SqlDataReader.cs @ 3286]00007F9FA14A06F0 00007fa4804742e5 System.Data.SqlClient.SqlDataReader+c__DisplayClass190_0.b__1(System.Threading.Tasks.Task) [/_/src/System.Data.SqlClient/src/System/Data/SqlClient/SqlDataReader.cs @ 4448]00007F9FA14A0720 00007fa480a239ea System.Data.SqlClient.SqlDataReader+c__DisplayClass194_0`1[[System.Boolean, System.Private.CoreLib]].b__0(System.Threading.Tasks.Task`1从卦中看,虽然异步写的很爽,可逆向分析起来真的是上刀山下火海。。。接下来思路在哪里呢?可以这么想,既然是和 SqlDataReader 有关系,那就挖一挖,看看里面有什么sql。
0:025> !dsoOS Thread Id: 0x3f8a (25)RSP/REGObject Namerdx00007fa128ad9c08 System.Data.SqlClient.SNI.TdsParserStateObjectManagedrdi00007fa128ad9c08 System.Data.SqlClient.SNI.TdsParserStateObjectManagedr9 00007fa128ad9c08 System.Data.SqlClient.SNI.TdsParserStateObjectManagedr1200007fa128ad9c08 System.Data.SqlClient.SNI.TdsParserStateObjectManagedr1300007fa128ad9b70 System.Data.SqlClient.TdsParser...00007F9FA31546B0 00007fa3297b8fb8 System.Data.SqlClient.SqlDataReader...0:025> !DumpObj /d 00007fa3297b84d0Name:System.StringMethodTable: 00007fa477db0f90EEClass: 00007fa477d1e230Size:2496(0x9c0) bytesFile:/usr/share/dotnet/shared/Microsoft.NETCore.App/3.1.22/System.Private.CoreLib.dllString:select xxx,xxx,xxx,xxx from template_xxxreport where 1=1 Fields:MTField Offset Type VT AttrValue Name00007fa477daa0e8400022a8 System.Int321 instance 1237 _stringLength00007fa477da6f00400022bcSystem.Char1 instance 73 _firstChar00007fa477db0f90400022c108System.String0 static 00007fa027fff360 Empty从 sql 看貌似是读了template_xxxreport表, 而且还没有筛选条件,看样子是深夜跑什么数据把 CPU 给抬起来了,那接下里的问题是什么地方会执行这条sql呢?
3. 到底在哪里执行的
刚才的线程栈看不到一句用户代码,我们还可以用!gcroot追踪下这个 sql 的祖宗,可能会有新的发现哦。
0:025> !gcroot 00007fa3297b84d000007F9FA3154770 00007FA4803FA6CE System.Threading.Tasks.ContinuationResultTaskFromResultTask`2[[System.__Canon, System.Private.CoreLib],[System.__Canon, System.Private.CoreLib]].InnerInvoke() [/_/src/System.Private.CoreLib/shared/System/Threading/Tasks/TaskContinuation.cs @ 191]rbx: ->00007FA233579680 System.Threading.Tasks.ContinuationResultTaskFromResultTask`2[[System.Object, System.Private.CoreLib],[System.Threading.Tasks.Task`1[[System.Boolean, System.Private.CoreLib]], System.Private.CoreLib]]->00007FA233579748 System.Threading.Tasks.UnwrapPromise`1[[System.Boolean, System.Private.CoreLib]]...->00007FA329BE4BB0 System.Threading.Tasks.StandardTaskContinuation->00007FA329BE4B18 System.Threading.Tasks.ContinuationTaskFromResultTask`1[[System.Boolean, System.Private.CoreLib]]->00007FA329BE4AD8 System.Action`1[[System.Threading.Tasks.Task`1[[System.Boolean, System.Private.CoreLib]], System.Private.CoreLib]]->00007FA329BE2AE8 System.Data.SqlClient.SqlDataReader+<>c__DisplayClass195_0`1[[System.Boolean, System.Private.CoreLib]]->00007FA32982AE50 System.Threading.Tasks.TaskCompletionSource`1[[System.Boolean, System.Private.CoreLib]]->00007FA32982AE68 System.Threading.Tasks.Task`1[[System.Boolean, System.Private.CoreLib]]->00007FA3297B91B0 System.Runtime.CompilerServices.AsyncTaskMethodBuilder`1+AsyncStateMachineBox`1[[xxx.xxx.Template_xxxxReport, xxx.xxx],[Dapper.SqlMapper+从引用链条看,这条sql使用 Dapper 的QueryRowAsync查询,实体类是xxx.xxxx.Template_xxxxReport,有了这些信息就好办了,反馈给朋友后,让朋友看下这是哪里的sql和model。
据朋友调查后,说是用的某商业数据访问sdk 内部逻辑不严谨造成的,参考代码如下:
public async Task当param =null时,底层用param = new { };当无参数处理,这就导致全表sql的发生,朋友说现在想想都有点后怕。。。
三:总结
这次事故主要是由某商业数据访问sdk在异常参数处理时逻辑不严谨所致,毕竟抛异常比全量查询要好得多,大家在买商业组件的时候,且行且珍惜。
推荐系统
电脑公司Ghost Win8.1 x32 精选纯净版2022年7月(免激活) ISO镜像高速下载
语言:中文版系统大小:2.98GB系统类型:Win8电脑公司Ghost Win8.1x32位纯净版V2022年7月版本集成了自2022流行的各种硬件驱动,首次进入系统即全部硬件已安装完毕。电脑公司Ghost Win8.1x32位纯净版具有更安全、更稳定、更人性化等特点。集成最常用的装机软件,精心挑选的系统维护工具,加上绿茶独有
微软Win11原版22H2下载_Win11GHOST 免 激活密钥 22H2正式版64位免费下载
语言:中文版系统大小:5.13GB系统类型:Win11微软Win11原版22H2下载_Win11GHOST 免 激活密钥 22H2正式版64位免费下载系统在家用办公上跑分表现都是非常优秀,完美的兼容各种硬件和软件,运行环境安全可靠稳定。Win11 64位 Office办公版(免费)优化 1、保留 Edge浏览器。 2、隐藏“操作中心”托盘图标。 3、保留常用组件(微软商店,计算器,图片查看器等)。 5、关闭天气资讯。
Win11 21H2 官方正式版下载_Win11 21H2最新系统免激活下载
语言:中文版系统大小:4.75GB系统类型:Win11Ghost Win11 21H2是微软在系统方面技术积累雄厚深耕多年,Ghost Win11 21H2系统在家用办公上跑分表现都是非常优秀,完美的兼容各种硬件和软件,运行环境安全可靠稳定。Ghost Win11 21H2是微软最新发布的KB5019961补丁升级而来的最新版的21H2系统,以Windows 11 21H2 22000 1219 专业版为基础进行优化,保持原汁原味,系统流畅稳定,保留常用组件
windows11中文版镜像 微软win11正式版简体中文GHOST ISO镜像64位系统下载
语言:中文版系统大小:5.31GB系统类型:Win11windows11中文版镜像 微软win11正式版简体中文GHOST ISO镜像64位系统下载,微软win11发布快大半年了,其中做了很多次补丁和修复一些BUG,比之前的版本有一些功能上的调整,目前已经升级到最新版本的镜像系统,并且优化了自动激活,永久使用。windows11中文版镜像国内镜像下载地址微软windows11正式版镜像 介绍:1、对函数算法进行了一定程度的简化和优化
微软windows11正式版GHOST ISO镜像 win11下载 国内最新版渠道下载
语言:中文版系统大小:5.31GB系统类型:Win11微软windows11正式版GHOST ISO镜像 win11下载 国内最新版渠道下载,微软2022年正式推出了win11系统,很多人迫不及待的要体验,本站提供了最新版的微软Windows11正式版系统下载,微软windows11正式版镜像 是一款功能超级强大的装机系统,是微软方面全新推出的装机系统,这款系统可以通过pe直接的完成安装,对此系统感兴趣,想要使用的用户们就快来下载
微软windows11系统下载 微软原版 Ghost win11 X64 正式版ISO镜像文件
语言:中文版系统大小:0MB系统类型:Win11微软Ghost win11 正式版镜像文件是一款由微软方面推出的优秀全新装机系统,这款系统的新功能非常多,用户们能够在这里体验到最富有人性化的设计等,且全新的柔软界面,看起来非常的舒服~微软Ghost win11 正式版镜像文件介绍:1、与各种硬件设备兼容。 更好地完成用户安装并有效地使用。2、稳定使用蓝屏,系统不再兼容,更能享受无缝的系统服务。3、为
雨林木风Windows11专业版 Ghost Win11官方正式版 (22H2) 系统下载
语言:中文版系统大小:4.75GB系统类型:雨林木风Windows11专业版 Ghost Win11官方正式版 (22H2) 系统下载在系统方面技术积累雄厚深耕多年,打造了国内重装系统行业的雨林木风品牌,其系统口碑得到许多人认可,积累了广大的用户群体,雨林木风是一款稳定流畅的系统,一直以来都以用户为中心,是由雨林木风团队推出的Windows11国内镜像版,基于国内用户的习惯,做了系统性能的优化,采用了新的系统
雨林木风win7旗舰版系统下载 win7 32位旗舰版 GHOST 免激活镜像ISO
语言:中文版系统大小:5.91GB系统类型:Win7雨林木风win7旗舰版系统下载 win7 32位旗舰版 GHOST 免激活镜像ISO在系统方面技术积累雄厚深耕多年,加固了系统安全策略,雨林木风win7旗舰版系统在家用办公上跑分表现都是非常优秀,完美的兼容各种硬件和软件,运行环境安全可靠稳定。win7 32位旗舰装机版 v2019 05能够帮助用户们进行系统的一键安装、快速装机等,系统中的内容全面,能够为广大用户
相关文章
- Windows10系统下SD卡打开不了怎样办?
- win7系统电脑对u盘格式化操作时提示“windows无法完成格式化”解决方法-系统城
- 苹果笔记本电脑怎么重装系统步骤教程
- 怎样使用USB3.0的U盘装Win7
- win8电脑硬盘读写频率太高的解决方法
- 专为炒股人士而设 同花顺炒股Win8版体验
- win7硬盘怎么分区 win7电脑硬盘分区步骤【图文教程】
- 怎样自动安装win7系统?win7自动安装系统步骤
- 注册表打开不了怎样办?XP系统下regedit打开不了注册表怎样办?
- 教你win7中怎么清除如何清理win7最近的文档文档历史记录
- 微信支付实名认证的办法介绍_微信
- windows8系统之家纯净版下载
- U盘连接XP系统电脑能识别但不显示怎样办?
- Win8本地连接在啥地方?Win8怎样打开本地连接?
- U盘文件无故失去的因素及处理办法
- 电脑蓝屏代码0x0000007A怎么办?电脑蓝屏代码0x0000007A解决办法
- 迅雷怎么举报有害信息?迅雷X有害信息举报方法
- XP怎样修好开机引导?XP修好开机引导的具体办法
热门系统
- 1华硕笔记本&台式机专用系统 GhostWin7 32位正式旗舰版2018年8月(32位)ISO镜像下载
- 2深度技术 Windows 10 x86 企业版 电脑城装机版2018年10月(32位) ISO镜像免费下载
- 3电脑公司 装机专用系统Windows10 x86喜迎国庆 企业版2020年10月(32位) ISO镜像快速下载
- 4深度技术 Windows 10 x86 企业版 六一节 电脑城装机版 版本1903 2022年6月(32位) ISO镜像免费下载
- 5雨林木风 Ghost Win7 SP1 装机版 2020年4月(32位) 提供下载
- 6深度技术 Windows 10 x64 企业版 电脑城装机版2021年1月(64位) 高速下载
- 7新萝卜家园电脑城专用系统 Windows10 x64 企业版2019年10月(64位) ISO镜像免费下载
- 8新萝卜家园 GhostWin7 SP1 最新电脑城极速装机版2018年8月(32位)ISO镜像下载
- 9电脑公司Ghost Win8.1 x32 精选纯净版2022年5月(免激活) ISO镜像高速下载
- 10新萝卜家园Ghost Win8.1 X32 最新纯净版2018年05(自动激活) ISO镜像免费下载
热门文章
常用系统
- 1新雨林木风 Windows10 x64 企业装机版2018年8月(64位)快速版IS下载
- 2正版Win10官网下载_微软官方Win10 64位正版系统下载
- 3番茄花园 GHOST XP SP3 正式免激活版 V2023.08 下载
- 4系统之家 GHOST XP SP3 纯净版 V2014.12 下载
- 5Ghost Win8 32位专业版下载_Ghost Win8 32位精简版系统下载
- 6深度技术Ghost Win10 x64 免费专业版v2023.05最新下载
- 7新萝卜家园电脑城专用系统 Windows10 x86 企业版 版本1507 2022年5月(32位) ISO镜像高速下载
- 8萝卜家园 GHOST XP SP3 经典旗舰版 V2018.10 下载
- 9Ghost Win10激活镜像文件下载_电脑公司Ghost Win10 64位专业激活版下载
- 10深度技术GHOST WIN10 极速专业版 v2023.04最新版下载