.NetCore 接口请求耗时记录

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: .NetCore 接口请求耗时记录

通过日志,记录每个接口请求的耗时情况

结合  <logger name="*" level="Trace" writeTo="tracefile"/> 配置使用,NLog 热生效不需要重启服务

增加 RequestLogMiddleware.cs

public class RequestLogMiddleware
{
    /// <summary>
    ///
    /// </summary>
    private readonly RequestDelegate _next;
    /// <summary>
    ///
    /// </summary>
    private readonly Logger logger = LogManager.GetCurrentClassLogger();
    /// <summary>
    ///
    /// </summary>
    /// <param name="next"></param>
    public RequestLogMiddleware(RequestDelegate next, ILogger<RequestLogMiddleware> logger)
    {
        _next = next;
    }
    /// <summary>
    /// 访问日志记录
    /// </summary>
    /// <param name="context"></param>
    /// <returns></returns>
    public async Task Invoke(HttpContext context)
    {
        //if (_RequestLogOptions != null & _RequestLogOptions.CurrentValue != null & _RequestLogOptions.CurrentValue.Enable)
        {
            var watch = new Stopwatch();
            watch.Start();
            context.Response.OnStarting(() =>
            {
                watch.Stop();
                try
                {
                    //排序 .jpg .css .js 等资源文件
                    if (!context.Request.Path.Value.Contains("."))
                    {
                        var headers = context.Request.Headers;
                        if (headers.ContainsKey("X-Forwarded-For"))
                        {
                            context.Connection.RemoteIpAddress = IPAddress.Parse(headers["X-Forwarded-For"].ToString().Split(',', StringSplitOptions.RemoveEmptyEntries)[0]);
                        }
                        var ip = context.Connection.RemoteIpAddress.MapToIPv4().ToString();
                        logger.Trace($"{ip}|{context.Response.StatusCode}|{watch.ElapsedMilliseconds}|{context.Request.Method} => {context.Request.Path.Value}{context.Request.QueryString}");
                    }
                }
                finally
                {
                }
                return Task.CompletedTask;
            });
        }
        await _next.Invoke(context);
    }
}
/// <summary>
/// 请求记录中间件扩展类
/// </summary>
public static class RequestLogMiddlewareExtensions
{
    /// <summary>
    /// 添加请求日志记录中间件
    /// </summary>
    /// <param name="builder"></param>
    /// <remarks>
    /// 日志格式 Host ==> ConnectId ==> Scheme ==> Method ==> Path ==> QueryString ==>Response Status ==> Response ContentLength ==> Response Time
    /// 日志记录级别为 Trace
    /// </remarks>
    /// <returns></returns>
    public static IApplicationBuilder UseRequestLogHandler(this IApplicationBuilder builder)
    {
        builder.UseMiddleware<RequestLogMiddleware>();
        return builder;
    }
}

 

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
8月前
【记录】有关接口响应很快,但是在页面渲染的时候发现很慢的问题
【记录】有关接口响应很快,但是在页面渲染的时候发现很慢的问题
193 0
|
8月前
|
Web App开发 前端开发 网络协议
API 请求慢?这次锅真不在后端
API 请求慢?这次锅真不在后端
114 0
|
前端开发 测试技术
【前端验证】记录将发包量作为传参以加速debug的环境优化记录
【前端验证】记录将发包量作为传参以加速debug的环境优化记录
|
5月前
|
开发框架 缓存 .NET
并发请求太多,服务器崩溃了?试试使用 ASP.NET Core Web API 操作筛选器对请求进行限流
并发请求太多,服务器崩溃了?试试使用 ASP.NET Core Web API 操作筛选器对请求进行限流
248 0
|
3月前
|
缓存 网络协议 API
【Azure 环境】请求经过应用程序网关,当响应内容大时遇见504超时报错
应用程序网关的响应缓冲区可以收集后端服务器发送的全部或部分响应数据包,然后再将它们发送给客户端。 默认在应用程序网关上启用响应缓冲,这对于适应缓慢的客户端很有用。
|
5月前
WebApi 接口请求耗时记录
WebApi 接口请求耗时记录
29 0
|
6月前
|
机器学习/深度学习 人工智能 缓存
函数计算产品使用问题之在第一次启动时请求外部接口总是超时,是什么导致的
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
6月前
|
前端开发
纯前端模拟后端接口异步获取数据
纯前端模拟后端接口异步获取数据
50 0
|
缓存 NoSQL 前端开发
若依系统(分离版)后台接口被调时,代码哪里判断了token是否超时?
若依系统(分离版)后台接口被调时,代码哪里判断了token是否超时?
1267 0
|
网络协议 前端开发 数据可视化
前端抱怨 API 响应慢,到底慢在哪里?
前端抱怨 API 响应慢,到底慢在哪里?
390 0
前端抱怨 API 响应慢,到底慢在哪里?

热门文章

最新文章