Spring Boot 2结合Log4j2实现API接口路径动态日志保存
本文介绍如何在Spring Boot 2应用中利用Log4j2,根据API接口路径动态生成并保存日志文件。这需要比简单使用RollingFileAppender更灵活的日志记录机制。
目标:为每个API接口(例如/paypage/createorder/addsave,/merchant/goodlist/getlistbyquery)创建独立的日志文件,保存在jar包目录/logs/接口路径/yyyy-mm-dd.log下。
问题:直接在main函数或拦截器中修改Log4j2配置文件文件名无效,因为配置文件加载时机过早。
解决方案:使用Log4j2的RoutingAppender。RoutingAppender根据运行时条件将日志路由到不同的Appender。结合ThreadContext,我们可以将API路径作为路由键,动态控制日志文件路径。
实现步骤:
<Routing name="routing"> <Routes pattern="${ctx:routingkey}"> <Route> <RollingFile name="rolling-${ctx:routingkey}" filename="./logs/${ctx:routingkey}/${date:yyyy-mm-dd}.log" filePattern="./logs/${date:yyyy-mm}/${ctx:routingkey}-%d{yyyy-mm-dd}-%i.log.gz"> <PatternLayout pattern="%d{iso8601} [%t] %p %c{3} - %m%n"/> <Policies> <TimeBasedTriggeringPolicy interval="1" modulate="true"/> <SizeBasedTriggeringPolicy size="10MB"/> </Policies> </RollingFile> </Route> </Routes> </Routing>
public class Log4j2Interceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { String apiPath = request.getRequestURI(); ThreadContext.put("ROUTINGKEY", apiPath); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { ThreadContext.remove("ROUTINGKEY"); } }
通过以上步骤,Spring Boot 2应用即可根据API接口路径动态生成日志文件,实现更精细的日志管理。 请确保日志目录存在且具有写入权限。 RoutingAppender的路由规则可根据实际需求调整。
以上就是Spring Boot 2中如何使用Log4j2实现按API接口路径动态保存日志?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号