溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

.NET?6中的dotnet?monitor是什么

發(fā)布時間:2021-12-07 14:01:12 來源:億速云 閱讀:163 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“.NET 6中的dotnet monitor是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“.NET 6中的dotnet monitor是什么”吧!

一.什么是 dotnet monitor

在不同的環(huán)境中運(yùn)行 .NET 應(yīng)用程序可能會使收集診斷信息(例如日志、跟蹤、dump)變得困難。dotnet monitor 是一種工具,它提供了一種統(tǒng)一的方法來收集這些診斷信息,而不管您是在桌面計(jì)算機(jī)(desktop machine 可理解為我們?nèi)粘J褂玫碾娔X)還是在 kubernetes 集群中運(yùn)行。

收集這些診斷信息有兩種不同的機(jī)制:

  • 按需收集診斷信息的 HTTP API。當(dāng)您的應(yīng)用程序遇到問題并且想收集更多信息時,可以調(diào)用這些 HTTP API。

  • 基于規(guī)則配置的觸發(fā)器。您可以配置規(guī)則,以便在滿足所需條件時收集診斷信息,例如在 CPU 持續(xù)一段時間保持較高的指標(biāo)時收集進(jìn)程轉(zhuǎn)儲(process dump)。

二.入門

dotnet monitor 可以通過兩種不同的分發(fā)機(jī)制獲得:

  • .NET CLI 工具

  • 通過 Microsoft Container Registry (MCR) 獲得的容器鏡像

.NET CLI 工具

dotnet monitor CLI 工具首先需要安裝 .NET 6 SDK,如果你沒有足夠新的 SDK,可以通過 .NET 下載網(wǎng)頁獲取安裝包進(jìn)行安裝。

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

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

如果你已經(jīng)安裝但是想更新到最新,可以運(yùn)行以下命令:

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 來查詢可用進(jìn)程、收集診斷信息并檢查請求信息的狀態(tài)。

暴露了以下 HTTP API:

  • /processes- 獲取可被發(fā)現(xiàn)的進(jìn)程的詳細(xì)信息

  • /dump- 在不使用調(diào)試器的情況下捕獲進(jìn)程的 dump

  • /gcdump- 捕獲進(jìn)程的 GC dump

  • /trace- 不使用 profiler 來追蹤進(jìn)程

  • /metrics- 以 Prometheus exposition 格式捕獲默認(rèn)進(jìn)程的指標(biāo)快照

  • /livemetrics- 捕獲進(jìn)程的實(shí)時指標(biāo)流

  • /logs- 捕獲進(jìn)程的日志

  • /info- 獲取有關(guān) dotnet monitor 的信息

  • /operations- 獲取操作狀態(tài)和取消操作

下面的示例演示如何使用 dotnet monitor 從目標(biāo)進(jìn)程開始,在60秒的時間內(nèi)從Microsoft.AspNetCore.Server.Kestrel.Connections 日志級別為 Debug 的日志流數(shù)據(jù)。

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 按需從目標(biāo)進(jìn)程中捕獲診斷信息。除了日志,您還可以從目標(biāo)進(jìn)程收集跟蹤、內(nèi)存轉(zhuǎn)儲、GC轉(zhuǎn)儲和 metrics。

.NET?6中的dotnet?monitor是什么

四.觸發(fā)器

dotnet monitor 可以配置為根據(jù)發(fā)現(xiàn)的進(jìn)程中的條件自動收集診斷信息。 發(fā)現(xiàn)新進(jìn)程時,如果該進(jìn)程數(shù)據(jù)與規(guī)則匹配,則 dotnet monitor 將嘗試應(yīng)用配置的規(guī)則。 應(yīng)用的規(guī)則將開始監(jiān)視觸發(fā)器描述的條件的過程。 如果滿足該條件,則假定尚未達(dá)到指定的限制來執(zhí)行操作列表。

.NET?6中的dotnet?monitor是什么

示例:如果 dotnet monitor 檢測到持續(xù)超過一分鐘的CPU使用率在80%以上,則它將收集進(jìn)程 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"
          }
        }
      ]
    }
  }
}

到此,相信大家對“.NET 6中的dotnet monitor是什么”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI