使用 AgileConfig 動態配置 NLog

来源:https://www.cnblogs.com/kklldog/archive/2022/05/17/config-nlog.html
-Advertisement-
Play Games

NLog 是我們在 .NET 領域使用非常廣泛的日誌組件。它預設使用 xml 來維護它的配置。最近有幾個同學問我當使用 AgileConfig 的時候如何配置 NLog 。因為 AgileConfig 不支持集成 xml 格式的配置。其實 NLog 是支持從 appsettings.json / I ...


NLog 是我們在 .NET 領域使用非常廣泛的日誌組件。它預設使用 xml 來維護它的配置。最近有幾個同學問我當使用 AgileConfig 的時候如何配置 NLog 。因為 AgileConfig 不支持集成 xml 格式的配置。其實 NLog 是支持從 appsettings.json / IConfiguration 讀取配置的,那麼肯定跟我們的 AgileConfig 集合是沒有問題的。以下介紹下 NLog 如何跟 AgileConfig 進行集成,以及支持動態化的配置。

使用 AgileConfig 配置 NLog

NLog 預設的配置是通過 xml 來配置的。現在我們的 .NET 程式大多數都是通過 appsettings.json 來配置的。NLog 提供了從 appsettings.json / IConfiguration 讀取配置的的擴展。既然支持 IConfiguration 讀取那麼跟我們的 AgileConfig 起來就非常簡單了。

修改 program.cs

從 nuget 安裝:

NLog.Extensions.Hosting
NLog.Web.AspNetCore

使用 UseAgileConfig 擴展開啟 AgileConfig 支持。在 builder.Services.AddLogging 方法內手動設置 LogManager.Configuration 的值。

//use agileconfig client
builder.Host.UseAgileConfig();

//add nlog porvider
builder.Services.AddLogging(b => {
    b.ClearProviders();
     IConfiguration config = builder.Configuration;
    NLog.LogManager.Configuration = new NLogLoggingConfiguration(config.GetSection("NLog"));
    b.AddNLogWeb();
});

在 AgileConfig 維護配置

修改好代碼後,我們需要把 json 配置文件維護到 AgileConfig 上。
AgileConfig 的基礎使用不再贅述,看以前的文章。AgileConfig 資料

  • 新建應用 Nlog_test
    在 AgileConfig 控制台新建一個應用 Nlog_test 。

  • 維護 Nlog 配置
    把以下 json 配置維護到 Nlog_test 應用下。
{
  "NLog": {
    "rules": [
      {
        "logger": "*",
        "minLevel": "Trace",
        "writeTo": "logfile2"
      }
    ],
    "targets": {
      "async": "True",
      "logconsole": {
        "type": "Console"
      },
      "logfile1": {
        "fileName": "d:/nlogs/nlog-${shortdate}.log",
        "type": "File"
      },
      "logfile2": {
        "fileName": "d:/nlogs/nlog-${shortdate}-file2.log",
        "type": "File"
      }
    },
    "throwConfigExceptions": "True"
  }
}

複製以上 json 文件粘貼到 “編輯 JSON” 文本框:

  • 發佈配置
    點擊發佈按鈕,上線 Nlog 配置。

運行項目

運行項目後我們可以看到日誌已經寫到指定的位置,說明 Nlog 成功從 AgileConfig 讀取到了配置。

動態刷新 NLog 配置

上面的代碼我們實現了脫離 xml 從 Agileconfig 讀取配置來 NLog ,但是我們這個配置是一次性的,當我們在 AgileConfig 控制台修改配置的時候並不會更改 Nlog 的配置。這個顯然不符合我們 AgileConfig 動態配置的氣質。既然 NLog 不會自動監聽 IConfiguration 的變化,那麼我們就通過 AgileConfig 的配置變化事件來手動 reload NLog 的配置吧。

void loadNlogConfig()
{
    IConfiguration config = builder.Configuration;
    NLog.LogManager.Configuration = new NLogLoggingConfiguration(config.GetSection("NLog"));
    NLog.LogManager.Configuration.Reload();
}

//use agileconfig client
builder.Host.UseAgileConfig((ConfigChangedArg e) => {
    loadNlogConfig();
});

//add nlog porvider
builder.Services.AddLogging(b => {
    b.ClearProviders();
    NLog.LogManager.ConfigurationChanged += (_, _) => NLog.LogManager.ReconfigExistingLoggers();
    loadNlogConfig();
    b.AddNLogWeb();
});

通過以上配置,當我們在 AgileConfig 修改 Nlog 配置規則的時候,只要點擊發佈,應用的 Nlog 配置就會實時更改。

AgileConfig

AgileConfig 是一個輕量級配置中心
✨✨✨Github地址:https://github.com/dotnetcore/AgileConfig 開源不易,歡迎star✨✨✨

演示地址:http://agileconfig_server.xbaby.xyz/ 超級管理員賬號:admin 密碼:123456

關註我的公眾號一起玩轉技術

QQ群:1022985150 VX:kklldog 一起探討學習.NET技術
作者:Agile.Zhou(kklldog)
出處:http://www.cnblogs.com/kklldog/
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。


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

-Advertisement-
Play Games
更多相關文章
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • “==”和equals的區別 首先我們應該知道的是: “==”是運算符,如果是基本數據類型,則比較存儲的值;如果是引用數據類型,則比較所指向對象的地址值。 equals是Object的方法,比較的是所指向的對象的地址值,一般情況下,重寫之後比較的是對象的值。 一、對象類型不同 1、equals(): ...
  • 把destoon數據生成json,一般用於百度小程式、QQ小程式和微信小程式或者原生APP,由於系統是GB2312編碼,所以服務端編寫的時候我們進行了一些編碼轉換的處理,保證服務端訪問的編碼是UTF-8就可以。不多了,下麵乾貨來了。如果你是程式或此段代碼對你有幫助,希望收藏!! 代碼來了,在根目錄新 ...
  • 環境介紹: python 3.8 解釋器 pycharm 2021專業版 >>> 激活碼 編輯器 谷歌瀏覽器 谷歌驅動 selenium >>> 驅動 >>> 瀏覽器 模塊使用: 採集一個視頻 requests >>> pip install requests re 採集多個視頻 selenium ...
  • 1引言:這裡主要做三件事 1.1resources文件夾下創建spring-mvc.xml並配置:開啟註解驅動(mvc:annotation-driven),靜態資源過濾(mvc:default-servlet-handler),視圖解析器(InternalResourceViewResolver) ...
  • 在 JVM 進行垃圾回收之前,我們需要先判斷一個對象是否存活,判斷對象是否存活採用了兩種方法: 引用計數法 給對象中添加一個引用計數器,每引用這個對象一次,計數器 +1,當引用失效時,計數器 -1。當引用計數器為 0 時,則表示該對象可被回收。 Java 不適用原因:無法解決對象互相迴圈引用的問題 ...
  • 大家好,這篇文章分享了C程式設計(譚浩強)第五版第四章課後題答案,所有程式已經測試能夠正常運行,如果小伙伴發現有錯誤的的地方,歡迎留言告訴我,我會及時改正!感謝大家的觀看!!! ...
  • 大家好,這篇文章分享了C程式設計(譚浩強)第五版第三章課後題答案,所有程式已經測試能夠正常運行,如果小伙伴發現有錯誤的的地方,歡迎留言告訴我,我會及時改正!感謝大家的觀看!!! ...
一周排行
    -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... ...