京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 6624|回复: 0

正确使用dotnet-*工具的方法

[复制链接]

26

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2022-1-13 08:35:56 | 显示全部楼层 |阅读模式 来自 中国
目录6 `- ]1 c5 q' ~6 F& M9 Z1 I- n

& U1 k+ w% _' E) E6 v

    % P" ~; Q- A- N
  • 安装  i" S8 @& d6 c8 c; R
  • 验证- O4 i$ y# }& I* U" H
  • dotnet-dump
      ~: O& B9 r; Z3 Q9 N
  • createdump- ^; W2 D' O" A* K
  • 分析coredump文件. Y* T6 z' E! h- [5 O7 ~0 b, C
  • 相关资料:
    . h2 e, u+ z- W  t; R6 r
, g* h- J! O- L, E" V3 n
安装
( W! U9 H( o- @. a+ P2 t+ s9 `- K" W1 M
       
    . n* {: b8 O: b( h
  • 因为我们现在都是容器化时代了,所以我们可以把这类工具全部制作成基础镜像   
    ; |( U# h* K6 `0 J8 S$ x
  • 准备Dockerfile: a) ~( f5 j7 H  l/ u( Q+ Q
  1. FROM mcr.microsoft.com/dotnet/sdk:3.1 AS sdkRUN dotnet tool install --tool-path /tools dotnet-traceRUN dotnet tool install --tool-path /tools dotnet-countersRUN dotnet tool install --tool-path /tools dotnet-dumpRUN dotnet tool install --tool-path /tools dotnet-gcdumpFROM mcr.microsoft.com/dotnet/core/aspnet:3.1 AS runtimeWORKDIR /toolsCOPY --from=sdk /tools .basedockerfile.yaml
复制代码
验证, o+ }# U5 D0 N7 S
' @* g% k. r4 ~$ U% t
基础镜像做好了,查看下镜像的大小应该就比runtime的大小多几十兆,相比为了使用dotnet-* tool而直接采用sdk的话,体积小了很多很多
% d, u2 P: q, F8 B用我们刚才制作的基础镜像随便起个demo程序验证下
2 n; X9 Z0 f& U7 [1 ~
        8 V$ T% d& z; T  L: t
  • 已经包含了tools文件夹了,里面存放了我们的tools工具
    5 i0 X' b! b; z$ s$ o2 p1 c
  U" R. ]& h. ^

, Y9 M' C6 r" `& ?+ D/ s5 Y7 M' `
       
    3 w" W, G- h1 T& Z
  • 以dotnet-trace为例,测试下是否可用(ps:注意使用方式)
    ! J/ }( L1 f3 Y! S5 W

. a* l8 X! O  s# o& Z- W至此包含tools的runtime基础镜像制作完毕。
8 G2 G& m9 V7 i$ C" C! z, u. @9 C% T8 J0 |& p' z$ w
dotnet-dump
7 W: A+ w( [* w, c0 \4 a) y( e# l1 i2 Q' V
它只能收集托管内存,不能用于条是本地代码的问题,而且分析它所创建的dump文件,必须和当前环境保持一致  f5 N' B; e  o6 S# T/ ^: B. b
, _: C9 D( C" H) C7 Q6 N5 [8 N
createdump$ F" z& X% R# l' a

8 P) _& K4 j. p8 ?/ n$ e9 t它既可以收集本地信息又可以收集托管信息,是一种比较全面而且推荐的方法
2 u# L4 {9 |5 C: z3 q虽然gdb、gcore也能起到同样的作用,但是他们可能会在收集的时候错过一些托管状态,导致最后你分析dump文件的时候有”UNKNOWN“的错误
$ a0 f: K' I* W1 F这个工具是伴随着.net core runtime安装的,目录一般在”/usr/share/dotnet/shared/Microsoft.NETCore.App/[version]“下# U/ t1 g: G) q$ Q" v
开始使用:$ Q$ L1 ]' o0 {0 e  K) H
        5 V5 j, h2 s' I2 p( s
  • /usr/share/dotnet/shared/Microsoft.NETCore.App/3.1.10/createdump -u 1 (1是我容器中程序的进程id)
    4 i* i; ^0 \) y$ m3 h( \2 s6 n

, ]7 w1 W* C4 c2 J) N2 R
       
    ( p) y9 p# l+ J6 A  b
  • 他会将coredump文件生成到容器的tmp目录下,至此没报错的话,说明成功   
    1 z9 d/ p9 ~; q
  • 如果报权限相关错误,可以在你的yaml文件里加上:
    $ d5 g% G. w' D4 T

/ `3 V. m- u3 O. ?# j5 s
! k) d. G2 ]5 }' Q分析coredump文件: Z$ W* D7 ]7 |# g7 }0 F
! H7 v8 o+ C. q5 F9 l, D
先将上面生成在tmp下的coredump文件copy到可以调试的地方
  M: v+ h/ p9 I1 S1 A; G3 pkubectl cp  bookstore/demo-7b6d9f6d4f-2t8hl:/tmp/coredump.1 /root/mydump/coredump.1 -c app-k8s
4 Q' x5 q; w9 r# b: d
* s/ F3 O1 A# m, c8 ^5 Y& N' f
然后为我们的coredump.1文件下载关联的symbol:6 H3 s' n; G  x6 q! L
如果你准备分析dump的机器没有dotnet sdk的话,先装一个把2 I6 Z/ p7 i, M$ U4 _- i
! u: i2 }2 r5 d- a+ V1 w
        $ u$ V2 D6 V- \* Y; Q9 B% @
  • sudo rpm -Uvh https://packages.microsoft.com/config/centos/7/packages-microsoft-prod.rpm   
    - ]9 S( {8 h8 D; _1 e3 }  S
  • sudo yum install dotnet-sdk-3.1' k: ]7 P: Q4 W% s
如果dotnet-symbol没有安装的话,安装一个4 w# y, [# a  T# q

6 o; H$ q* E8 i/ @/ l& {3 U3 O2 K
       
    ( B% h1 @; t/ D  a# `( Y
  • dotnet tool install --global dotnet-symbol   
    6 E- N9 b) v6 O0 u9 A
  • 然后关闭当前终端,再打开一个新的
      g. R/ o8 s/ J/ b+ h
然后执行dotnet-symbol --host-only --debugging coredump.13 c/ W9 V# Z- K3 u0 q: g# d% ^1 \

0 V* p' V+ e1 I- Y# w* ^4 s, h( i) j4 D

- W/ |7 T7 x* z0 u$ g* J9 N
        . O$ Z7 j+ O0 V0 M9 l+ \0 y* n5 y& w
  • 看到dac,dbi文件写入就代表成功了,这时候你的文件夹应该长这样0 Q5 n0 d+ G. H5 @5 w% i/ c

) I9 [% P' T( Y6 y/ y3 |然后我们使用lldb进行调试
% p6 c& R; G- V2 E
2 @/ N. ]; ~' C8 w, o
       
    ) B3 F" a" t/ N. W' V
  • 如果你机器里没装的话,先装一个吧    + S" X8 U9 u1 Z% n* n& g: L1 w
  • 安装sos插件:
    9 V# v3 i& f0 s# R: S- m  W
              ) x% L+ o0 Y$ M5 O6 ?, T
    • dotnet tool install --global dotnet-sos        
      * f6 ^9 Y! M/ o- p  F6 X2 I
    • dotnet-sos install   
      , z- N' A6 H+ ^* R- o# F, G
            ( s# m# B4 g/ |# X
  • lldb-8 --core coredump.1   
    8 D5 c3 F" S, Z& N% Q
  • 然后就可以用lldb来分析dump文件了
    # k; M5 Q* o2 E; q0 |9 N) Q
: [. |0 w2 A: p; [3 K. |$ y
相关资料:$ v  z3 @) ]( d$ A
0 r0 b) E2 g- g% ?
        ' ~) z4 Q5 @' q/ e4 o7 x( G0 _- j, C6 s
  • https://docs.microsoft.com/en-us/dotnet/core/diagnostics/dotnet-symbol    + i$ ^0 ]* z+ H# @! _' n0 e2 f
  • https://github.com/dotnet/diagnostics/blob/master/documentation/debugging-coredump.md    $ y2 W6 ?; s2 B5 x  D
  • https://devblogs.microsoft.com/devops/understanding-symbol-files-and-visual-studios-symbol-settings/    0 {' z7 X/ H& G
  • https://github.com/dotnet/diagnostics/blob/master/documentation/FAQ.md    1 c+ Z. r: M9 v
  • https://github.com/dotnet/runtime/issues/11012   
    ) i% a3 Q5 Q- R9 b
  • 关于大对象使用的注意点以及官方blob gc的实现描述7 F+ N. S+ m7 V" X
以上所述是小编给大家介绍的正确使用dotnet-*工具的方法,希望对大家有所帮助。在此也非常感谢大家对脚本之家网站的支持!
. T: K0 \, O: x7 n9 F6 _. z. W% l( b
" n/ ^* s5 Y! W2 d5 @! X来源:http://www.jb51.net/article/232931.htm
- ]3 B; y0 Z. I. j免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2026-6-25 20:31 , Processed in 0.038885 second(s), 24 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表