LoggerMessageAttribute 高性能的日誌記錄

来源:https://www.cnblogs.com/chenyishi/p/18073599
-Advertisement-
Play Games

.NET 6 引入了 LoggerMessageAttribute 類型。 使用時,它會以source-generators的方式生成高性能的日誌記錄 API。 source-generators可在編譯代碼時,可以提供其他源代碼作為編譯的輸入。 LoggerMessageAttribute依賴於 ...


.NET 6 引入了 LoggerMessageAttribute 類型。 使用時,它會以source-generators的方式生成高性能的日誌記錄 API。

source-generators可在編譯代碼時,可以提供其他源代碼作為編譯的輸入。

LoggerMessageAttribute依賴於 ILogger 介面和 LoggerMessage.Define 功能。

在 partial 日誌記錄方法上使用 LoggerMessageAttribute 時,系統會觸發源生成器。 觸發後,它既可以自動生成其修飾的 partial 方法的實現,也可以生成包含正確用法提示的編譯時診斷。

與現有的日誌記錄方法相比,編譯時日誌記錄解決方案在運行時通常要快得多。 這是因為它最大限度地消除了裝箱、臨時分配和副本。

 

基本用法

使用 LoggerMessageAttribute 時,類和方法必須為 partial。 真實記錄日誌的代碼生成器在編譯時觸發,並生成 partial 方法的實現。

public static partial class Log
{
    [LoggerMessage(
        EventId = 0,
        Level = LogLevel.Error,
        Message = "Can not open SQL connection {err}")]
    public static partial void CouldNotOpenConnection(this ILogger logger, string err);
}

在上面的示例中,日誌記錄方法為 static,日誌級別在屬性定義中指定,並使用 this 關鍵字將方法定義為擴展方法。

在調用時,可按常規方式調用即可

internal class Program
{
    private static async Task Main(string[] args)
    {

        using ILoggerFactory loggerFactory = LoggerFactory.Create(
            builder =>
            builder.AddJsonConsole(
                options =>
                options.JsonWriterOptions = new JsonWriterOptions()
                {
                    Indented = true
                }));

        ILogger logger = loggerFactory.CreateLogger("Program");

        logger.CouldNotOpenConnection("network err");
    }
}

 

使用規則

在日誌記錄方法上使用 LoggerMessageAttribute 時,必須遵循一些規則:

  • 日誌記錄方法必須為 partial 並返回 void。
  • 日誌記錄方法名稱不得以下劃線開頭。
  • 日誌記錄方法的參數名稱不得以下劃線開頭。
  • 日誌記錄方法不得在嵌套類型中定義。
  • 日誌記錄方法不能是泛型方法。
  • 如果日誌記錄方法是 static,則需要 ILogger 實例作為參數。

代碼生成模型依賴於使用新式 C# 編譯器 9 或更高版本編譯的代碼。 .NET 5 提供了 C# 9.0 編譯器。 若要升級到新式 C# 編譯器,請編輯項目文件以面向 C# 9.0。 

 

好處

使用源生成器方法有幾個主要好處:

  • 允許保留日誌記錄結構,並啟用消息模板所需的確切格式語法。
  • 允許為模板占位符提供替代名稱,允許使用格式說明符。
  • 允許按原樣傳遞所有原始數據,在對其進行處理之前,不需要進行任何複雜的存儲(除了創建 string)。
  • 提供特定於日誌記錄的診斷,針對重覆的事件 ID 發出警告。

 

https://devblogs.microsoft.com/dotnet/introducing-c-source-generators/

https://learn.microsoft.com/zh-cn/dotnet/csharp/language-reference/keywords/partial-method

https://learn.microsoft.com/zh-cn/dotnet/core/extensions/logger-message-generator


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Pandas無疑是我們數據分析時一個不可或缺的工具,它以其強大的數據處理能力、靈活的數據結構以及易於上手的API贏得了廣大數據分析師和機器學習工程師的喜愛。 然而,隨著數據量的不斷增長,如何高效、合理地管理記憶體,確保Pandas DataFrame在運行時不會因記憶體不足而崩潰,成為我們每一個人必須面 ...
  • 在前幾篇線程系列文章中,我們介紹了線程池的相關技術,任務執行類只需要實Runnable介面,然後交給線程池,就可以輕鬆的實現非同步執行多個任務的目標,提升程式的執行效率,比如如下非同步執行任務下載。 ...
  • 拓展閱讀 第一節 從零開始手寫 mybatis(一)MVP 版本。 第二節 從零開始手寫 mybatis(二)mybatis interceptor 插件機制詳解 第三節 從零開始手寫 mybatis(三)jdbc pool 從零實現資料庫連接池 第四節 從零開始手寫 mybatis(四)- myb ...
  • 故事 春天,辦公室外的世界總是讓人神往的,小貓帶著耳機,托著腮幫,望著外面美好的春光神游著... 一聲不和諧的座機電話聲打破這份本該屬於小貓的寧靜,“hi,小貓,線上有個客戶想購買A產品規格的商品,投訴說下單總是失敗,幫忙看一下啥原因。”客服部小姐姐甜美的聲音從電話那頭傳來。“哦哦,好,我看一下,把 ...
  • roncoo-education —— 一個分散式線上教育系統。目前主要功能有課程點播功能,支持多家視頻雲的接入,課程附件管理功能,支持多家存儲雲的接入,可以幫助個人或者企業快速搭建一個輕量級的線上教育平臺。 ...
  • 在Java多線程編程中,正確且安全地停止線程是一項關鍵技能。簡單粗暴地“殺死”線程不僅可能導致數據不一致性,還可能引發各種難以預測的錯誤。 ...
  • 這個作業屬於哪個課程 軟體工程2024 這個作業要求在哪裡 個人項目 這個作業的目標 瞭解軟體項目開發的整體流程,實現自己的個人項目,學習單元測試、性能優化和 git 操作,學會使用 PSP 表格 Github地址 : 點擊此處,進入我的倉庫 一、項目需求 題目:論文查重 設計一個論文查重演算法,給出 ...
  • 大家好,我是R哥。 周末愉快呀,最近我在做 Java 面試輔導,也模擬面試了好些個學員,說說其中一個學員吧,一個工作 5 年的 Java 程式員,模擬面試,居然一個問題也不會。。 當晚模擬面試完,我的心情很複雜。 我之前做系統架構師,同時也是面試官,這些年,少說也面試過幾百上千人,不乏知識淵博、技能 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...