大佬教程收集整理的这篇文章主要介绍了springboot内嵌tomcat日志配置,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
在tomcat的access中打印出请求的情况可以帮助我们分析问题,通常比较关注的有访问IP、线程号、访问url、返回状态码、访问时间、持续时间。
tomcat主要涉及到两类日志配置:
access log捕捉http请求tomcat log打印启动全过程
参考的国外的博客,直接贴下测试代码:
@RestController public class HelloController { @GetMapping("/greetings/{username}") public String getGreetings(@PathVariable("username") String userName) { return "Hello " + userName + ", Good day...!!!"; } }
server: port: 9000 servlet: context-path: / # 配置access日志 tomcat: accesslog: enabled: true file-date-format: .yyyy-MM-dd suffix: .log prefix: access_log directory: tomcat_log pattern: common basedir: d:/tmp
配置好后启动项目,浏览器访问:
http://localhost:9000/greetings/tom
查看磁盘上的日志文件d:/tmp/tomcat_log/access_log.2020-06-13.log
省略了前缀server.tomcat.accesslog
enabled,取值true、false,需要accesslog时设置为true
directory,指定access文件的路径
rotate,指定是否启用日志轮转。默认为true。这个参数决定是否需要切换切换日志文件,如果被设置为false,则日志文件不会切换,即所有文件打到同一个日志文件中,并且file-date-format参数也会被忽略
pattern,定义日志的格式,
pattern的配置:
%a - 远程IP地址
%A - 本地IP地址
%b - 发送的字节数(Bytes sent), 不包括HTTP headers的字节,如果为0则展示'-'
%B - 发送的字节数(Bytes sent), 不包括HTTP headers的字节
%h - 远程主机名称(如果resolveHosts为false则展示IP)
%H - 请求协议
%l - 远程用户名,始终为'-'(Remote logical username from identd)
%m - 请求的方法(GET, POST等)%p - 接受请求的本地端口
%q - 查询字符串,如果存在,有一个前置的'?'
%r - 请求的第一行(包括请求方法和请求的URI)
%s - response的HTTP状态码(200,404等)%S - 用户的session ID
%t - 日期和时间,Common Log Format格式
%u - 被认证的远程用户, 不存在则展示'-'
%U - 请求URL路径%v - 本地服务名
%D - 处理请求的时间,单位为毫秒
%T - 处理请求的时间,单位为秒%I - 当前请求的线程名(can compare later with stacktraces)
pattern可以设置为指定的模板名称,具体含有如下:
common - %h %l %u %t "%r" %s %b
,依次为:远程主机名称,远程用户名,被认证的远程用户,日期和时间,请求的第一行,response code,发送的字节数
combined - %h %l %u %t "%r" %s %b "%{Referer}i" "%{User-Agent}i"
,依次为:远程主机名称,远程用户名,被认证的远程用户,日期和时间,请求的第一行,response code,发送的字节数,request header的Referer信息,request header的User-Agent信息。
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的一个属性
说明:combined模式的pattern可以增加Referer和User-Agent headers的参数形式,每个参数用双引号包起来,引号中的内容还是上面列举的参数。比如"%{User-Agent}i"使其为”%{User-Agent}i“,即请求的User-Agent(客户端,浏览器)。
# 配置tomcat日志
logging:
level:
org.apache.tomcat: DEBUG
org.apache.catalina: DEBUG
启动项目观察日志,发现打印了一堆DEBUG信息:
linux系统
获取tomcat进程pid ps -ef|grep tomcat 统计该tomcat进程内的线程个数 ps -Lf 29295 |wc -l
windows系统
其中8080为tomcat默认端口,如果端口有修改,可使用修改后的端口
pstree -p 后面为进程id。
netstat -ano|findstr 8080pstree -p 5240 | wc -l
以上是大佬教程为你收集整理的springboot内嵌tomcat日志配置全部内容,希望文章能够帮你解决springboot内嵌tomcat日志配置所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。