logback 自定义log字段(MDC)推送到logstash(spring boot + logback+ logstash)

这篇具有很好参考价值的文章主要介绍了logback 自定义log字段(MDC)推送到logstash(spring boot + logback+ logstash)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

直接上代码:

1.创建FIlter,往 MDC 里面追加内容

@WebFilter
@Component
public class LogBackFilter implements Filter {
    

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
        // LOGSTASH 日志附加信息追加
        addMDC(request,response,chain);
        
    }

    @Override
    public void destroy() {
        
        rmMDC();
    }

    private void addMDC(ServletRequest request, ServletResponse response, FilterChain chain){

        HttpServletRequest httpServletRequest = ((HttpServletRequest) request);

        String uuid = UUID.randomUUID().toString();
        MDC.put(LogConstant.REQUEST_ID, uuid);

        String remoteIp = request.getRemoteAddr();
        MDC.put(LogConstant.REQUEST_RM_IP, remoteIp);

        String remoteHost = request.getRemoteHost();
        MDC.put(LogConstant.REQUEST_RM_HOST, remoteHost);

        String uri =  httpServletRequest.getRequestURI();
        MDC.put(LogConstant.REQUEST_URI, uri);

        AuthUser authUser = UserContext.getCurrentUser();
        if(authUser!=null){
            MDC.put(LogConstant.REQUEST_USER_ID, authUser.getId());
        }
    }

    private void rmMDC(){
        MDC.remove(LogConstant.REQUEST_ID);
        MDC.remove(LogConstant.REQUEST_RM_IP);
        MDC.remove(LogConstant.REQUEST_RM_HOST);
        MDC.remove(LogConstant.REQUEST_URI);
        MDC.remove(LogConstant.REQUEST_USER_ID);
    }
}

2.logback配置:

includeMdcKeyName 标签 追加 mdc中的key文章来源地址https://www.toymoban.com/news/detail-608005.html

 <!--输出到elk的LOGSTASH-->
    <appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
        <!-- 配置elk日志收集 配饰的是 LOGSTASH 的地址-->
        <destination>${LOGSTASH_SERVER}</destination>
        <encoder charset="UTF-8" class="net.logstash.logback.encoder.LogstashEncoder">
            <providers>
                <timestamp>
                    <timeZone>UTC</timeZone>
                </timestamp>
            </providers>
            
            <includeCallerData>true</includeCallerData>
            <includeMdc>true</includeMdc>

            <!-- MDC字段 -->
            <includeMdcKeyName>X-Request-Id</includeMdcKeyName>
            <includeMdcKeyName>X-Request-Uri</includeMdcKeyName>
            <includeMdcKeyName>X-Request-UserId</includeMdcKeyName>
            <includeMdcKeyName>X-Request-Rm-Ip</includeMdcKeyName>
            <includeMdcKeyName>X-Request-Rm-Host</includeMdcKeyName>

            <!--自定义字段 区分项目-->
            <customFields>{"appName":"${APP_NAME}"}</customFields>

        </encoder>
    </appender>

到了这里,关于logback 自定义log字段(MDC)推送到logstash(spring boot + logback+ logstash)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Could not initialize Logback logging from classpath:logback-spring.xml 错误解决

    1. 问题发生    springboot 项目以前运行时没有问题,但是重装系统换了个IDEA运行项目忽然报错如下: 2. 排查过程   本来我只注意到 Could not initialize Logback logging from classpath:logback-spring.xml 这个提示,我以为是别人动到了代码,看了下提交记录也没有,经过网上排查,有说是

    2024年02月12日
    浏览(35)
  • Spring Boot多环境配置及Logback日志记录

    Spring Boot多环境配置 logback日志记录器 Spring Boot的针对不同的环境创建不同的配置文件, 语法结构:application-{profile}.properties profile:代表的就是一套环境 application-dev.yml 开发环境 端口8090 application-test.yml 测试环境 端口8091 application-prod.yml 生产环境 端口8092 在application.yml 中激活

    2024年01月19日
    浏览(34)
  • 在Spring Cloud架构下使用Spring Boot的Logback日志处理方案

    在pom.xml文件中添加以下依赖: 在src/main/resources目录下创建logback.xml文件,并添加以下配置: 其中,LOG_HOME为日志文件输出路径,可以根据需要进行修改。 下面是logback.xml配置文件的主要内容: 3.1 配置输出位置 3.2 配置输出格式 定义了日志输出的格式,包括时间、线程、日志

    2024年02月09日
    浏览(34)
  • Spring Boot日志:SLF4J和Logback

    SpringBoot中的日志库分为两种: 实现库:提供具体的日志实现,例如日志级别的控制、打印格式、输出目标等。 外观库:自身不提供日志实现,而是对其他日志库进行封装,从而方便使用。基于外观模式实现。 关于外观库的出现,可设想一下:现在有多种日志库,每一种接口

    2024年02月15日
    浏览(32)
  • Spring Boot学习随笔- 本地化测试(@SpringBootTest)、热部署(spring-boot-devtools)、日志Logback常用级别使用、指定包级别输出

    学习视频:【编程不良人】2021年SpringBoot最新最全教程 频繁启动服务器进行功能的访问非常繁琐、SpringBoot给我们提供了用于测试的依赖,自动集成Junit,使用了这个以来后,test包在打包时不会被打包进去 @SpringBootTest注解 修饰在类上,用来启动本地Spring环境 作用 热部署是指

    2024年02月05日
    浏览(61)
  • logback 集成 logstash

    相关环境参考: Java 输出 JSON 日志 如果原有配置文件中需要保留一些特殊配置时,需要理解这里的配置才能将配置应用到已有的配置中。 3.1 动态刷新 想要在应用运行时看到修改配置文件后的效果,可以在原有配置添加: 3.2 优雅关机 增加logstash配置后,为了让程序在关闭时

    2024年02月01日
    浏览(24)
  • 日志采集 logback集成logstash ELK springboot

    logstash依赖  给logback配置logstash的那台机器的ip和服务的端口  在logstash那台机器上配置  在安装了logstash的服务器里,找到logstash文件目录,执行./logstash -f logstash.conf即可启动logstash 以上配置即可实现 logback 到 logstash。 下面是升级配置 ===========================分割线===============

    2024年02月12日
    浏览(34)
  • Logstash Logback Encoder实现ELK日志归集

    搭建SpringCloud平台日志归集方案,主要使用Logstash Logback Encoder组件实现。 主要分为运维相关的配置和开发相关的配置,具体分类无需纠结,都了解一遍即可。 不足之处,各位大神指出,感谢~ Elasticsearch配置 新建Index Templates,Mapping参考值如下,具体参考值可参考 Logstash Logba

    2024年02月11日
    浏览(37)
  • Spring Boot 配置 log4j2

    本教程中,我们将学习如何在 Spring Boot 中整合使用 Log4j2 日志框架。 Spring Boot 中默认使用 Logback 作为日志框架,接下来我们将学习如何在 Spring Boot 中集成与配置 Log4j2。在配置之前,我们需要知道的是 Log4j2 是 Log4j 的升级版,它在 Log4j 的基础上做了诸多改进: 1.异步日志;

    2024年02月08日
    浏览(26)
  • Spring Boot整合Log4j2.xml的问题

    Spring Boot整合Log4j2.xml的时候返回以下错误: Caused by: org.apache.logging.log4j.LoggingException: log4j-slf4j-impl cannot be present with log4j-to-slf4j 进行了解决。 Spring Boot整合Log4j2.xml经过以下操作: 配置 log4j2.xml 添加到 src/main/resources 目录下 Gradle的配置:在 build.gradle 中添加: 启动应用,返回以

    2024年02月09日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包