返回顶部
首页 > 资讯 > 后端开发 > ASP.NET >.NET 6 中的 dotnet monitor详细解析
  • 839
分享到

.NET 6 中的 dotnet monitor详细解析

2024-04-02 19:04:59 839人浏览 独家记忆
摘要

目录一.什么是dotnetmonitor二.入门.netCLI工具容器镜像三.Httpapi四.触发器五.反馈原文:Announcing dotnet monitor in .NET

原文:Announcing dotnet monitor in .NET 6

我们在 2020 年 6 月首次推出了dotnet monitor 作为实验工具,并在去年(2020年)努力将其转变为生产级工具。今天,我很高兴地的宣布 dotnet monitor 的第一个正式版将和 .NET 6 一起发布,作为 .NET 6 的一部分。

dotnet monitor 已经为 Azure App Service(linux)提供 .NET 应用程序的诊断工具提供支持,我们希望它在更多环境中使用。

一.什么是 dotnet monitor

在不同的环境中运行 .NET 应用程序可能会使收集诊断信息(例如日志、跟踪、dump)变得困难。dotnet monitor 是一种工具,它提供了一种统一的方法来收集这些诊断信息,而不管您是在桌面计算机(desktop Machine 可理解为我们日常使用的电脑)还是在 kubernetes 集群中运行。

收集这些诊断信息有两种不同的机制:

  • 按需收集诊断信息的 HTTP API。当您的应用程序遇到问题并且想收集更多信息时,可以调用这些 HTTP API。
  • 基于规则配置的触发器。您可以配置规则,以便在满足所需条件时收集诊断信息,例如在 CPU 持续一段时间保持较高的指标时收集进程转储(process dump)。

二.入门

dotnet monitor 可以通过两种不同的分发机制获得:

  • .NET CLI 工具
  • 通过 Microsoft Container ReGIStry (MCR) 获得的容器镜像

.NET CLI 工具

dotnet monitor CLI 工具首先需要安装 .NET 6 SDK,如果你没有足够新的 SDK,可以通过 .NET 下载网页获取安装包进行安装。

你可以使用一下命令获取最新版的 dotnet monitor:

dotnet tool install -g dotnet-monitor --version 6.0.0

如果你已经安装但是想更新到最新,可以运行以下命令:

dotnet tool update -g dotnet-monitor --version 6.0.0

容器镜像

dotnet monitor 容器镜像在 MCR 上可用,你可以通过以下命令获取最新的镜像:

Docker pull mcr.microsoft.com/dotnet/monitor:6.0.0

三.HTTP API

dotnet monitor 公开了一个 HTTP API 来查询可用进程、收集诊断信息并检查请求信息的状态。

暴露了以下 HTTP API:

  • /processes- 获取可被发现的进程的详细信息
  • /dump- 在不使用调试器的情况下捕获进程的 dump
  • /GCdump- 捕获进程的 GC dump
  • /trace- 不使用 profiler 来追踪进程
  • /metrics- 以 prometheus exposition 格式捕获默认进程的指标快照
  • /livemetrics- 捕获进程的实时指标流
  • /logs- 捕获进程的日志
  • /info- 获取有关 dotnet monitor 的信息
  • /operations- 获取操作状态和取消操作

下面的示例演示如何使用 dotnet monitor 从目标进程开始,在60秒的时间内从Microsoft.Aspnetcore.Server.Kestrel.Connections 日志级别为 Debug 的日志流数据。

PS> curl.exe -X POST "https://localhost:52323/logs?name=myWEBApp&durationSeconds=60" `

    -H "Accept: application/x-ndJSON" `

    -H "Content-Type: application/json" `

    --neGotiate -u $(whoami)`

    -d '{"filterSpecs": {"Microsoft.AspNetCore.Server.Kestrel.Connections": "Debug"}}' 

{"Timestamp":"2021-11-05 08:12:54Z","LogLevel":"Debug","EventId":39,"EventName":"ConnectionAccepted","Category":"Microsoft.AspNetCore.Server.Kestrel.Connections","Message":"Connection id u00220HMD06BUKL2CUu0022 accepted.","State":{"Message":"Connection id u00220HMD06BUKL2CUu0022 accepted.","ConnectionId":"0HMD06BUKL2CU","{OriginalFORMat}":"Connection id u0022{ConnectionId}u0022 accepted."}}

{"Timestamp":"2021-11-05 08:12:54Z","LogLevel":"Debug","EventId":1,"EventName":"ConnectionStart","Category":"Microsoft.AspNetCore.Server.Kestrel.Connections","Message":"Connection id u00220HMD06BUKL2CUu0022 started.","State":{"Message":"Connection id u00220HMD06BUKL2CUu0022 started.","ConnectionId":"0HMD06BUKL2CU","{OriginalFormat}":"Connection id u0022{ConnectionId}u0022 started."}}

{"Timestamp":"2021-11-05 08:12:54Z","LogLevel":"Debug","EventId":9,"EventName":"ConnectionKeepAlive","Category":"Microsoft.AspNetCore.Server.Kestrel.Connections","Message":"Connection id u00220HMD06BUKL2CUu0022 completed keep alive response.","State":{"Message":"Connection id u00220HMD06BUKL2CUu0022 completed keep alive response.","ConnectionId":"0HMD06BUKL2CU","{OriginalFormat}":"Connection id u0022{ConnectionId}u0022 completed keep alive response."},"Scopes":[{"ConnectionId":"0HMD06BUKL2CU"},{"RequestId":"0HMD06BUKL2CU:00000002","RequestPath":"/"}]}

如上面的示例所示,您可以使用 dotnet monitor 按需从目标进程中捕获诊断信息。除了日志,您还可以从目标进程收集跟踪、内存转储、GC转储和 metrics。

四.触发器

dotnet monitor 可以配置为根据发现的进程中的条件自动收集诊断信息。 发现新进程时,如果该进程数据与规则匹配,则 dotnet monitor 将尝试应用配置的规则。 应用的规则将开始监视触发器描述的条件的过程。 如果满足该条件,则假定尚未达到指定的限制来执行操作列表。

示例:如果 dotnet monitor 检测到持续超过一分钟的CPU使用率在80%以上,则它将收集进程 dump,限制每小时不超过1个。


{
  "CollectionRules": {
    "HighCpuRule": {
      "Filters": [
        {
          "Key": "ProcessName",
          "Value": "MyApp",
          "MatchType": "Exact"
        }
      ],
      "Trigger": {
        "Type": "EventCounter",
        "Settings": {
          "ProviderName": "System.Runtime",
          "CounterName": "cpu-usage",
          "GreaterThan": 80,
          "SlidingWindowDuration": "00:01:00"
        }
      },
      "Limits": {
        "ActionCount": 1,
        "ActionCountSlidingWindowDuration": "1:00:00"
      },
      "Actions": [
        {
          "Type": "CollectDump",
          "Settings": {
            "Type": "Triage",
            "Egress": "myBlobStorageAccount"
          }
        }
      ]
    }
  }
}

规则文档:https://GitHub.com/dotnet/dotnet-monitor/blob/main/documentation/collectionrules.md

五.反馈

github issue: https://github.com/dotnet/dotnet-monitor/issues/new/choose

到此这篇关于.NET 6 中的 dotnet monitor的文章就介绍到这了,更多相关.NET6 dotnet monitor内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: .NET 6 中的 dotnet monitor详细解析

本文链接: https://lsjlt.com/news/159329.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • .NET 6 中的 dotnet monitor详细解析
    目录一.什么是dotnetmonitor二.入门.NETCLI工具容器镜像三.HTTPAPI四.触发器五.反馈原文:Announcing dotnet monitor in .NET...
    99+
    2024-04-02
  • .NET 6中的dotnet monitor讲解
    目录一.什么是dotnetmonitor二.入门.NETCLI工具容器镜像三.HTTPAPI四.触发器五.反馈一.什么是 dotnet monitor 在不同的环境中运行 .NET ...
    99+
    2024-04-02
  • .NET 6中的dotnet monitor怎么理解
    这篇文章给大家介绍.NET 6中的dotnet monitor怎么理解,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一.什么是 dotnet monitor在不同的环境中运行 .NET 应用程序可能...
    99+
    2023-06-22
  • .NET 6中的dotnet monitor是什么
    本篇内容主要讲解“.NET 6中的dotnet monitor是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“.NET 6中的dotnet monit...
    99+
    2023-06-22
  • 如何进行.Net 6中的PeriodTimer分析
    这篇文章主要为大家分析了如何进行.Net 6中的PeriodTimer分析的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“如何进行.Net ...
    99+
    2023-06-26
  • java中Optional的使用详细解析
    目录Optional的使用详解1、Optional介绍2、构建Optional3、Optional API 及源码注解4、测试使用4.1、构建4.2、判断类4.3、获取类(常用)4....
    99+
    2024-04-02
  • springMVC中的view视图详细解析
    目录1、ThymleafView2、转发视图3、重定向视图4、视图控制器view-controllerSpring MVC中的视图是view接口,视图的作用是渲染数据,将模型mode...
    99+
    2024-04-02
  • PHP中POST方法的详细解析
    PHP中POST方法的详细解析 在PHP编程中,POST方法是一种用于向服务器发送数据的HTTP请求方法。通过POST方法,我们可以将表单中的数据提交给服务器,服务器接收到数据后进行处...
    99+
    2024-04-02
  • PHP中success方法的详细解析
    PHP中success方法的详细解析 在PHP编程中,成功处理返回结果时经常会用到success方法。success方法通常用于表示执行成功并返回相应的数据,它是一种简洁而有效的处理成...
    99+
    2024-04-02
  • 在.NET Core中使用CSRedis的详细过程
    目录CSRedis开始之前字符串(string)使用CSRedis进行简单操作非正常情况列表(list)集合(set)散列(hashmap)有序集合事务Key的过期引用CSRedis...
    99+
    2024-04-02
  • 详解.NET Core中的Worker Service
    目录Worker Service项目程序和后台服务Worker Service 中使用Logging运行Worker Service当你想到ASP.NET Core时,可能会想到We...
    99+
    2024-04-02
  • Java中详细解析Map接口
    目录Map详解:Map基本操作:hashMap原理:Put方法:Get方法:Map的遍历:TreeMapLinkedHashMap:对比下Hashmap、Hashtable和Conc...
    99+
    2024-04-02
  • Python中的相对路径/ ./ ../详细解析
    在学习李沐:动手学深度学习的第13章目标检测时,需要导入一只猫:  这里采用相对路径。因为是相对的所以要有一个基准(当前工作目录)。这个基准可以用os模块获取当前工作目录: import osprint(os.getcwd()) 对于当前...
    99+
    2023-10-12
    python
  • Python类中__init__() 和self的详细解析
    目录1、Python中self的含义2、Python中为何要有self3、首先来看一下__init__()和self对象4、如果没有在__init__中初始化对应的实例变量的话,导致...
    99+
    2022-12-30
    python类中的__init__ python__init__用法 Python类 self
  • JavaScript中的回调函数详细解析
    以上就是JavaScript中的回调函数详细解析的详细内容,更多请关注编程网其它相关文章!...
    99+
    2022-11-23
    JavaScript
  • STl中的排序算法详细解析
    1. 所有STL sort算法函数的名字列表: 函数名             功能描述 sort          对给定区间所有元素进行...
    99+
    2022-11-15
    STl 排序算法
  • CSS中固定定位的详细解析
    CSS中固定定位的定位属性详解在CSS中,固定定位(fixed positioning)是一种常用的定位方式,它可以使元素相对于浏览器窗口的特定位置进行定位,不随页面滚动而改变位置。本文将详细介绍固定定位的定位属性,并提供具体的代码示例。固...
    99+
    2023-12-28
    CSS固定定位 定位属性详解。
  • React Hook中的useState函数的详细解析
    useState => 让函数组件具有维持状态的能力useState 这个 Hook 是用来管理 state 的,它可以让函数组件具有维持状态的能力。即在一个函数组件的多次渲染...
    99+
    2022-11-13
    React Hook  useState函数 React Hook
  • .NET中的HashSet及原理解析
    目录哈希表原理HashSet实现总结参考文章在.NET中,System.Collection及System.Collection.Generic命名空间中提供了一系列的集合类,Has...
    99+
    2024-04-02
  • CStdioFile的用法详细解析
    关于CStdioFileCStdioFile继承自CFile,一个CStdioFile 对象代表一个用运行时函数fopen 打开的C 运行时流式文件。 流式文件是被缓冲的,而且可以以...
    99+
    2022-11-15
    CStdioFile
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作