内容简介:使用spring-boot框架开发的项目中,默认的logback格式可能默认是如下的格式:假设有一种场景,我们希望能够将业务数据加入到access日志中,方便统计每个接口在用户粒度的调用量。那么在分布式日志服务中,我们可以考虑在每行的access日志中,添加用户的id,方便直接解析到es中,在es中计算count即可。
前言
使用spring-boot框架开发的项目中,默认的logback格式可能默认是如下的格式:
<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="access." suffix=".log"
pattern="%h %l %u %t "%r" %s %b "%{Referer}i" "%{User-Agent}i" %{X-Forwarded-For}i "%Dms"" resolveHosts="false"/>
假设有一种场景,我们希望能够将业务数据加入到access日志中,方便统计每个接口在用户粒度的调用量。
那么在分布式日志服务中,我们可以考虑在每行的access日志中,添加用户的id,方便直接解析到es中,在es中计算count即可。
本文主要解决access日志中添加userId的问题。
具体思路
tomcat的access日志配置介绍可以参考博文:【 Tomcat Access Log配置 】
在上述博文中,我们可以看到如下内容:
Access Log中也支持cookie,请求header,响应headers,Session或者其他在ServletRequest中的对象的信息。格式遵循apache语法
%{xxx}i 请求headers的信息
%{xxx}o 响应headers的信息
%{xxx}c 请求cookie的信息
%{xxx}r xxx是ServletRequest的一个属性
%{xxx}s xxx是HttpSession的一个属性
我们发现是可以给ServletRequest添加属性,打印日志的时候进行解析的。
不过使用上述的格式配置的logback-access.xml文件因为格式问题导致无法解析。
找到一篇详解logback layout配置的文章: https://blog.csdn.net/Doraemo...
可以看到需要使用%reqAttribute{XXXX}才可以。
<pattern>%i{ClientIp} %h %l %u [%t] "%r" %s %b "%i{Referer}" "%i{User-Agent}" %i{x-ssl-header} %reqAttribute{user-id}%n======%n%fullRequest%n======%n%fullResponse</pattern>
只需要在代码中进行如下设置即可
servletRequest.setAttribute("user-id", userId);
(可能写的有点抽象啊,只是为了自己记录一下,不要忘记)
以上所述就是小编给大家介绍的《spring-boot的access日志格式修改》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Mac下修改MySQL编码格式(Linux基本一致)
- 开源堡垒机 Jumpserver v1.4.7 发布 , 修改配置文件格式
- 开源堡垒机 Jumpserver v1.4.7 发布 , 修改配置文件格式
- 不修改模板的前提下修改VisualState中的某些值
- 修改Git已提交的的Author和EMail(批量修改脚本)
- ViewGroup 默认顺序绘制子 View,如何修改?什么场景需要修改绘制顺序?
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
The Smashing Book
Jacob Gube、Dmitry Fadeev、Chris Spooner、Darius A Monsef IV、Alessandro Cattaneo、Steven Snell、David Leggett、Andrew Maier、Kayla Knight、Yves Peters、René Schmidt、Smashing Magazine editorial team、Vitaly Friedman、Sven Lennartz / 2009 / $ 29.90 / € 23.90
The Smashing Book is a printed book about best practices in modern Web design. The book shares technical tips and best practices on coding, usability and optimization and explores how to create succes......一起来看看 《The Smashing Book》 这本书的介绍吧!