使用 AgileConfig 動態配置 NLog

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 。

126853ca5cda09e4e219ab80ca604740.png
  • 維護 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” 文本框:

8344db309fe24c2770e6bc9863b36e35.png
  • 發布配置 點擊發布按鈕,上線 Nlog 配置。804b82bc441cd5c5b0c7bc0e5a2356d9.png

運行項目

運行項目后我們可以看到日志已經寫到指定的位置,說明 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

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

fed8f9ae33fc951223457b9067add613.png

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/287402.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/287402.shtml
英文地址,請注明出處:http://en.pswp.cn/news/287402.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

systemd ? ? ?kernel

Systemd:Systemd的新特性:1.在系統引導的時候可以實現服務的并行啟動;2.能夠實現按需激活進程;在系統啟動時,需要隨系統啟動服務,其服務進程并沒有啟動,但是Systemd為每一個此類服務進程都注冊了…

Android之提示Method return type must not include a type variable or wildcard:

1 問題 調用retrofit的時候提示錯誤如下 Method return type must not include a type variable or wildcard: io.reactivex.Observable<package.class<?>> 2 原因 我們知道英文單詞variable是多變的&#xff0c;易變的意思&#xff0c;然后 wildcard是未知數的…

《看聊天記錄都學不會C語言?太菜了吧》(5)打了一把游戲我學會了一個編程知識?

若是大一學子或者是真心想學習剛入門的小伙伴可以私聊我&#xff0c;若你是真心學習可以送你書籍&#xff0c;指導你學習&#xff0c;給予你目標方向的學習路線&#xff0c;無套路&#xff0c;博客為證。 本系列文章將會以通俗易懂的對話方式進行教學&#xff0c;對話中將涵蓋…

【QGIS入門實戰精品教程】2.1:初識QGIS軟件

從今天開始&#xff0c;我們一起來學習一款免費開源、對機器要求低、功能強大的GIS軟件&#xff1a;QGIS &#xff01; 一、QGIS簡介 QGIS&#xff08;原稱Quantum GIS&#xff09;是一個自由軟件的桌面GIS軟件。它提供數據的顯示、編輯和分析功能。 QGIS是一個用戶界面友好的…

Android深度探索(卷1)HAL與驅動開發第六章總結

操作系統是通過各種驅動程序賴家與硬件設備的&#xff0c;它為用戶屏蔽了各種各樣的設備&#xff0c;驅動硬件是操作系統最基本的功能&#xff0c;并且提供統一的操作方式。設備驅動程序是操作系統最基本的組成部分之一&#xff0c;在Linux內核源程序中也占有60%以上&#xff0…

es mysql 同步插件_[es和數據庫怎么同步]mysql與elasticsearch實時同步常用插件及優缺點對比(ES與關系型數據庫同步)...

目前mysql與elasticsearch常用的同步機制大多是基于插件實現的&#xff0c;常用的插件包括&#xff1a;elasticsearch-jdbc,elasticsearch-river-MySQL,go-mysql-elasticsearch,logstash-input-jdbc。本文對四種插件的優缺點進行了圖表對比。|序號|插件名稱|地址|——:————…

linux上怎么快速刪除一個目錄?

使用rm -rf命令轉載于:https://www.cnblogs.com/dyh-air/p/7726611.html

關于是否在C#中加入不可空引用類型的爭論

來自微軟的Mads Togersen在近期所提出的一條提議&#xff0c;即在C#語言中加入對不可空引用類型的支持在.NET社區中引起了熱烈的爭論。人們對此提議的反應大相徑庭&#xff0c;既有人對此表示贊賞&#xff0c;也不乏傾向于保持現狀的意見。\\在Reddit上&#xff0c;這條提議引起…

Andorid之提示java.lang.RuntimeException: Unable to start service net.gotev.uploadservice.UploadService@

1 問題 用android-upload-service上傳一個文件提示錯誤如下 04-15 17:46:33.245 24932 24932 E AndroidRuntime: Process: com.appsinnova.android.keepshare, PID: 24932 04-15 17:46:33.245 24932 24932 E AndroidRuntime: java.lang.RuntimeException: Unable to start se…

使用 VS Code + Markdown 編寫 PDF 文檔

1背景介紹 作為一個技術人員&#xff0c;基本都需要編寫技術相關文檔&#xff0c;而且大部分技術人員都應該掌握 Markdown 這個技能&#xff0c;使用 Markdown 來編寫并生成 PDF 文檔將會是一個不錯的體驗&#xff0c;以下就介紹下如何使用 VS Code Markdown 來編寫 PDF…

《看聊天記錄都學不會C語言?太菜了吧》(6)編程很難嗎?差一點就學不會了呢!

若是大一學子或者是真心想學習剛入門的小伙伴可以私聊我&#xff0c;若你是真心學習可以送你書籍&#xff0c;指導你學習&#xff0c;給予你目標方向的學習路線&#xff0c;無套路&#xff0c;博客為證。 本系列文章將會以通俗易懂的對話方式進行教學&#xff0c;對話中將涵蓋…

【ArcGIS風暴】氣象臺站氣溫(降水)矢量數據插值成柵格氣溫(降水)空間數據

關于文本格式的氣象數據生成Shapefile矢量數據的過程,可以參照文章《ArcGIS 10.2導入Excel數據X、Y坐標(經緯度、平面坐標),生成Shapefile點數據圖層》。本文在前面生成的具有氣溫和降水屬性的氣象臺站矢量數據的基礎上,通過柵格插值,柵格裁剪等過程生成空間分布的氣溫和…

時間差幾天 php,計算和當前時間差多少天

我們有時在做網站時會碰到比較特別的需求&#xff0c;一條信息顯示是幾天和幾天后的或者一個月前的&#xff0c;上次做一個APP時就碰到了這周情況&#xff0c;留下當時用的代碼以便以后用時不需要東奔西走。PHP代碼&#xff1a;function calcTime($time){$now time(); //當前時…

Android studio之導入新庫提示Add library ‘Gradle*****@aar‘ to classpath

1 問題 as導入第三方庫在依賴的基類build.gradle里面添加如下 implementation com.truizlop.sectionedrecyclerview:library:1.2.0 提示錯誤如下 2 原因 implementation 單層引用&#xff0c;只引用當前aar包層&#xff0c; api 多層引用&#xff0c;引用當前aar包層&#…

Windows 查看端口占用

查看 Windows 端口占用情況 在 Windows 命令行窗口下執行一下命令 查看所有端口占用情況netstat -ano 查看特定端口的占用情況netstat -aon|findstr "8080" 查看PID對應的進程tasklist|findstr "2212" 實例 博主碰到的是8080端口被占用了&#xff0c;如下圖…

Android quot;QR二維碼掃描quot;

支持燈 掃描結果 支持 抄、分享、瀏覽打開&#xff08;超鏈接&#xff09; 自己主動保存掃描記錄 劃刪除 和源代碼 git: http://git.oschina.net/892642257/QRCode csdn(0分): http://download.csdn.net/detail/onlyonecoder/7713589 版權聲明&#xff1a;本文博主原創文章。博…

ASP.NET Core中的依賴注入(4): 構造函數的選擇與服務生命周期管理

ServiceProvider最終提供的服務實例都是根據對應的ServiceDescriptor創建的&#xff0c;對于一個具體的ServiceDescriptor對象來說&#xff0c;如果它的ImplementationInstance和ImplementationFactory屬性均為Null&#xff0c;那么ServiceProvider最終會利用其ImplementationT…

C# WPF布局控件LayoutControl介紹

Dev學習地址文檔地址 &#xff1a;https://docs.devexpress.com/wpf&#xff1a;https://docs.devexpress.com/WPF/7875/wpf-controlswinform&#xff1a;https://docs.devexpress.com/WindowsForms/7874/winforms-controlsasp.NET: https://docs.devexpress.com/AspNet/7873/a…

《看聊天記錄都學不會C語言?太菜了吧》(7)下一篇文章告訴你牛郎是誰

若是大一學子或者是真心想學習剛入門的小伙伴可以私聊我&#xff0c;若你是真心學習可以送你書籍&#xff0c;指導你學習&#xff0c;給予你目標方向的學習路線&#xff0c;無套路&#xff0c;博客為證。 本系列文章將會以通俗易懂的對話方式進行教學&#xff0c;對話中將涵蓋…

【遙感物候】30年物候始期空間分布特征(平均值)和變化趨勢分析(Slope 一元線性回歸分析)

問題分析:本文的數據為經過預處理和計算得到的30年(1983-2012年)物候參數始期遙感數據,共計30期影像,現在需要逐像元計算整個物候始期的空間分布特征(平均值)和變化趨勢分析(Slope 一元線性回歸分析)。最終的效果(左圖為分布特征,右圖為變化趨勢): 一、方法原理 …