如何給asp.net core寫個(gè)中間件記錄接口耗時(shí)
Intro
寫接口的難免會(huì)遇到別人說接口比較慢,到底慢多少,一個(gè)接口服務(wù)器處理究竟花了多長(zhǎng)時(shí)間,如果能有具體的數(shù)字來記錄每個(gè)接口耗時(shí)多少,別人再說接口慢的時(shí)候看一下接口耗時(shí)統(tǒng)計(jì),如果幾毫秒就處理完了,對(duì)不起這鍋我不背。
中間件實(shí)現(xiàn)
asp.net core 的運(yùn)行是一個(gè)又一個(gè)的中間件來完成的,因此我們只需要定義自己的中間件,記錄請(qǐng)求開始處理前的時(shí)間和處理結(jié)束后的時(shí)間,這里的中間件把請(qǐng)求的耗時(shí)輸出到日志里了,你也可以根據(jù)需要輸出到響應(yīng)頭或其他地方。
public static class PerformanceLogExtension
{
public static IApplicationBuilder UsePerformanceLog(this IApplicationBuilder applicationBuilder)
{
applicationBuilder.Use(async (context, next) =>
{
var profiler = new StopwatchProfiler();
profiler.Start();
await next();
profiler.Stop();
var logger = context.RequestServices.GetService<ILoggerFactory>()
.CreateLogger("PerformanceLog");
logger.LogInformation("TraceId:{TraceId}, RequestMethod:{RequestMethod}, RequestPath:{RequestPath}, ElapsedMilliseconds:{ElapsedMilliseconds}, Response StatusCode: {StatusCode}",
context.TraceIdentifier, context.Request.Method, context.Request.Path, profiler.ElapsedMilliseconds, context.Response.StatusCode);
});
return applicationBuilder;
}
}
中間件配置
在 Startup 里配置請(qǐng)求處理管道,示例配置如下:
app.UsePerformanceLog();
app.UseAuthentication();
app.UseMvc(routes =>
{
// ...
});
// ...
示例
在日志里按 Logger 名稱 “PerformanceLog” 搜索日志,日志里的 ElapsedMilliseconds 就是對(duì)應(yīng)接口的耗時(shí)時(shí)間,也可以按 ElapsedMilliseconds 范圍來搜索,比如篩選耗時(shí)時(shí)間大于 1s 的日志

Memo
這個(gè)中間件比較簡(jiǎn)單,只是一個(gè)處理思路。
大型應(yīng)用可以用比較專業(yè)的 APM 工具,最近比較火的 Skywalking 項(xiàng)目可以了解一下,支持 .NET Core, 詳細(xì)信息參考: https://github.com/SkyAPM/SkyAPM-dotnet
Reference
https://github.com/WeihanLi/ActivityReservation
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
- ASP.NET?Core中Startup類、Configure()方法及中間件詳解
- ASP.NET?Core的中間件與管道介紹
- 詳解ASP.NET Core中間件Middleware
- 理解ASP.NET Core 中間件(Middleware)
- ASP.NET Core中間件初始化的實(shí)現(xiàn)
- ASP.NET Core 應(yīng)用程序中的靜態(tài)文件中間件的實(shí)現(xiàn)
- 詳解在ASP.NET Core中如何編寫合格的中間件
- 淺談ASP.NET Core 2.0 中間件(譯)
- ASP.NET Core中間件設(shè)置教程(7)
- ASP.NET Core基礎(chǔ)之中間件
相關(guān)文章
ASP.NET web.config中 數(shù)據(jù)庫連接字符串加密解密
本文主要介紹利用aspnet_regiis.exe工具對(duì)web.config中connectionStrings節(jié)點(diǎn)進(jìn)行加密和解密的過程,希望對(duì)大家有所幫助。2016-05-05
.NET Core讀取配置文件方式詳細(xì)總結(jié)
這篇文章主要為大家詳細(xì)總結(jié)了.NET Core讀取配置文件方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08
.net開發(fā)人員常犯的錯(cuò)誤分析小結(jié)
我最新一直在和新手和入手級(jí)開發(fā)人員打交道,我注意到一些開發(fā)人員(甚至是老手)在粗心時(shí)常犯的錯(cuò)誤。這些錯(cuò)誤各不相同,從工具的使用到網(wǎng)絡(luò)服務(wù)的適當(dāng)應(yīng)用都有。以下是六個(gè)主要的開發(fā)錯(cuò)誤。2009-03-03
MAUI中實(shí)現(xiàn)構(gòu)建跨平臺(tái)原生控件
這篇文章介紹了MAUI中實(shí)現(xiàn)構(gòu)建跨平臺(tái)原生控件的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-02-02
擴(kuò)展了Repeater控件的EmptyDataTemplate模板功能
Repeater控件是一個(gè)數(shù)據(jù)顯示控件,該控件允許通過為列表中顯示的每一項(xiàng)重復(fù)使用指定的模板來自定義布局2013-01-01
ASP.NET MVC學(xué)習(xí)教程之Razor語法
這篇文章主要給大家介紹了關(guān)于ASP.NET MVC學(xué)習(xí)教程之Razor語法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05
淺談ASP.NET Core 2.0 帶初始參數(shù)的中間件(譯)
這篇文章主要介紹了淺談ASP.NET Core 2.0 帶初始參數(shù)的中間件(譯),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-10-10

