色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

.Net core Blazor+自定義日志提供器實(shí)現(xiàn)實(shí)時(shí)日志查看器的原理解析

瀏覽:120日期:2022-06-09 11:00:17
目錄
  • 場景
  • 實(shí)現(xiàn)原理
  • 如何使用?
  • 1、啟用blazor server(若你本來是,直接跳過)
  • 2、安裝咱的日志包:BXJG.BlazorServerLogger3、配置
  • 自定義配置和樣式
  • 非微軟的日志框架的集成
  • 資源

基于blazor server的實(shí)時(shí)日志顯示組件

場景

我們經(jīng)常遠(yuǎn)程連接服務(wù)器去查看日志,比較麻煩,如果直接訪問項(xiàng)目的某個(gè)頁面就能實(shí)時(shí)查看日志就比較奈斯了,花了1天研究了下.net core 日志的原理,結(jié)合blazor實(shí)現(xiàn)了基本效果。

實(shí)現(xiàn)原理

  • 自定義日志提供器,將日志記錄到內(nèi)存中,滾動10W條刪除。
  • 提供blazor組件,實(shí)時(shí)從內(nèi)存中讀取后顯示,搞了個(gè)簡單的條件搜索。

為毛用內(nèi)存存儲?因?yàn)榭欤饕康氖菍?shí)時(shí)監(jiān)控,方便調(diào)試,只需要最近一段時(shí)間的數(shù)據(jù),所以內(nèi)存是最合適的。

由于數(shù)據(jù)是存儲在全局靜態(tài)變量中的(線程安全的),所以多個(gè)人同時(shí)打開頁面查看日志其實(shí)看的是同一份數(shù)據(jù)。

這個(gè)庫默認(rèn)提供了與.net core默認(rèn)的日志框架的繼承,但你也可以用自己的方式把數(shù)據(jù)存儲到那個(gè)靜態(tài)變量中。

如何使用?

必須是asp.net 6.x的項(xiàng)目,至于是mvc webapi razorpages還是blazor無所謂,都可以簡單配置支持blazor server,assembly模式按沒考慮過。

我的項(xiàng)目是webapi,啟用blazor server有影響嗎?完全木有,asp.net core本就是基礎(chǔ)web框架,同一個(gè)項(xiàng)目可以同時(shí)支持webapi mvc razorpage和blazor的。

1、啟用blazor server(若你本來是,直接跳過)

若你不熟悉如何在現(xiàn)有項(xiàng)目集成blazor server,可以建個(gè)空的blazor server項(xiàng)目,然后按下面的步驟操作

在startup.cs或program.cs中

//注冊服務(wù)services.AddRazorPages();services.AddServerSideBlazor();//配置路由app.UseEndpoints(endpoints =>{  endpoints.MapDefaultControllerRoute();  endpoints.MapBlazorHub();  endpoints.MapFallbackToPage("/_Host");});

然后將你新建的空的blazor server項(xiàng)目中的如下文件和目錄拷貝過來

  • wwwroot:里面包含默認(rèn)樣式,若你完全決定自己搞樣式,可以不拷貝
  • Pages:里面包含blazor server中基礎(chǔ)的頁面,其中_Host.cshtml(用來放blazor server根組件的)、_Layout.cshtml(_Host.cshtml依賴這個(gè)布局,我們還會在里面放公用的css js引用)文件必拷
  • Shared、公共組件,比如blazor的布局、菜單等組件
  • _Imports.razor、為所有blazor組件做全局命名空間導(dǎo)入的,注意它只為blazor組件服務(wù),并不是global using,這個(gè)是給整個(gè)項(xiàng)目用的
  • 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" />前面的命名空間替換為你當(dāng)前項(xiàng)目的命名空間,這個(gè)是當(dāng)前項(xiàng)目中的組件的樣式文件,自動生成的

2、安裝咱的日志包:BXJG.BlazorServerLogger3、配置

在program.cs中

public static IHostBuilder CreateHostBuilder(string[] args) =>    Host.CreateDefaultBuilder(args).ConfigureLogging(b=>b.AddBlazorServerLogger())

現(xiàn)在啟動,導(dǎo)航到 /log-blazor 頁面看效果。

自定義配置和樣式

目前做的比較簡單,默認(rèn)滾動刪除10W條、記錄所有類別和級別的日志、以及組件的樣式都是固定的,有興趣可以自己改。

默認(rèn)為你建好了頁面 /log-blazor,這要求你在App.razor中配置AdditionalAssemblies="new Assembly[]{ typeof(BlazorServerLogger).Assembly}",如果你不想要這個(gè)頁面,可以自己建頁面,然后引入BlazorServerLogger組件,升值你也可以直接讀取BlazorServerLoggerExt.MsgContainer中的當(dāng)前日志信息,自己做顯示。

非微軟的日志框架的集成

如果你記錄日志使用的不是微軟的ILogger接口,或者你使用的第三方日志框架沒有與微軟的日志框架集成,那么上面的步驟3就不用做了,而是在記錄日志時(shí)直接調(diào)用BlazorServerLoggerExt.Add靜態(tài)方法就行了。

不過這樣你原來的代碼得改,最好與你自己目前的框架做個(gè)集成,舉個(gè)例子:若你原來是直接使用的log4net,則你需要自定義一個(gè)Appender,然后調(diào)用BlazorServerLoggerExt.Add,這樣你原來記錄日志的方式不變。

資源

源碼:https://gitee.com/bxjg1987_admin/abp/tree/master/src/Libs/BXJG.BlazorServerLogger

到此這篇關(guān)于.Net core Blazor+自定義日志提供器實(shí)現(xiàn)實(shí)時(shí)日志查看器的文章就介紹到這了,更多相關(guān).net core Blazor日志查看器內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: ASP.NET
主站蜘蛛池模板: a毛片免费全部播放完整成 a毛片免费全部在线播放毛 | 国产一区二区三区不卡在线观看 | 亚洲人免费视频 | 黄+色+性+人免费 | 一级一片免费看 | 国产91久久久久久久免费 | 美女黄色免费看 | 欧美成人午夜做爰视频在线观看 | 亚洲国产精品线观看不卡 | 18在线观看国内精品视频 | 全国男人天堂网 | 中文字幕一区日韩在线视频 | 另类视频一区 | 自拍第1页 | 99精品免费久久久久久久久日本 | 亚洲一区二区三区中文字幕 | 国产成人在线看 | 免费一级欧美片在线观免看 | 欧美一级一片 | 国产精品无打码在线播放9久 | 欧美的高清视频在线观看 | 在线视频 中文字幕 | 国产一区二区三区亚洲欧美 | 欧美一级二级片 | 免费一级毛片在线播放欧美 | 99久久精品免费 | 国产真实乱系列2孕妇 | 一级做a爰片久久毛片鸭王 一级做a爰全过程免费视频毛片 | 222aaa天堂| 日本一级特黄aa毛片免费观看 | 成人免费一级毛片在线播放视频 | 国产精品人伦久久 | 欧美成人精品一区二区三区 | 国产爽爽视频 | 国产永久高清免费动作片www | 国产呦精品一区二区三区网站 | 一级片免费观看 | 成年人在线免费观看视频网站 | 91精品国产手机在线版 | 亚洲七七久久精品中文国产 | 精品久久在线 |