WinDbg排查CPU高的問題

来源:https://www.cnblogs.com/mojinxun/archive/2020/05/21/12931223.html
-Advertisement-
Play Games

一、概述 在Window伺服器部署程式後,可能因為代碼的不合理或者其他各種各樣的問題,會導致CPU暴增,甚至達到100%等情況,嚴重危及到伺服器的穩定以及系統穩定,但是一般來說對於已發佈的程式,沒法即時看到出問題的代碼,而微軟提供了一個很好的工具“WinDbg”,使得我們能夠回溯問題。下麵講一下操作 ...


一、概述

在Window伺服器部署程式後,可能因為代碼的不合理或者其他各種各樣的問題,會導致CPU暴增,甚至達到100%等情況,嚴重危及到伺服器的穩定以及系統穩定,但是一般來說對於已發佈的程式,沒法即時看到出問題的代碼,而微軟提供了一個很好的工具“WinDbg”,使得我們能夠回溯問題。下麵講一下操作步驟。

 

二、操作步驟

1. 下載軟體:

  下載地址:https://docs.microsoft.com/zh-cn/windows-hardware/drivers/debugger/debugger-download-tools

  

 

2. 安裝

  只需要選擇:Debugging Tools for Windows 即可。  

  

 

3. EXE位置

  {安裝目錄}/Debugger/{x64 || x86}/windbg.exe

 

4. 獲取DMP文件

(1)打開任務管理器

(2)選擇CPU較高的進程

(3)右鍵“創建轉儲文件”

(4)獲取最後的目錄位置,拿到DMP文件即可

  

 

5. 查看有問題的進程(已準備w3wp.DMP文件)

(1)打開windbg.exe

(2)將w3wp.DMP 拖入視窗

(3)輸入指令載入sos clr

  .loadby sos clr

(4)檢查clr版本是否一致

  !clrstack

  下圖表示clr不存在或者版本不一致

  

 

  

  這個時候就需要將DMP文件所在伺服器的sos.dll clr.dll mscordacwks.dll 三個dll拷貝下來,所在位置:C:\Windows\Microsoft.NET\Framework?\version?\SOS.dll 同目錄下

  放到一個目錄中:【D:\windb\dll】,以下指令用於指定對應的sos.dll,clr.dll

  .cordll -lp D:\windb\dll

  

 

(5)獲取執行時間很長的線程

  !runaway

  

  可以看到前幾個線程執行了很長時間沒有結束掉,那麼我們就進入這個線程,查看具體的堆棧信息

(6)進入線程

  ~{threadId}s => ~61s

  

 

(7)查看堆棧信息

  !clrstack

  

  上圖即可看到對應的一些自定義的代碼,即可根據這些代碼分析哪塊代碼寫得不合理,也還可以點擊進入查看詳細的信息

  

 

 

6. 以上為簡單的查看CPU過高的簡單解決方案案例,對於WinDbg的相關指令可以使用搜索引擎進行搜索學習。以下附上一些文章:

 

 

https://blog.csdn.net/iwilldoitx/article/details/81048500

 

https://www.cnblogs.com/huangsitao/p/10299300.html

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在 Office 文檔的一些有趣的設計,顏色和畫刷是可以繼承的,這個繼承包括了屬性的繼承。在形狀填充裡面使用的漸變色是可以一部分屬性放在主題裡面,主要找到主題裡面的畫刷,替換掉形狀自己定義的內容,才是形狀的畫刷 ...
  • 之前版本是通過安裝 Blend SDK 支持 Behaviors 庫的,但是這個方法都是通過引用 dll 的方式,不夠優雅。在升級到 dotnet core 3.0 的時候就需要使用 WPF 官方團隊開源的 Microsoft.Xaml.Behaviors.Wpf 庫代替 ...
  • 本文用的是 世紀互聯 的 Azure.cn 版本,這個版本因為是在國內,所以網速會快超級超級多。使用 世紀互聯 的版本需要一塊錢哦,用一塊錢就能進入一個月的免費試用。本文主要告訴小伙伴如何使用 Azure 無伺服器 Function 函數計算服務 ...
  • 本文主要是來安利大家基於 Azure 的認知服務,主要是文本認知服務,可以做到分析輸入文本的情緒,以及判斷當前輸入文本所屬語言等功能 ...
  • 在一個白板類應用的交互中一定會涉及到模式之間的更換和交互衝突。白板類軟體的交互模式一般包含了筆跡書寫模式,選擇模式,擦除筆跡模式等。多個模式之間存在切換,而切換可以發生在某個模式執行過程,如需要在白板軟體裡面支持筆跡書寫功能,在書寫的過程打斷進入筆跡的擦除模式。本文告訴大家我所在團隊的白板內核的模式... ...
  • 前言 預設的 index.html 顯示的 Loading 太簡陋了. 而且沒有載入進度條. 所以做了一個. 代碼地址 : https://github.com/BlazorPlus/BlazorDemoWasmLoading 只需要改 index. html <!DOCTYPE html> <ht ...
  • 近年來,企業管理軟體開發領域掀起了一陣快速開發平臺的風氣,很多人覺得這是開發界有人帶的節奏,很快就會消失了,軟體開發應該回歸最真實的代碼之中。 不過隨著時間的推移,越來越多的企業認識到快速開發平臺的重要性,相比於傳統的代碼式開發風格,快速開發平臺的優勢體現的淋漓盡致。 傳統開發平臺最突出的特點就是開 ...
  • 背景:我們的應用程式通常都是由多個程式集組成,例如一個 exe 程式依賴於多個 dll 程式集。在某些情況下,我們希望程式的分發能夠簡單,單獨一個 exe 就能正常運行。這種情況下,就需要將 dll 依賴項合併到 exe 主程式中。 本文章給大家講下非常好用的NuGet 包,Costura.Fody ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...