springboot集成log4j2,Spring集成log4j2解决方案整理总结
2021-06-11 13:04
标签:tis jvm project boot home lam rate 错误信息 巴巴 参考网站: https://www.cnblogs.com/keeya/p/10101547.html 最详细的Log4j使用教程 Spring 中配置log4j日志功能 SSM框架+Log4j框架搭建 spring mvc中log4j****的配置与使用 log4j.properties和log4j.xml有什么区别 如果properties不能满足你的要求了,你自然就需要用xml了。 xml可以保存多属性的复杂对象结构。 web项目Log4j日志输出路径配置问题 问题描述:一个web项目想在一个tomcat下运行多个实例(通过修改war包名称的实现),然后每个实例都将日志输出到tomcat的logs目录下实例名命名的文件夹下进行区分查看每个实例日志,要求通过尽可能少的改动配置文件,最好修改实例名后可以不修改log4j的配置文件。 实现分析:一般实现上面需求,需要在修改完war包名称之外要再做下面配置: 1、修改每个实例名下web.xml中参数webAppRootKey为不同值。同一个tomcat下运行多个web应用时,该值相同的话,运行时会抛异常。 ? ? ? ? 2、log4j配置文件日志输出路径修改 log4j配置文件中路径配置一般有三种方法: (1)绝对路径法:直接配置为系统觉得路径; (2)相对路径法:(路径是相对于Tomcat/bin路径) ? log4j.appender.logfile.File=../logs/app.log,将日志记录到tomcat下的logs文件夹; ? log4j.appender.logfile.File=logs/app.log,将日志记录到tomcat的bin目录下的logs文件夹; (3)使用环境变量相对路径法:程序会优先找jvm环境变量,然后再找系统环境变量,来查找配置文件中的变量。 ? log4j.appender.logfile.File=${user.dir}/logs/app.log,使用tomcat容器时${user.dir}对应tomcat的bin目录; ? log4j.appender.logfile.File=${user.home}/logs/app.log,${user.home}对应操作系统当前用户目录; ? log4j.appender.logfile.File=${webApp.root}/logs/app.log,${webApp.root}对应当前应用根目录; 暂时没找到不修改log4j配置而实现上面需求的方法。在log4j配置文件中可以获取环境变量来配置,但变量里没有当前应用的名称(不能直接通过webApp.root,因为它在不同的实例名称不一样),尝试在web.xml中增加listener,获取应用名称,然后调用System.setProperty("contextPath", sce.getServletContext().getContextPath());将上下文设置到系统变量中在log4j应用,但多实例运行时每个实例都会改变该属性值。 结论,该问题的解决方法: 1、手动修改配置,修改war名称后手动修改web.xml和log4j配置文件,实现上述需求。 2、通过其它程序来进行批量修改,若bat或maven等在修改war包名称时,自动修改掉web.xml和log4j中相关配置。 springboot集成log4j2,Spring集成log4j2解决方案整理总结 标签:tis jvm project boot home lam rate 错误信息 巴巴 原文地址:https://www.cnblogs.com/linuxtop/p/14224875.html
Log4J
常用日志框架
为什么选用Log4j2
相比与其他的日志系统,log4j2丢数据这种情况少;disruptor技术,在多线程环境下,性能高于logback等10倍以上;利用jdk1.5并发的特性,减少了死锁的发生;
springboot集成log4j2(已实践:该操作没问题,很便捷)
1.引入jar包
springboot默认是用logback的日志框架的,所以需要排除logback,不然会出现jar依赖冲突的报错。
Spring集成log4j2(已验证、可用)
https://www.cnblogs.com/fukua123/p/10692247.html
#1、配置pom.xml,引用log4j2相关包
参考log4j2.xml
在这里简单介绍下常用的配置参数**
1.日志级别
机制:如果一条日志信息的级别大于等于配置文件的级别,就记录。
trace:追踪,就是程序推进一下,可以写个trace输出
debug:调试,一般作为最低级别,trace基本不用。
info:输出重要的信息,使用较多
warn:警告,有些信息不是错误信息,但也要给程序员一些提示。
error:错误信息。用的也很多。
fatal:致命错误。
2.输出源
CONSOLE(输出到控制台)
FILE(输出到文件)
3.格式
SimpleLayout:以简单的形式显示
HTMLLayout:以HTML表格显示
PatternLayout:自定义形式显示
PatternLayout自定义日志布局:
%d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生产时间,输出到毫秒的时间
%-5level : 输出日志级别,-5表示左对齐并且固定输出5个字符,如果不足在右边补0
%c : logger的名称(%logger)
%t : 输出当前线程名称
%p : 日志输出格式
%m : 日志内容,即 logger.info("message")
%n : 换行符
%C : Java类名(%F)
%L : 行号
%M : 方法名
%l : 输出语句所在的行数, 包括类名、方法名、文件名、行数
hostName : 本地机器名
hostAddress : 本地ip地址
为什么阿里巴巴禁止工程师直接使用日志系统(Log4j、Logback)中的 API
对于Java工程师来说,关于日志工具的使用,最佳实践就是在应用中使用如Log4j + SLF4J 这样的组合来进行日志输出。
这样做的最大好处,就是业务层的开发不需要关心底层日志框架的实现及细节,在编码的时候也不需要考虑日后更换框架所带来的成本。这也是门面模式所带来的好处。
综上,请不要在你的Java代码中出现任何Log4j等日志框架的API的使用,而是应该直接使用SLF4J这种日志门面。
logback log4j log4j2 性能实测
https://blog.csdn.net/yjh1271845364/article/details/70888262
可见在同步日志模式下, Logback的性能是最糟糕的.
而log4j2的性能无论在同步日志模式还是异步日志模式下都是最佳的.
其根本原因在于log4j2使用了LMAX, 一个无锁的线程间通信库代替了, logback和log4j之前的队列. 并发性能大大提升, 下期文章将研究一下LMAX, 到底是什么
关于log4j2的新特性
丢数据这种情况少,可以用来做审计功能。而且自身内部报的exception会被发现,但是logback和log4j不会。
log4j2使用了disruptor技术,在多线程环境下,性能高于logback等10倍以上。
(garbage free)之前的版本会产生非常多的临时对象,会造成GC频繁,log4j2则在这方面上做了优化,减少产生临时对象。尽可能少的GC
利用插件系统,使得扩展新的appender,filter,layout等变得容易,log4j不可以扩展 插件????
因为插件系统的简单性,所以在配置的时候,可以不用具体指定所要处理的类型。class
可以自定义level
Java 8 lambda support for lazy logging
Support for Message objects
对filter的功能支持的更强大
系统日志(Syslog)协议supports both TCP and UDP
利用jdk1.5并发的特性,减少了死锁的发生。
Socket LogEvent SerializedLayout
支持kafka queue
参考文章
文章标题:springboot集成log4j2,Spring集成log4j2解决方案整理总结
文章链接:http://soscw.com/index.php/essay/93591.html