如何将Log4j彻底切换成logback?
之前有篇文章《彻底搞明白为什么日志框架依赖冲突了》介绍了同一项目中因为依赖了多个日志实现而导致的异常。log4j和logback都是日志实现,通常情况下,我们项目中都不会直接使用实现类,而是使用slf4j、jcl、log4j-api等日志facade。这样最大的好处就是,项目不会和某一日志框架绑定。
本篇将介绍如果把项目的日志框架切换成logback,切成其它的实现同理实现即可。
1、排除项目中所有的log4j、log4j-core相关的依赖。
这里推荐idea插件Maven helper工具,来查看和管理依赖。
在这个界面上可以查到项目中直接依赖和间接依赖的所有的log4j的jar,然后选中右键排除即可。
2、桥接其它日志框架到slf4j
如果某个jar破坏了“我们项目中都不会直接使用实现类”这个原则,直接使用了log4j里面的类,那怎么办?排掉项目就回报错,比如:
2021-12-29 14:50:12 ERROR c.q.b.d.c.GlobalDefaultExceptionHandler - Exception occurred: Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: org/apache/log4j/Level
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: org/apache/log4j/Level
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1006)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:925)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:974)
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:866)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:503)
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:851)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:590)