成人sese/国产免费人成视频在线观看/九色 在线/免费观看又色又爽又黄的/啪在线视频/日日做日日摸夜夜爽

首頁 智能 > 正文

Docker 中的 .NET 異常了怎么抓 Dump|當前獨家

一:背景1. 講故事

有很多朋友跟我說,在 Windows 上看過你文章知道了怎么抓 Crash, CPU爆高,內存暴漲 等各種Dump,為什么你沒有寫在 Docker 中如何抓的相關文章呢?瞧不上嗎?


(相關資料圖)

哈哈,在DUMP的分析旅程中,跑在 Docker 中的 .NET 占比真的不多,大概10個dump有 1-2 個是 docker 中的,市場決定了我的研究方向,為了彌補這一塊的空洞,決定寫一篇文章來分享下這三大異常下的捕獲吧。

二:Docker 下的三大異常捕獲1. crash dump 捕獲

前不久我寫了一篇 Linux 上的 .NET 崩潰了怎么抓 Dump (https://www.cnblogs.com/huangxincheng/p/17440153.html)的文章,使用了微軟推薦的環境變量方式,其實這在 Docker 中是一樣適用的。

為了讓 webapi崩潰退出,我故意造一個棧溢出異常,參考代碼如下:

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);        }    }

有了代碼之后,接下來寫一個 Dockerfile,主要就是把三個環境變量塞進去。

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"]

這里有一個細節,為了能夠讓 Docker 中的 webapi 能夠訪問到,將 localhost 設置為 * ,修改 appsettings.json如下:

{  "urls": "http://*:5001",  "Logging": {    "LogLevel": {      "Default": "Information",      "Microsoft.AspNetCore": "Warning"    }  },  "AllowedHosts": "*"}

有了這些基礎最后就是 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

上面的腳本已經寫的非常清楚了,這里有幾個注意點提一下:

--privileged

一定要加上特殊權限,否則生成 dump 的時候會提示無權限。

-v /data2:/dumps

防止dump丟失,記得掛載到宿主機目錄 或者 共享容器 中。

2. 內存暴漲 dump 捕獲

要想對 docker 中的 .NET 程序內存 進行監控,我一直都是極力推薦 procdump,目前最新的是版本是 1.5, github官網地址: https://github.com/Sysinternals/ProcDump-for-Linux 鑒于現在訪問 github 太慢,大家可以把 procdump_1.5-16239_amd64.deb下載到本地,為什么下載它,是因為容器中是 debain 系統。

下載好了之后放到項目中,使用默認代碼骨架:

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();        }    }

接下來就是寫 dockerfile 了,這里有一個細節,就是如何在 Docker 中開啟多進程,這里用 start.sh 腳本的方式開啟,參考代碼如下:

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"]

有了這些設置后,接下來就是 publish 代碼用 docker 構建啦,為了方便演示,這里就用 前臺模式開啟了哈。

[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

從腳本信息看,當內存到了 48MB的時候觸發的 dump 生成,也成功的進入了 /dumps目錄中,太棒了。

3. cpu爆高 dump 捕獲

抓 cpu 爆高的dump最好的方式就是多抓幾個,比如說:當 CPU >20% 連續超過 5s 抓 2個dump,這種方式抓的dump很容易就能找到真兇,為了方便演示,讓兩個 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();        }

接下來就是修改 dockerfile,因為我的虛擬機是 8 核心,如果兩個核心被打滿,那應該會占用大概 24% 的 cpu 利用率,所以腳本中就設置 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 構建。

[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/

看輸出是正在監控,接下來我們訪問下網址: http://192.168.17.129:5001/cpu,稍等片刻之后就會生成兩個dump 文件。

三:總結

雖然Docker中的 .NET 程序占比較少,但把經驗總結出來還是很值得的,以后有人問怎么抓,可以把這篇文章直接丟過去啦!

關鍵詞:

最近更新

關于本站 管理團隊 版權申明 網站地圖 聯系合作 招聘信息

Copyright © 2005-2023 創投網 - m.zhigu.net.cn All rights reserved
聯系我們:39 60 29 14 2@qq.com
皖ICP備2022009963號-3

主站蜘蛛池模板: 又爽又黄又无遮掩的免费视频 | 视频一区二区无码制服师生 | 日韩国产成人无码av毛片蜜柚 | 亚洲精品成人在线播放 | 性欧美欧美巨大69 | 国产成人一区二区三区 | 少妇性荡欲视频 | 国产永久在线观看 | 国产亚洲曝欧美不卡精品 | 97精品国产一区二区三区 | 久久精品欧美一区二区 | 欧美不卡视频在线 | 成人欧美一区二区三区的电影 | 精品无码人妻一区二区三区 | 日韩欧美视频在线免费观看 | 日韩一级黄色大片 | 无码人妻一区二区三区在线 | 久久九九网站 | 精品国偷自产国产一区 | 日本xxxx小便xxxx偷拍 | 久久无码潮喷a片无码高潮 欧美成人视屏 | 亚洲www啪成人一区二区 | 国产精品一区二区在线免费观看 | 免费无码黄动漫十八禁 | 亚洲国产成人精品久久久国产成人一区 | 激情小说亚洲图片 | 少妇人妻偷人精品视频 | 欧美日韩一区二区精品 | 久久久久久九九99精品 | 久久精品视频国产 | 国产九九九九 | 日韩欧美在线观看一区二区视频 | 日韩中文字幕在线一区二区三区 | 欧美州大乳艳妇裸体 | 欧美最大胆的西西人体44 | 日本黄色天堂 | 免费一级欧美片在线播放 | 亚洲国产精品久久久天堂 | 亚洲成a人v欧美综合天堂下载 | 曰批免费视频播放免费 | 久久草视频 | 亚洲天堂成人 | 无码全黄毛片免费看 | 亚洲a一区 | 国产不卡一 | 91视频免费在线观看 | 8x8x美女 | 欧美黄色一级片视频 | 无码少妇一区二区三区芒果 | 亚洲最大无码av网站观看 | 中文字幕精品视频 | 日韩人妻系列无码专区 | 日本韩国中文字幕 | 精品久久久久久久久久岛国gif | 日韩乱码人妻无码中文字幕视频 | 日韩在线第一 | 国产乱淫av片 | 天天操天天插 | 国产69精品久久 | 主站蜘蛛池模板: 蛛词}| 久久精品国产99精品最新 | 国产人妻精品无码av在线 | 国产精品亚洲专区无码唯爱网 | 国产成人精品日本亚洲 | 精品久久久久久无码免费 | 精品国产福利久久久 | 91精品一本久道久久丁香狠狠躁 | 在线 | 18精品免费1区2 | 免费精品一区二区三区第35 | 男女视频一区二区 | 最新av片| 精品人伦一区二区三区蜜桃网站 | 欧美乱大交xxxxx春色视频 | 人人艹在线观看 | 免费无码a片一区二三区 | av色欲无码人妻中文字幕 | 欧美成人精品福利视频 | 18禁无遮挡羞羞污污污污网站 | 美女av一区二区三区 | 亚洲精品无码久久久久久 | 色拍拍综合 | 日本中文一区 | 99久久国产综合精品五月天喷水 | 亚洲国产中文曰韩丝袜 | 日本一级淫片 | 国产精品怡红院永久免费 | 中文字幕无码免费久久9一区9 | 99久久久国产精品美女 | 国产成人片无码免费视频 | 亚洲人人爱 | 欧美乱大交做爰xxxⅹ性3 | 亚洲乱码一卡二卡卡3卡4卡 | 国产免费高清视频1l.com.com.com少 | 久久亚洲道色综合久久 | 中文字幕制服丝袜一区二区三区 | 好吊色一区二区三区 | 一区视频免费观看 | 麻豆黄色影院 | 东京热tokyo综合久久精品 | 国产成人精品999 | 免费视频福利 | 日韩免费无码成人久久久久久片 | 欧美xxxx做受欧美88bbw | 曰韩在线 | 亚洲精品网站在线观看你懂的 | 青草草在线观看 | 国产1页| 久久精品亚洲精品无码 | 最近免费中文字幕中文高清百度 | 六月激情婷婷 | 特级小箩利无码毛片 | 蜜桃av无码免费看永久 | 亚洲 小说区 图片区 都市 | 日韩两性视频 | 每日更新在线观看av | 欧洲卡一卡二卡三爱区 | 午夜精华 | 日韩欧美国产aⅴ另类 | 久久免费看a级毛毛片 | 主站蜘蛛池模板: 蛛词}| 中文乱码免费一区二区 | 色爱综合| 亚洲精品一区二区三区蜜桃久 | 欧美日韩另类小说 | 午夜精品久久久久久久无码 | 亚洲欧美精品午睡沙发 | 欧美-第1页-屁屁影院 | 巨爆乳中文字幕巨爆区巨爆乳无码 | 久久久黑人 | 伊人论坛 | av黄色在线看 | 制服丝袜亚洲中文欧美在线 | 狠狠综合亚洲综合亚洲色 | 13小箩利洗澡无码视频网站 | 亚洲人成电影在线观看影院 | 国产欧美一区二区三区另类精品 | 亚洲a成人无m网站在线 | 成人福利动态图啪啪gif看了吧 | 免费无码又爽又刺激高潮的视频 | 任你操av | 亚洲精品成人网站在线播放 | 欧美肥婆性猛交xxxxxj | 粗大猛烈进出高潮视频 | 亚洲天堂男人 | 99久久成人国产精品免费 | 亚洲熟妇av欧差aa片爽 | 亚洲激情欧美激情 | 97久久日一线二线三线 | 国内裸体无遮挡免费视频 | 婷婷狠狠久久久一本精品 | 中国一级黄色 | 任你躁在线精品免费 | 精品国产日韩亚洲一区 | 国产精品1区 | 青青草原av | 一级中文字幕 | 思思久久96热在精品国产 | 亚洲综合欧美综合 | 精品人妻系列无码人妻在线不卡 | 日本黄h兄妹h动漫一区二区三区 | 亚洲午夜不卡无码影院 | 国产人妻精品一区二区三区 | 中文日韩亚洲欧美字幕 | 大色综合色综合网站 | 又大又硬又黄又刺激的免费视频 | 亚洲日本va在线视频观看 | 国产中年夫妇高潮精品视频 | 一个人看的www片免费高清视频 | 久久久久99精品成人品 | 五月开心婷婷六月丁香婷 | se亚洲| 精品久久久久久无码专区 | 免费人成网站免费看视频 | 国产果冻豆传媒麻婆 | 99激情视频 | 久久国产精品一区二区三区 | 99久久精品国产成人一区二区 | 国产精品色片 | 黄页嫩草| 主站蜘蛛池模板: 蛛词}| 国产午夜片无码区在线观看 | 77777熟女视频在线观看 | 亚洲精品久久久久久久久久久久久久 | 夜爽8888视频在线观看 | 久久精品人妻少妇一区二区三区 | 91少妇丨porny丨 | 亚洲成a人片在线观看中文无码 | 亚欧洲乱码视频一二三区 | 永久免费的啪啪网站免费观看 | 激情久久小说 | 一级毛片黄 | 永久免费无码国产 | a黄毛片 | 淫片aaa| 国产欧美视频在线播放 | 青青草在久久免费久久免费 | 夜夜操免费视频 | 日韩高清免费在线 | 免费看片网站91 | 国产自啪精品视频网站丝袜 | 成人亚洲国产 | 亚洲欧美日韩久久 | 久久免费只有精品国产 | 日日色视频 | 亚洲精品无码av中文字幕 | 国精产品国语对白东北 | 又爽又大久久久级淫片毛片 | 亚洲黄色一区二区 | 黑人操欧美人 | 国产在线无码视频一区 | 富二代av| 国产成人精品怡红院在线观看 | 国产爆乳无码av在线播放 | 国产精品久久久久久久久搜平片 | 一边摸一边抽搐一进一出视频 | 美女脱了内裤张开腿让男人桶网站 | 国产无遮挡裸露视频免费 | 国内精品乱码卡一卡2卡三卡 | 欧美视频区高清视频播放 | 把腿张开老子臊烂你多p视频 | 亚洲乱码日产精品一二三 | 久久免费只有精品国产 | 你懂的在线看 | 好吊妞人成视频在线观看27du | 交视频在线播放 | 激情欧美日韩一区二区 | 国产精品人妻在线观看 | 欧美亚洲另类在线 | 亚洲国产果果在线播放在线 | 国产天堂av | 看黄a大片日本真人视频直播 | 精品国产一区二区三区2021 | av岬奈奈美一区二区三区 | 久久久久久欧美精品色一二三四 | 玩丰满少妇ⅹxx性人妖 | 日本少妇呻吟高潮免费看 | 亚洲香蕉伊综合在人在线观看 | 国产精品成人免费精品自在线观看 | 日产精品无人区 | 主站蜘蛛池模板: 蛛词}| 青草视频国产 | jizzzz中国| 久久久久九九九九 | 在线观看成人无码中文av天堂不卡 | 91国内真实乱 | 911av| 欧美一区二区三区在线看 | 狠狠色噜噜狠狠狠777米奇小说 | 人妻丰满熟妇a无码区 | 东北老头嫖妓猛对白精彩 | 豆国产97在线 | 亚洲 | 一个人免费永久观看 | 人妻护士在线波多野结衣 | 无码国产精品一区二区高潮 | 丁香婷婷亚洲 | 久色网站 | 青草视频在线观看免费 | 免费成人在线视频网站 | 国产啪亚洲国产精品无码 | 天堂中文在线免费观看 | 国产精品999. | 国内精品国内自产视频 | 中文字幕观看在线 | 精品视频免费 | 免费无码av片在线观看播放 | 亚洲自偷自偷在线制服 | 亚洲区av | 美女福利在线视频 | 四虎www4hu永久免费 | 国产激情电影综合在线看 | 国产中文在线观看 | 日本边添边摸边做边爱喷水 | 午夜不卡av | 性无码免费一区二区三区在线网站 | 亚洲精品成人网久久久久久 | 天海翼精品久久中文字幕 | 无码免费伦费影视在线观看 | 久久五月综合 | 人妖系列网站在线观看 | 亚洲综合日韩久久成人av | 911露脸国语对白 | 日韩午夜一区 | 在线精品国产一区二区三区 | 中文字幕亚洲制服在线看 | 亚洲一区二区在线免费观看 | 国产尤物精品自在拍视频首页 | 特级黄色毛片 | 亚洲.日韩.欧美另类 | 欧美人与性囗牲恔配 | 99久久精品国产免费看 | 67194熟妇在线观看线路 | 人妻大战黑人白浆狂泄 | 在线综合亚洲欧美日韩 | 国产老熟女伦老熟妇露脸 | 在线中文字幕av | 亚洲高清色 | 亚洲肥老太bbw中国熟女 | 色悠久久久久综合网伊 | 日韩精品一区二区三区亚洲综合 |