spring-boot的access日志格式修改

栏目: Java · 发布时间: 5年前

内容简介:使用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日志格式修改》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

图形程序开发人员指南

图形程序开发人员指南

Michael Abrash / 前导工作室 / 机械工业出版社 / 1998 / 128

Michael Abrash's classic Graphics Programming Black Book is a compilation of Michael's previous writings on assembly language and graphics programming (including from his "Graphics Programming" column......一起来看看 《图形程序开发人员指南》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

在线进制转换器
在线进制转换器

各进制数互转换器

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具