Docker 中的 .NET 異常了怎么抓 Dump|當(dāng)前獨(dú)家
有很多朋友跟我說(shuō),在 Windows 上看過(guò)你文章知道了怎么抓 Crash, CPU爆高,內(nèi)存暴漲 等各種Dump,為什么你沒(méi)有寫(xiě)在 Docker 中如何抓的相關(guān)文章呢?瞧不上嗎?
(相關(guān)資料圖)
哈哈,在DUMP的分析旅程中,跑在 Docker 中的 .NET 占比真的不多,大概10個(gè)dump有 1-2 個(gè)是 docker 中的,市場(chǎng)決定了我的研究方向,為了彌補(bǔ)這一塊的空洞,決定寫(xiě)一篇文章來(lái)分享下這三大異常下的捕獲吧。
二:Docker 下的三大異常捕獲1. crash dump 捕獲前不久我寫(xiě)了一篇 Linux 上的 .NET 崩潰了怎么抓 Dump (https://www.cnblogs.com/huangxincheng/p/17440153.html)
的文章,使用了微軟推薦的環(huán)境變量方式,其實(shí)這在 Docker 中是一樣適用的。
為了讓 webapi
崩潰退出,我故意造一個(gè)棧溢出異常,參考代碼如下:
public class Program { public static void Main(string[] args) { var builder = WebApplication.CreateBuilder(args); builder.Services.AddAuthorization(); var app = builder.Build(); app.UseAuthorization(); //1. crash Task.Factory.StartNew(() => { Test("a"); }); app.Run(); } public static string Test(string a) { return Test("a" + a.Length); } }
有了代碼之后,接下來(lái)寫(xiě)一個(gè) Dockerfile,主要就是把三個(gè)環(huán)境變量
塞進(jìn)去。
FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS runtimeWORKDIR /appCOPY ./ ./# 1. 使用中科大鏡像源RUN sed -i "s/deb.debian.org/mirrors.ustc.edu.cn/g" /etc/apt/sources.listENV COMPlus_DbgMiniDumpType 4ENV COMPlus_DbgMiniDumpName /dumps/%p-%e-%h-%t.dmpENV COMPlus_DbgEnableMiniDump 1ENTRYPOINT ["dotnet", "AspNetWebApi.dll"]
這里有一個(gè)細(xì)節(jié),為了能夠讓 Docker 中的 webapi 能夠訪問(wèn)到,將 localhost 設(shè)置為 * ,修改 appsettings.json
如下:
{ "urls": "http://*:5001", "Logging": { "LogLevel": { "Default": "Information", "Microsoft.AspNetCore": "Warning" } }, "AllowedHosts": "*"}
有了這些基礎(chǔ)最后就是 docker build & docker run 啦。
[root@localhost data]# docker build -t aspnetapp .[+] Building 0.3s (9/9) FINISHED => [internal] load build definition from Dockerfile 0.0s => => transferring dockerfile: 447B 0.0s => [internal] load .dockerignore 0.0s => => transferring context: 2B 0.0s => [internal] load metadata for mcr.microsoft.com/dotnet/aspnet:6.0 0.3s => [1/4] FROM mcr.microsoft.com/dotnet/aspnet:6.0@sha256:a2a04325fdb2a871e964c89318921f82f6435b54 0.0s => [internal] load build context 0.0s => => transferring context: 860B 0.0s => CACHED [2/4] WORKDIR /app 0.0s => CACHED [3/4] COPY ./ ./ 0.0s => CACHED [4/4] RUN sed -i "s/deb.debian.org/mirrors.ustc.edu.cn/g" /etc/apt/sources.list 0.0s => exporting to image 0.0s => => exporting layers 0.0s => => writing image sha256:be69203995c0e5423b2af913549e618d7ee8306fff3961118ff403b1359ae571 0.0s => => naming to docker.io/library/aspnetapp 0.0s[root@localhost data]# docker run -itd -p 5001:5001 --privileged -v /data2:/dumps --name aspnetcore_sample aspnetappca34c9274d998096f8562cbef3a43a7cbd9aa5ff2923e0f3e702b159e0b2f447[root@localhost data]# docker ps -aCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMESca34c9274d99 aspnetapp "dotnet AspNetWebApi…" 20 seconds ago Exited (139) 9 seconds ago aspnetcore_sample[root@localhost data]# docker logs ca34c9274d99 ... at AspNetWebApi.Program.Test(System.String) at AspNetWebApi.Program.Test(System.String) at AspNetWebApi.Program.Test(System.String) at AspNetWebApi.Program.Test(System.String) at AspNetWebApi.Program+<>c.b__0_0() at System.Threading.Tasks.Task.InnerInvoke() at System.Threading.Tasks.Task+<>c.<.cctor>b__272_0(System.Object) at System.Threading.ExecutionContext.RunFromThreadPoolDispatchLoop(System.Threading.Thread, System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object) at System.Threading.Tasks.Task.ExecuteWithThreadLocal(System.Threading.Tasks.Task ByRef, System.Threading.Thread) at System.Threading.Tasks.Task.ExecuteEntryUnsafe(System.Threading.Thread) at System.Threading.ThreadPoolWorkQueue.Dispatch() at System.Threading.PortableThreadPool+WorkerThread.WorkerThreadStart() at System.Threading.Thread.StartCallback()[createdump] Gathering state for process 1 dotnet[createdump] Crashing thread 0017 signal 6 (0006)[createdump] Writing full dump to file /dumps/1-dotnet-ca34c9274d99-1687746929.dmp[createdump] Written 261320704 bytes (63799 pages) to core file[createdump] Target process is alive[createdump] Dump successfully written[root@localhost data2]# cd /data2[root@localhost data2]# ls -lntotal 255288-rw-------. 1 0 0 261414912 Jun 26 10:35 1-dotnet-ca34c9274d99-1687746929.dmp
上面的腳本已經(jīng)寫(xiě)的非常清楚了,這里有幾個(gè)注意點(diǎn)提一下:
--privileged一定要加上特殊權(quán)限,否則生成 dump 的時(shí)候會(huì)提示無(wú)權(quán)限。
-v /data2:/dumps防止dump丟失,記得掛載到宿主機(jī)目錄 或者 共享容器 中。
2. 內(nèi)存暴漲 dump 捕獲要想對(duì) docker 中的 .NET 程序內(nèi)存 進(jìn)行監(jiān)控,我一直都是極力推薦 procdump
,目前最新的是版本是 1.5
, github官網(wǎng)地址: https://github.com/Sysinternals/ProcDump-for-Linux 鑒于現(xiàn)在訪問(wèn) github 太慢,大家可以把 procdump_1.5-16239_amd64.deb
下載到本地,為什么下載它,是因?yàn)槿萜髦惺?debain 系統(tǒng)。
下載好了之后放到項(xiàng)目中,使用默認(rèn)代碼骨架:
public class Program { public static void Main(string[] args) { var builder = WebApplication.CreateBuilder(args); builder.Services.AddAuthorization(); var app = builder.Build(); app.UseAuthorization(); app.Run(); } }
接下來(lái)就是寫(xiě) dockerfile 了,這里有一個(gè)細(xì)節(jié),就是如何在 Docker 中開(kāi)啟多進(jìn)程,這里用 start.sh 腳本的方式開(kāi)啟,參考代碼如下:
FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS runtimeWORKDIR /appCOPY ./ ./# 1. 使用中科大鏡像源RUN sed -i "s/deb.debian.org/mirrors.ustc.edu.cn/g" /etc/apt/sources.list# 2. 安裝 gdb & procdumpRUN apt-get update && apt-get install -y gdbRUN dpkg -i procdump.debRUN echo "#!/bin/bash \n\procdump -m 30 -w dotnet /dumps & \n\dotnet \$1 \n\" > ./start.shRUN chmod +x ./start.shENTRYPOINT ["./start.sh", "AspNetWebApi.dll"]
有了這些設(shè)置后,接下來(lái)就是 publish 代碼用 docker 構(gòu)建啦,為了方便演示,這里就用 前臺(tái)模式
開(kāi)啟了哈。
[root@localhost data]# docker build -t aspnetapp .[+] Building 11.5s (13/13) FINISHED [root@localhost data]# docker rm -f aspnetcore_sampleaspnetcore_sample[root@localhost data]# docker run -it --rm -p 5001:5001 --privileged -v /data2:/dumps --name aspnetcore_sample aspnetappProcDump v1.5 - Sysinternals process dump utilityCopyright (C) 2023 Microsoft Corporation. All rights reserved. Licensed under the MIT license.Mark Russinovich, Mario Hewardt, John Salem, Javid HabibiSysinternals - www.sysinternals.comMonitors one or more processes and writes a core dump file when the processes exceeds thespecified criteria.[02:57:34 - INFO]: Waiting for processes "dotnet" to launch[02:57:34 - INFO]: Press Ctrl-C to end monitoring without terminating the process(es).Process Name: dotnetCPU Threshold: n/aCommit Threshold: >=30 MBThread Threshold: n/aFile Descriptor Threshold: n/aSignal: n/aException monitor OffPolling Interval (ms): 1000Threshold (s): 10Number of Dumps: 1Output directory: /dumps[02:57:34 - INFO]: Starting monitor for process dotnet (9)info: Microsoft.Hosting.Lifetime[14] Now listening on: http://[::]:5001info: Microsoft.Hosting.Lifetime[0] Application started. Press Ctrl+C to shut down.info: Microsoft.Hosting.Lifetime[0] Hosting environment: Productioninfo: Microsoft.Hosting.Lifetime[0] Content root path: /app/[02:57:35 - INFO]: Trigger: Commit usage:48MB on process ID: 9[createdump] Gathering state for process 9 dotnet[createdump] Writing full dump to file /dumps/dotnet_commit_2023-06-26_02:57:35.9[createdump] Written 254459904 bytes (62124 pages) to core file[createdump] Target process is alive[createdump] Dump successfully written[02:57:35 - INFO]: Core dump 0 generated: /dumps/dotnet_commit_2023-06-26_02:57:35.9[02:57:36 - INFO]: Stopping monitors for process: dotnet (9)[root@localhost data2]# ls -lhtotal 243M-rw-------. 1 root root 243M Jun 26 10:57 dotnet_commit_2023-06-26_02:57:35.9
從腳本信息看,當(dāng)內(nèi)存到了 48MB
的時(shí)候觸發(fā)的 dump 生成,也成功的進(jìn)入了 /dumps
目錄中,太棒了。
抓 cpu 爆高的dump最好的方式就是多抓幾個(gè),比如說(shuō):當(dāng) CPU >20% 連續(xù)超過(guò) 5s 抓 2個(gè)dump,這種方式抓的dump很容易就能找到真兇,為了方便演示,讓兩個(gè) cpu 直接打滿,參考代碼如下:
public static void Main(string[] args) { var builder = WebApplication.CreateBuilder(args); builder.Services.AddAuthorization(); var app = builder.Build(); app.UseAuthorization(); //3. cpu app.MapGet("/cpu", (HttpContext httpContext) => { Task.Factory.StartNew(() => { bool b = true; while (true) { b = !b; } }); Task.Factory.StartNew(() => { bool b = true; while (true) { b = !b; } }); return new WeatherForecast(); }); app.Run(); }
接下來(lái)就是修改 dockerfile,因?yàn)槲业奶摂M機(jī)是 8 核心,如果兩個(gè)核心被打滿,那應(yīng)該會(huì)占用大概 24% 的 cpu 利用率,所以腳本中就設(shè)置 20% 吧。
FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS runtimeWORKDIR /appCOPY ./ ./# 1. 使用中科大鏡像源RUN sed -i "s/deb.debian.org/mirrors.ustc.edu.cn/g" /etc/apt/sources.list# 2. 安裝 wgetRUN apt-get update && apt-get install -y gdbRUN dpkg -i procdump.debRUN echo "#!/bin/bash \n\procdump -c 20 -n 2 -s 5 -w dotnet /dumps & \n\dotnet \$1 \n\" > ./start.shRUN chmod +x ./start.shENTRYPOINT ["./start.sh", "AspNetWebApi.dll"]
最后就是 docker 構(gòu)建。
[root@localhost data]# docker build -t aspnetapp .[+] Building 0.4s (13/13) FINISHED[root@localhost data]# docker run -it --rm -p 5001:5001 --privileged -v /data2:/dumps --name aspnetcore_sample aspnetappProcDump v1.5 - Sysinternals process dump utilityCopyright (C) 2023 Microsoft Corporation. All rights reserved. Licensed under the MIT license.Mark Russinovich, Mario Hewardt, John Salem, Javid HabibiSysinternals - www.sysinternals.comMonitors one or more processes and writes a core dump file when the processes exceeds thespecified criteria.[03:35:56 - INFO]: Waiting for processes "dotnet" to launch[03:35:56 - INFO]: Press Ctrl-C to end monitoring without terminating the process(es).Process Name: dotnetCPU Threshold: >= 20%Commit Threshold: n/aThread Threshold: n/aFile Descriptor Threshold: n/aSignal: n/aException monitor OffPolling Interval (ms): 1000Threshold (s): 5Number of Dumps: 2Output directory: /dumps[03:35:56 - INFO]: Starting monitor for process dotnet (8)info: Microsoft.Hosting.Lifetime[14] Now listening on: http://[::]:5001info: Microsoft.Hosting.Lifetime[0] Application started. Press Ctrl+C to shut down.info: Microsoft.Hosting.Lifetime[0] Hosting environment: Productioninfo: Microsoft.Hosting.Lifetime[0] Content root path: /app/
看輸出是正在監(jiān)控,接下來(lái)我們?cè)L問(wèn)下網(wǎng)址: http://192.168.17.129:5001/cpu
,稍等片刻之后就會(huì)生成兩個(gè)dump 文件。
雖然Docker中的 .NET 程序占比較少,但把經(jīng)驗(yàn)總結(jié)出來(lái)還是很值得的,以后有人問(wèn)怎么抓,可以把這篇文章直接丟過(guò)去啦!
關(guān)鍵詞:
您可能也感興趣:
今日熱點(diǎn)
為您推薦
焦點(diǎn)日?qǐng)?bào):懷進(jìn)鵬為教育部直屬機(jī)關(guān)全體黨員干部講專題黨課
蔡徐坤商業(yè)版圖盤(pán)點(diǎn) 蔡徐坤 C女士打胎
理財(cái)產(chǎn)品“踩剎車”?債市不具備大跌的基礎(chǔ)
更多
- 16 條河流 22 個(gè)站出現(xiàn)超警洪水,廣西繼續(xù)發(fā)布藍(lán)色預(yù)警
- 英特科技:6月21日融資買入1712.71萬(wàn)元,融資融券余額6187.15...
- 熱資訊!天津市工商網(wǎng)站查詢企業(yè)信息(天津市工商網(wǎng))
- 天津治療白癜風(fēng)醫(yī)院哪里正規(guī)_女性白癜風(fēng)的早期癥狀有哪些? ...
- 全球要聞:強(qiáng)化“高”“新”引領(lǐng),做優(yōu)做強(qiáng)中山火炬開(kāi)發(fā)區(qū)創(chuàng)...
- 美國(guó)印第安納州遭龍卷風(fēng)襲擊:多處房屋被毀,已致1人死亡
- 前5月多地財(cái)政收入恢復(fù)性增長(zhǎng) 開(kāi)源節(jié)流應(yīng)對(duì)收支緊平衡
- excel曲線圖怎么做趨勢(shì)線(excel曲線圖怎么做) 熱消息
排行
- Docker 中的 .NET 異常了怎么抓 Dump|當(dāng)前獨(dú)家
- 古裝劇雷同現(xiàn)實(shí)劇抬頭 "腦洞劇"走紅反映觀眾訴求
- 來(lái)不及減肥也可以瘦5斤
- 南京老舊小區(qū)增梯 已有1463部簽訂協(xié)議
- 2018型男們的選包方案!
- 新房裝好一年多墻壁脫落
- 制造行業(yè)升級(jí)大勢(shì)所趨 可加速制造強(qiáng)國(guó)建設(shè)步伐
- 我國(guó)首個(gè)海上智能氣田群——東方氣田群全面建成
- 全新智能產(chǎn)業(yè)體系建立,中國(guó)智能產(chǎn)業(yè)將邁上更高的臺(tái)階
- 上海浦東新區(qū)人工智能技能大賽舉行
最近更新
- Docker 中的 .NET 異常了怎么抓 Dump|當(dāng)前獨(dú)家
- 拔火罐的好處和壞處有哪些?正常拔罐幾天一次最好?
- 全球信息:適合小學(xué)生看的英語(yǔ)動(dòng)畫(huà)片_適合小學(xué)生看的動(dòng)畫(huà)片
- 國(guó)家疾控局等11部門(mén)發(fā)布方案,加快實(shí)現(xiàn)消除血吸蟲(chóng)病-世界最資訊
- 世界球精選!夏日限時(shí)美景|綠色山脈與潞黨參相映成趣
- 小圓鏡有什么危害(后視鏡小圓鏡有害處嗎?)-環(huán)球快訊
- 醫(yī)渡科技(02158)糖尿病數(shù)字療法產(chǎn)品通過(guò)FDA審批 當(dāng)前快看
- 我在鄭州拍文物|路標(biāo)_全球新消息
- 最新工資價(jià)位表來(lái)了!你是什么段位?
- 315曝光玉蕾橄欖菜環(huán)保違法被罰33萬(wàn) 玉蕾橄欖菜公司已被罰沒(méi)數(shù)百萬(wàn)
- 袁瀟洋:虛擬電廠將轉(zhuǎn)變電力調(diào)度的機(jī)制從而提升電網(wǎng)韌性_環(huán)球...
- 海關(guān)總署:我國(guó)毒情形勢(shì)持續(xù)改善 2022年海關(guān)查獲各類毒品5.3噸
- 氣溫攀升,儲(chǔ)能如何助力“降峰”-每日熱門(mén)
- LOTTO 非常值得關(guān)注的鞋子品牌
- 環(huán)球?qū)崟r(shí):高血壓患者可以吃辣椒嗎?無(wú)論可不可以,另外這3種...
- 環(huán)球訊息:「港股異動(dòng)」李寧(02331.HK)跌3.03%
- 公安部公布六起非法占用耕地犯罪典型案例
- 綻放指間的工藝,在一鏨一刻中傳承畬族銀器之美|天天微資訊
- 最高檢披露麻醉藥品、精神藥品失管涉毒問(wèn)題多發(fā)原因
- 當(dāng)前熱文:甘肅酒泉一餐飲店高壓鍋爆炸致2傷
- 仰臥起坐能減掉肚子上的贅肉嗎?肚子抽脂肪多少錢一次?
- 世界最新:第四屆中國(guó)賀州國(guó)際石材·碳酸鈣展覽會(huì)即將啟幕
- 每日簡(jiǎn)訊:鐵路端午小長(zhǎng)假運(yùn)輸發(fā)送旅客7037.9萬(wàn)人次
- “瓦格納”沒(méi)有牽動(dòng)金融市場(chǎng)神經(jīng)?華爾街:情況不明,后市未定
- iPhone 15至少漲價(jià)2000 變化巨大
- 魅族20 PRO 無(wú)界版不僅僅為了提升設(shè)計(jì)這么簡(jiǎn)單 | 吳佩頻道
- 天天快消息!曾風(fēng)靡全國(guó),如今卻被螺螄粉吊打:紅極一時(shí)的“...
- 「港股異動(dòng)」康方生物(09926.HK)漲4.66%_環(huán)球要聞
- 從端午產(chǎn)業(yè)“三變”看消費(fèi)市場(chǎng)活力
- 尋子22年的“雷公”,與兒子DNA復(fù)核成功!-消息
今日要聞
- 工商銀行兔年金條100g價(jià)格今天多少一克(2023年06月26日)_天天觀速訊
- “5G-A URLLC+汽車制造”,華為跑出工業(yè)數(shù)智轉(zhuǎn)型的新加速度
- CMM三坐標(biāo)測(cè)量?jī)x對(duì)產(chǎn)品質(zhì)量檢驗(yàn) 每日熱議
- 萊音珠寶鉑金多少錢一克(2023年06月26日)參考價(jià)格
- 《暗黑破壞神4》?德魯伊閃電快打狼bd構(gòu)筑思路 閃電快打狼怎么玩?
- 16 條河流 22 個(gè)站出現(xiàn)超警洪水,廣西繼續(xù)發(fā)布藍(lán)色預(yù)警
- 世界即時(shí):魚(yú)油行業(yè)市場(chǎng)到底多大?魚(yú)油行業(yè)市場(chǎng)深度分析2023
- 內(nèi)蒙古發(fā)生重大刑事案件 事發(fā)地有村民稱犯罪嫌疑人是村主任 最新
- 天天快資訊丨微pe工具箱cgi備份還原方法
- 李彥宏:大模型是當(dāng)下全球科技創(chuàng)新焦點(diǎn)