热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

自定义注解实现logback配置按名称打印日志

首先是目录结构

首先是目录结构

目录结构图

logback-spring.xml


<configuration scan="true" scanPeriod="10 seconds" debug="false">

<include resource="logback/logback-base.xml"/>

<springProfile name="dev">

<include resource="logback/logback-dev.xml"/>
springProfile>

<springProfile name="prod">

<include resource="logback/logback-prod.xml"/>
springProfile>
configuration>

logback-base.xml

<included>

<springProperty name="LOGGER_FILE_MAX_SIZE" scope="context" source="logback.filesize" defaultValue="5MB"/>

<springProperty name="LOGGER_FILE_MAX_DAY" scope="context" source="logback.filemaxday" defaultValue="2"/>

<property name="LOGGER_FILE_PATH" value="logs"/>

<property name="CHARSET" value="utf-8"/>

<property name="TOTAL_SIZE_CAP" value="1GB" />

<property name="LOG_PATTERN"
value="%d{yyyy-MM-dd HH:mm:ss.SSS} %level ${PID} [%thread] %logger %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wex}"/>

<conversionRule conversionWord="wex"
converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter"/>

included>

logback-dev.xml

<included>
<property name="DEV_LOGGER_LEVEL" value="DEBUG"/>

<property name="CONSOLE-LOG-PATTERN"
value="%red(%date{yyyy-MM-dd HH:mm:ss}) %highlight(%-5level) %red([%thread]) %boldMagenta(%logger{50}) %cyan(%msg%n)"/>

<appender name="stdoutAppender" class="ch.qos.logback.core.ConsoleAppender">
<withJansi>truewithJansi>
<encoder>
<pattern>${CONSOLE-LOG-PATTERN}pattern>
<charset>${CHARSET}charset>
encoder>
appender>
<appender name="console-async-appender" class="ch.qos.logback.classic.AsyncAppender">
<discardingThreshold>0discardingThreshold>
<appender-ref ref="stdoutAppender"/>
appender>
<root level="${DEV_LOGGER_LEVEL}" additivity="false">
<appender-ref ref="console-async-appender"/>
root>
included>

logback-prod.xml

<included>
<property name="PROD_LOGGER_LEVEL" value="INFO"/>
<appender name="data-appender-error" class="ch.qos.logback.classic.sift.SiftingAppender">
<discriminator>
<key>jobNamekey>
<defaultValue>systemdefaultValue>
discriminator>
<sift>
<appender name="${jobName}-error" class="ch.qos.logback.core.rolling.RollingFileAppender">
<encoder>
<pattern>${LOG_PATTERN}pattern>
<charset>${CHARSET}charset>
encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOGGER_FILE_PATH}/${jobName}.%d{yyyy-MM-dd}.%i.errorfileNamePattern>
<maxHistory>${LOGGER_FILE_MAX_DAY}maxHistory>
<maxFileSize>${LOGGER_FILE_MAX_SIZE}maxFileSize>
<totalSizeCap>${TOTAL_SIZE_CAP}totalSizeCap>
<cleanHistoryOnStart>truecleanHistoryOnStart>
rollingPolicy>
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>ERRORlevel>
filter>
appender>
sift>
appender>
<appender name="data-appender-info" class="ch.qos.logback.classic.sift.SiftingAppender">
<discriminator>
<key>jobNamekey>
<defaultValue>systemdefaultValue>
discriminator>
<sift>
<appender name="${jobName}-info" class="ch.qos.logback.core.rolling.RollingFileAppender">
<encoder>
<pattern>${LOG_PATTERN}pattern>
<charset>${CHARSET}charset>
encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOGGER_FILE_PATH}/${jobName}.%d{yyyy-MM-dd}.%i.logfileNamePattern>
<maxHistory>${LOGGER_FILE_MAX_DAY}maxHistory>
<maxFileSize>${LOGGER_FILE_MAX_SIZE}maxFileSize>
<totalSizeCap>${TOTAL_SIZE_CAP}totalSizeCap>
<cleanHistoryOnStart>truecleanHistoryOnStart>
rollingPolicy>
<filter class="ch.qos.logback.classic.filter.LevelFilter">

<level>ERRORlevel>

<onMatch>DENYonMatch>

<onMismatch>ACCEPTonMismatch>
filter>
appender>
sift>
appender>
<appender name="file_async" class="ch.qos.logback.classic.AsyncAppender">
<discardingThreshold>0discardingThreshold>
<appender-ref ref="data-appender-info"/>
appender>
<appender name="error_file_async" class="ch.qos.logback.classic.AsyncAppender">
<discardingThreshold>0discardingThreshold>
<appender-ref ref="data-appender-error"/>
appender>
<logger name="根路径" level="error" additivity="false">
<appender-ref ref="error_file_async"/>
logger>
<logger name="根路径" level="${PROD_LOGGER_LEVEL}" additivity="false">
<appender-ref ref="file_async"/>
logger>
<root level="${PROD_LOGGER_LEVEL}">
<appender-ref ref="file_async"/>
<appender-ref ref="error_file_async"/>
root>
included>

最后是注解的实现,技术是logback的Mdc,只要任务在同一个线程内就可以实现日志区分

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface MdcLogger {
/**
* logger MDC对应的value值
* @return
*/

String value();
}

Aop的实现

@Aspect
@Component
public class MdcLoggerAspect {
private static Logger logger = LoggerFactory.getLogger(MdcLoggerAspect.class);
/**
* 切入点
*/

@Pointcut("@annotation(com.lz.bigdata.synchronizer.biz.dy.domain.annotation.MdcLogger)")
public void mdcLoggerCutPoint() {
logger.info("MDC切入点");
}
@Before("mdcLoggerCutPoint()")
public void mdcLoggerBefore(JoinPoint joinPoint) {
MdcLogger mdcLoggerAnnotation = ((MethodSignature) joinPoint.getSignature()).getMethod().getDeclaredAnnotation(MdcLogger.class);
String value = mdcLoggerAnnotation.value();
// String methodName = joinPoint.getTarget().getClass().getSimpleName() + "." + joinPoint.getSignature().getName();
MDC.put(配置文件定义的名称(此文章是jobName), value);
}
@After("mdcLoggerCutPoint()")
public void mdcLoggerAfter() {
MDC.clear();
}
}

推荐阅读
  • Android与JUnit集成测试实践
    本文探讨了如何在Android项目中集成JUnit进行单元测试,并详细介绍了修改AndroidManifest.xml文件以支持测试的方法。 ... [详细]
  • 深入理解:AJAX学习指南
    本文详细探讨了AJAX的基本概念、工作原理及其在现代Web开发中的应用,旨在为初学者提供全面的学习资料。 ... [详细]
  • HTML:  将文件拖拽到此区域 ... [详细]
  • 函子(Functor)是函数式编程中的一个重要概念,它不仅是一个特殊的容器,还提供了一种优雅的方式来处理值和函数。本文将详细介绍函子的基本概念及其在函数式编程中的应用,包括如何通过函子控制副作用、处理异常以及进行异步操作。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 本文详细介绍了如何在Oracle VM VirtualBox中实现主机与虚拟机之间的数据交换,包括安装Guest Additions增强功能,以及如何利用这些功能进行文件传输、屏幕调整等操作。 ... [详细]
  • CSS Border 属性:solid 边框的使用详解
    本文详细介绍了如何在CSS中使用solid边框属性,包括其基本语法、应用场景及高级技巧,适合初学者和进阶用户参考。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • 如何在PyCharm中配置Python脚本的默认模板
    本文介绍如何在PyCharm中设置Python脚本的默认模板,以便每次创建新的.py文件时自动填充预设内容,提高开发效率。 ... [详细]
  • 一、Advice执行顺序二、Advice在同一个Aspect中三、Advice在不同的Aspect中一、Advice执行顺序如果多个Advice和同一个JointPoint连接& ... [详细]
  • 问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ... [详细]
  • OBS Studio自动化实践:利用脚本批量生成录制场景
    本文探讨了如何利用OBS Studio进行高效录屏,并通过脚本实现场景的自动生成。适合对自动化办公感兴趣的读者。 ... [详细]
  • Bootstrap Paginator 分页插件详解与应用
    本文深入探讨了Bootstrap Paginator这款流行的JavaScript分页插件,提供了详细的使用指南和示例代码,旨在帮助开发者更好地理解和利用该工具进行高效的数据展示。 ... [详细]
  • 在尝试使用 Android 发送 SOAP 请求时遇到错误,服务器返回 '无法处理请求' 的信息,并指出某个值不能为 null。本文探讨了可能的原因及解决方案。 ... [详细]
author-avatar
书友56183408
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有