.Net?core?Blazor+自定義日志提供器實現(xiàn)實時日志查看器的原理解析
基于blazor server的實時日志顯示組件

場景
我們經(jīng)常遠程連接服務(wù)器去查看日志,比較麻煩,如果直接訪問項目的某個頁面就能實時查看日志就比較奈斯了,花了1天研究了下.net core 日志的原理,結(jié)合blazor實現(xiàn)了基本效果。
實現(xiàn)原理
- 自定義日志提供器,將日志記錄到內(nèi)存中,滾動10W條刪除。
- 提供blazor組件,實時從內(nèi)存中讀取后顯示,搞了個簡單的條件搜索。
為毛用內(nèi)存存儲?因為快,主要目的是實時監(jiān)控,方便調(diào)試,只需要最近一段時間的數(shù)據(jù),所以內(nèi)存是最合適的。
由于數(shù)據(jù)是存儲在全局靜態(tài)變量中的(線程安全的),所以多個人同時打開頁面查看日志其實看的是同一份數(shù)據(jù)。
這個庫默認提供了與.net core默認的日志框架的繼承,但你也可以用自己的方式把數(shù)據(jù)存儲到那個靜態(tài)變量中。
如何使用?
必須是asp.net 6.x的項目,至于是mvc webapi razorpages還是blazor無所謂,都可以簡單配置支持blazor server,assembly模式按沒考慮過。
我的項目是webapi,啟用blazor server有影響嗎?完全木有,asp.net core本就是基礎(chǔ)web框架,同一個項目可以同時支持webapi mvc razorpage和blazor的。
1、啟用blazor server(若你本來是,直接跳過)
若你不熟悉如何在現(xiàn)有項目集成blazor server,可以建個空的blazor server項目,然后按下面的步驟操作
在startup.cs或program.cs中
//注冊服務(wù)
services.AddRazorPages();
services.AddServerSideBlazor();
//配置路由
app.UseEndpoints(endpoints =>
{
endpoints.MapDefaultControllerRoute();
endpoints.MapBlazorHub();
endpoints.MapFallbackToPage("/_Host");
});然后將你新建的空的blazor server項目中的如下文件和目錄拷貝過來
- wwwroot:里面包含默認樣式,若你完全決定自己搞樣式,可以不拷貝
- Pages:里面包含blazor server中基礎(chǔ)的頁面,其中_Host.cshtml(用來放blazor server根組件的)、_Layout.cshtml(_Host.cshtml依賴這個布局,我們還會在里面放公用的css js引用)文件必拷
- Shared、公共組件,比如blazor的布局、菜單等組件
- _Imports.razor、為所有blazor組件做全局命名空間導入的,注意它只為blazor組件服務(wù),并不是global using,這個是給整個項目用的
- App.razor ,blazor server的根組件,它被放在_Host.cshtml中的。在此頁面頂部:<Router AppAssembly="@typeof(App).Assembly" AdditionalAssemblies="new Assembly[]{ typeof(BlazorServerLogger).Assembly}">
注意修改命名空間,尤其注意_Layout.cshtml head部分<link href="ZLJ.FYJIOT.ApiHost.styles.css" rel="stylesheet" />前面的命名空間替換為你當前項目的命名空間,這個是當前項目中的組件的樣式文件,自動生成的
2、安裝咱的日志包:BXJG.BlazorServerLogger3、配置
在program.cs中
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureLogging(b=>b.AddBlazorServerLogger())現(xiàn)在啟動,導航到 /log-blazor 頁面看效果。
自定義配置和樣式
目前做的比較簡單,默認滾動刪除10W條、記錄所有類別和級別的日志、以及組件的樣式都是固定的,有興趣可以自己改。
默認為你建好了頁面 /log-blazor,這要求你在App.razor中配置AdditionalAssemblies="new Assembly[]{ typeof(BlazorServerLogger).Assembly}",如果你不想要這個頁面,可以自己建頁面,然后引入BlazorServerLogger組件,升值你也可以直接讀取BlazorServerLoggerExt.MsgContainer中的當前日志信息,自己做顯示。
非微軟的日志框架的集成
如果你記錄日志使用的不是微軟的ILogger接口,或者你使用的第三方日志框架沒有與微軟的日志框架集成,那么上面的步驟3就不用做了,而是在記錄日志時直接調(diào)用BlazorServerLoggerExt.Add靜態(tài)方法就行了。
不過這樣你原來的代碼得改,最好與你自己目前的框架做個集成,舉個例子:若你原來是直接使用的log4net,則你需要自定義一個Appender,然后調(diào)用BlazorServerLoggerExt.Add,這樣你原來記錄日志的方式不變。
資源
源碼:https://gitee.com/bxjg1987_admin/abp/tree/master/src/Libs/BXJG.BlazorServerLogger
到此這篇關(guān)于.Net core Blazor+自定義日志提供器實現(xiàn)實時日志查看器的文章就介紹到這了,更多相關(guān).net core Blazor日志查看器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
.NET?Core?Web?APi類庫內(nèi)嵌運行的方法
這篇文章主要介紹了.NET?Core?Web?APi類庫內(nèi)嵌運行的方法,本節(jié)我們重點討論如何內(nèi)嵌運行.NET Core Web APi類庫,同時介紹了兩種激活比如控制器特性方案,需要的朋友可以參考下2022-09-09
.NET/C#利用反射調(diào)用含ref或out參數(shù)的方法示例代碼
這篇文章主要給大家介紹了關(guān)于.NET/C#利用反射調(diào)用含ref或out參數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-09-09
.net core如何利用ConcurrentTest組件對方法進行壓力測試詳解
這篇文章主要給大家介紹了關(guān)于.net core如何利用ConcurrentTest組件對方法進行壓力測試的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起看看吧2018-11-11
visual studio 2019使用net core3.0創(chuàng)建winform無法使用窗體設(shè)計器
這篇文章主要介紹了visual studio 2019使用net core3.0創(chuàng)建winform無法使用窗體設(shè)計器,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-03-03
C#下載文件(TransmitFile/WriteFile/流方式)實例介紹
C#下載文件想必很多業(yè)內(nèi)人士都不會陌生吧,C#下載文件方法很多,本文整理了一些,可供大家參考,感興趣的你可以研究下,或許本文所提供的知識點對你有所幫助2013-02-02
asp.net?core實體類生產(chǎn)CRUD后臺管理界面
這篇文章主要為大家介紹了asp.net?core實體類生產(chǎn)CRUD后臺管理界面詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05
Entity Framework Core使用控制臺程序生成數(shù)據(jù)庫表
這篇文章介紹了Entity Framework Core使用控制臺程序生成數(shù)據(jù)庫表的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
ASP.NET.4.5.1+MVC5.0設(shè)置系統(tǒng)角色與權(quán)限(一)
這篇文章主要介紹了ASP.NET.4.5.1+MVC5.0設(shè)置系統(tǒng)角色與權(quán)限的部分內(nèi)容,后續(xù)我們將繼續(xù)討論這個話題,希望小伙伴們喜歡。2015-01-01

