热门标签 | 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();
}
}

推荐阅读
  • EPPlus绘制刻度线的方法及示例代码
    本文介绍了使用EPPlus绘制刻度线的方法,并提供了示例代码。通过ExcelPackage类和List对象,可以实现在Excel中绘制刻度线的功能。具体的方法和示例代码在文章中进行了详细的介绍和演示。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • PHPMailer邮件类邮件发送功能的使用教学及注意事项
    本文介绍了使用国外开源码PHPMailer邮件类实现邮件发送功能的简单教学,同时提供了一些注意事项。文章涵盖了字符集设置、发送HTML格式邮件、群发邮件以及避免类的重定义等方面的内容。此外,还提供了一些与PHP相关的资源和服务,如传奇手游游戏源码下载、vscode字体调整、数据恢复、Ubuntu实验环境搭建、北京爬虫市场、进阶PHP和SEO人员需注意的内容。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • 本文介绍了使用哈夫曼树实现文件压缩和解压的方法。首先对数据结构课程设计中的代码进行了分析,包括使用时间调用、常量定义和统计文件中各个字符时相关的结构体。然后讨论了哈夫曼树的实现原理和算法。最后介绍了文件压缩和解压的具体步骤,包括字符统计、构建哈夫曼树、生成编码表、编码和解码过程。通过实例演示了文件压缩和解压的效果。本文的内容对于理解哈夫曼树的实现原理和应用具有一定的参考价值。 ... [详细]
  • 本文介绍了一种在PHP中对二维数组根据某个字段进行排序的方法,以年龄字段为例,按照倒序的方式进行排序,并给出了具体的代码实现。 ... [详细]
  • 本文介绍了如何使用PHP代码将表格导出为UTF8格式的Excel文件。首先,需要连接到数据库并获取表格的列名。然后,设置文件名和文件指针,并将内容写入文件。最后,设置响应头部,将文件作为附件下载。 ... [详细]
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社区 版权所有