tomcat下的日志配置详细说明

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

Tomcat 日志分为两类:
1、访问日志,记录访问的时间、访问的来源、访问的资料等相关信息。
2、运行日志,记录tomcat运行信息,异常、错误信息。


访问日志配置,在server.xml里的以下标签编辑,关闭访问日志注释以下段落内容即可

 

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"

               prefix="localhost_access_log." suffix=".txt"

               pattern="%h %l %u %t &quot;%r&quot; %s %b" />

 

各个参数的含义

 

className:官方的意思说必须按照默认配置那样不能改。

directory:日志位置。

prefix:日志文件前缀。

suffix:日志文件后缀。

pattern:日志模式参数,设置参数很丰富,参数说明见下表。

resolveHosts:如果这个值是true的话,tomcat会将这个服务器IP地址通过DNS转换为主机名,如果是false,就直接写服务器IP地址。

 

pattern 参数:

     %a - 远端IP地址

     %A - 本地IP地址

     %b - 发送的字节数,不包括HTTP头,如果为0,使用"-"

     %B - 发送的字节数,不包括HTTP头

     %h - 远端主机名(如果resolveHost=false,远端的IP地址)

     %H - 请求协议

     %l - 从identd返回的远端逻辑用户名(总是返回 '-')

     %m - 请求的方法(GET,POST,等)

     %p - 收到请求的本地端口号

     %q - 查询字符串(如果存在,以 '?'开始)

     %r - 请求的第一行,包含了请求的方法和URI

     %s - 响应的状态码

     %S - 用户的session ID

     %t - 日志和时间,使用通常的Log格式

     %u - 认证以后的远端用户(如果存在的话,否则为'-')

     %U - 请求的URI路径

     %v - 本地服务器的名称

     %D - 处理请求的时间,以毫秒为单位

     %T - 处理请求的时间,以秒为单位 

2 运行日志

运行日志配置
运行日志有5类:catalina 、 localhost 、 manager 、 admin 、 host-manager
每类日志有7种级别:WARNING > INFO > CONFIG > FINE > FINER > FINEST (lowest value) 级别越高报的信息越少
修改运行日志报的信息级别在conf/logging.propertie

  1. #可配置项(5类日志):catalina、localhost、manager、admin、host-manager  

  2. handlers = 1catalina.org.apache.juli.FileHandler, 2localhost.org.apache.juli.FileHandler,  

  3. 3manager.org.apache.juli.FileHandler, 4host-manager.org.apache.juli.FileHandler, java.util.logging.ConsoleHandler  

  4.   

  5. #日志输出为输出到文件和输出到控制台  

  6. .handlers = 1catalina.org.apache.juli.FileHandler, java.util.logging.ConsoleHandler  

  7.   

  8. #日志输出级别:SEVERE (最高级别) > WARNING > INFO > CONFIG > FINE > FINER(精心) > FINEST (所有内容,最低级别)  

  9. #配置文件使catalina日志输出级别为FINE  

  10. 1catalina.org.apache.juli.FileHandler.level = FINE  

  11. #catalina文件输出位置  

  12. 1catalina.org.apache.juli.FileHandler.directory = ${catalina.base}/logs  

  13. #catalina日志前缀为catalina  

  14. 1catalina.org.apache.juli.FileHandler.prefix = catalina.  

  15.   

  16. #配置文件使localhost日志输出级别为FINE  

  17. 2localhost.org.apache.juli.FileHandler.level = FINE  

  18. #localhost文件输出位置  

  19. 2localhost.org.apache.juli.FileHandler.directory = ${catalina.base}/logs  

  20. #localhost日志前缀为localhost  

  21. 2localhost.org.apache.juli.FileHandler.prefix = localhost.  

  22.   

  23. #配置文件使manager日志输出级别为FINE  

  24. 3manager.org.apache.juli.FileHandler.level = FINE  

  25. #manager文件输出位置  

  26. 3manager.org.apache.juli.FileHandler.directory = ${catalina.base}/logs  

  27. #manager日志前缀为manager  

  28. 3manager.org.apache.juli.FileHandler.prefix = manager.  

  29.   

  30. #配置文件使host-manager日志输出级别为FINE  

  31. 4host-manager.org.apache.juli.FileHandler.level = FINE  

  32. #host-manager文件输出位置  

  33. 4host-manager.org.apache.juli.FileHandler.directory = ${catalina.base}/logs  

  34. #host-manager日志前缀为host-manager  

  35. 4host-manager.org.apache.juli.FileHandler.prefix = host-manager.  

  36.   

  37. #配置文件使控制台日志输出级别为FINE  

  38. java.util.logging.ConsoleHandler.level = FINE  

  39. #控制台日志输出格式  

  40. java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter  

  41.   

  42. #localhost日志文件输出级别为INFO  

  43. org.apache.catalina.core.ContainerBase.[Catalina].[localhost].level = INFO  

  44. #localhost日志文件输出处理类2localhost.org.apache.juli.FileHandler  

  45. org.apache.catalina.core.ContainerBase.[Catalina].[localhost].handlers = 2localhost.org.apache.juli.FileHandler  

  46.   

  47. #manager日志文件输出级别为INFO  

  48. org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/manager].level = INFO  

  49. #manager日志文件输出处理类3manager.org.apache.juli.FileHandler  

  50. org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/manager].handlers = 3manager.org.apache.juli.FileHandler  

  51.   

  52. #host-manager日志文件输出级别为INFO  

  53. org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/host-manager].level = INFO  

  54. #host-manager日志文件输出处理类4host-manager.org.apache.juli.FileHandler  

  55. org.apache.catalina.core.ContainerBase.[Catalina].[localhost].[/host-manager].handlers = 4host-manager.org.apache.juli.FileHandler



     本文转自yzy121403725 51CTO博客,原文链接:http://blog.51cto.com/lookingdream/1955064 ,如需转载请自行联系原作者



相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
1月前
|
网络协议 Java 应用服务中间件
框架源码私享笔记(01)Tomcat核心架构功能 | 配置详解
本文首先分享了《活出意义来》一书序言中的感悟,强调成功如同幸福,不是刻意追求就能得到,而是全心投入时的副产品。接着探讨了Tomcat的核心功能与架构解析,包括网络连接器(Connector)和Servlet容器(Container),并介绍了其处理HTTP请求的工作流程。文章还详细解释了Tomcat的server.xml配置文件,涵盖了从顶级容器Server到子组件Connector、Engine、Host、Context等的配置参数及作用,帮助读者理解Tomcat的内部机制和配置方法。
|
1月前
|
SQL Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— application.yml 中对日志的配置
在 Spring Boot 项目中,`application.yml` 文件用于配置日志。通过 `logging.config` 指定日志配置文件(如 `logback.xml`),实现日志详细设置。`logging.level` 可定义包的日志输出级别,例如将 `com.itcodai.course03.dao` 包设为 `trace` 级别,便于开发时查看 SQL 操作。日志级别从高到低为 ERROR、WARN、INFO、DEBUG,生产环境建议调整为较高级别以减少日志量。本课程采用 yml 格式,因其层次清晰,但需注意格式要求。
135 0
|
5月前
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
1752 31
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
11天前
|
Java 关系型数据库 MySQL
JDK、Tomcat、MariaDB数据库和Profile多环境的配置与使用
以上就是JDK、Tomcat、MariaDB数据库和Profile多环境的配置与使用的基本步骤。这些步骤可能会因为你的具体需求和环境而有所不同,但是基本的思路是一样的。希望这些信息能够帮助你更好地理解和使用这些工具。
57 17
|
22天前
|
存储 监控 API
【Azure App Service】分享使用Python Code获取App Service的服务器日志记录管理配置信息
本文介绍了如何通过Python代码获取App Service中“Web服务器日志记录”的配置状态。借助`azure-mgmt-web` SDK,可通过初始化`WebSiteManagementClient`对象、调用`get_configuration`方法来查看`http_logging_enabled`的值,从而判断日志记录是否启用及存储方式(关闭、存储或文件系统)。示例代码详细展示了实现步骤,并附有执行结果与官方文档参考链接,帮助开发者快速定位和解决问题。
75 23
|
1月前
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
|
1月前
|
监控 Java 应用服务中间件
Tomcat log日志解析
理解和解析Tomcat日志文件对于诊断和解决Web应用中的问题至关重要。通过分析 `catalina.out`、`localhost.log`、`localhost_access_log.*.txt`、`manager.log`和 `host-manager.log`等日志文件,可以快速定位和解决问题,确保Tomcat服务器的稳定运行。掌握这些日志解析技巧,可以显著提高运维和开发效率。
121 13
|
1月前
|
数据库连接 测试技术 Windows
【YashanDB知识库】windows配置ODBC跟踪日志, 使用日志定位问题
【YashanDB知识库】windows配置ODBC跟踪日志, 使用日志定位问题
|
6月前
|
安全 应用服务中间件 网络安全
Tomcat如何配置PFX证书?
【10月更文挑战第2天】Tomcat如何配置PFX证书?
425 7
|
6月前
|
存储 算法 应用服务中间件
Tomcat如何配置JKS证书?
【10月更文挑战第2天】Tomcat如何配置JKS证书?
728 4

热门文章

最新文章

下一篇
oss创建bucket