当前位置:首页 > 科技  > 软件

基于Spring Boot,为网络请求添加唯一日志id

来源: 责编: 时间:2024-01-02 09:31:09 292观看
导读1 简介在Web应用程序的世界中,有效的请求监控和可追踪性对于维护系统完整性和诊断问题至关重要。Spring Boot是一种流行的Java框架,用于构建应用程序,并提供强大的日志记录功能。为了进一步丰富这一功能,可以通过为每个传

1 简介

在Web应用程序的世界中,有效的请求监控和可追踪性对于维护系统完整性和诊断问题至关重要。Spring Boot是一种流行的Java框架,用于构建应用程序,并提供强大的日志记录功能。为了进一步丰富这一功能,可以通过为每个传入请求添加唯一标识符来增强日志记录能力。这种简洁而强大的实践使开发人员能够跟踪和分析单个请求的流程,简化调试,并增强整个系统的可靠性。bFI28资讯网——每日最新资讯28at.com

本文我们强调在Spring Boot中为日志添加唯一标识符的重要性,介绍其实现方式以及其为应用程序开发和维护带来的众多优势好处。bFI28资讯网——每日最新资讯28at.com

2 问题描述

如今,每个服务通常都有多个服务器实例。有两种方法可以查看日志,一种是逐个访问各个服务器实例以查看日志,另一种是收集所有服务器的日志到一个集中地点进行查看。通常情况下,人们会选择第二种方法,使用像GCP中的Log Explorer这样的工具来搜索和分析日志。然而,由于来自多个服务器的大量日志,追踪这些日志变得困难。bFI28资讯网——每日最新资讯28at.com

此外,即使对于只有一个服务的单个服务器,由于并发请求和线程,日志会被打印出很多条。其中一个主要问题是日志打印的交错性,很难跟踪打印出的日志。bFI28资讯网——每日最新资讯28at.com

3 解决方案

为了解决上述问题,需要为每个日志条目关联一种标识符。我们可以生成一个唯一的ID,然后将该ID分配给特定请求的所有日志。因此,为特定请求生成的所有日志都具有唯一的ID。借助这个ID,可以便捷地跟踪日志。我们可以在日志中搜索此ID并获取特定请求的所有日志。在Spring Boot中实现这一点,可以使用AOP。bFI28资讯网——每日最新资讯28at.com

面向方面的编程(AOP)是一种编程范式,允许开发人员将横切关注点(如日志记录、安全性和事务管理)与核心业务逻辑分开模块化,促进代码的可重用性和可维护性。它通过引入“切面”在代码库的不同部分应用,而无需修改原始代码。bFI28资讯网——每日最新资讯28at.com

首先,需要创建一个请求过滤器,如下所示:bFI28资讯网——每日最新资讯28at.com

/** * A filter that adds a key to the Mapped Diagnostic Context (MDC) to each request so you can print a unique id in the log messages of each request **/@EqualsAndHashCode(callSuper = false)@Component@Slf4jpublic class Slf4jMDCFilter extends OncePerRequestFilter {    @Override    protected void doFilterInternal(final HttpServletRequest request, final HttpServletResponse response, final FilterChain chain) {        try {            MDC.put(MDC_UUID_TOKEN_KEY, UUID.randomUUID().toString());            chain.doFilter(request, response);        } catch (Exception ex) {            log.error(ERROR_FORMAT, "Exception occurred in filter while setting UUID for logs", ex);        } finally {            MDC.remove(MDC_UUID_TOKEN_KEY);        }    }    @Override    protected boolean isAsyncDispatch(final HttpServletRequest request) {        return false;    }    @Override    protected boolean shouldNotFilterErrorDispatch() {        return false;    }}

上述代码对每个API请求运行一次,并将相同的唯一ID添加到为特定请求生成的所有日志中。接下来,需要将上述AOP过滤器注册为一个bean,如下所示:bFI28资讯网——每日最新资讯28at.com

@Configuration@RequiredArgsConstructorpublic class BeanConfig {    private final Slf4jMDCFilter slf4jMDCFilter;    @Bean    public FilterRegistrationBean<Slf4jMDCFilter> servletRegistrationBean() {        final FilterRegistrationBean<Slf4jMDCFilter> filterRegistrationBean = new FilterRegistrationBean<>();        filterRegistrationBean.setFilter(slf4jMDCFilter);        filterRegistrationBean.setOrder(2);        return filterRegistrationBean;    }}

然后,需要在日志配置文件中添加一个appender,如下所示:bFI28资讯网——每日最新资讯28at.com

<appender name="Console" class="ch.qos.logback.core.ConsoleAppender">    <layout class="ch.qos.logback.classic.PatternLayout">        <Pattern>            %black(%d{ISO8601}) %X{Slf4jMDCFilter.UUID} %highlight(%-5level) [%blue(%t)] %yellow(%C{1}.): %msg%n%throwable        </Pattern>    </layout></appender>

4 结语

在Spring Boot中为每个请求的日志实现唯一标识符可以通过关联应用程序的不同组件中的日志,特别是在并发情况下,提供更好的可追踪性和调试能力。这个唯一标识符有助于跟踪请求的流程,识别潜在问题,并提高整个系统的可观察性。bFI28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-55176-0.html基于Spring Boot,为网络请求添加唯一日志id

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 九个技巧让你的PyTorch模型训练飞快!

下一篇: 九个技巧让你的PyTorch模型训练飞快!

标签:
  • 热门焦点
  • 如何正确使用:Has和:Nth-Last-Child

    我们可以用CSS检查,以了解一组元素的数量是否小于或等于一个数字。例如,一个拥有三个或更多子项的grid。你可能会想,为什么需要这样做呢?在某些情况下,一个组件或一个布局可能会
  • 分享六款相见恨晚的PPT模版网站, 祝你做出精美的PPT!

    1、OfficePLUSOfficePLUS网站旨在为全球Office用户提供丰富的高品质原创PPT模板、实用文档、数据图表及个性化定制服务。优点:OfficePLUS是微软官方网站,囊括PPT模板、Word模
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 微软邀请 Microsoft 365 商业用户,测试视频编辑器 Clipchamp

    8 月 1 日消息,微软近日宣布即将面向 Microsoft 365 商业用户,开放 Clipchamp 应用,邀请用户通过该应用来编辑视频。微软于 2021 年收购 Clipchamp,随后开始逐步整合到 Microsof
  • 每天一道面试题-CPU伪共享

    前言:了不起:又到了每天一到面试题的时候了!学弟,最近学习的怎么样啊 了不起学弟:最近学习的还不错,每天都在学习,每天都在进步! 了不起:那你最近学习的什么呢? 了不起学弟:最近在学习C
  • 微博大门常打开,迎接海外画师漂洋东渡

    作者:互联网那些事&ldquo;起猛了,我能看得懂日语了&rdquo;。&ldquo;为什么日本人说话我能听懂?&rdquo;&ldquo;中文不像中文,日语不像日语,但是我竟然看懂了&rdquo;&hellip;&hell
  • 支持aptX Lossless无损传输 iQOO TWS 1赛道版发布限时优惠价369元

    2023年7月4日,“无损音质,声动人心”iQOO TWS 1正式发布,支持aptX Lossless无损传输,限时优惠价369元。iQOO TWS 1耳机率先支持端到端aptX Lossless无
  • iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • 北京:科技教育体验基地开始登记

      北京“科技馆之城”科技教育体验基地登记和认证工作日前启动。首批北京科技教育体验基地拟于2023年全国科普日期间挂牌,后续还将开展常态化登记。  北京科技教育体验基
Top