Tomcat 日志文件名的命名规范

1. 核心日志类型及命名规范

(1) Catalina 日志(引擎级日志)
  • 文件名catalina.<yyyy-MM-dd>.log
  • 说明:记录 Tomcat 启动、关闭、严重错误等全局事件。
  • 示例catalina.2025-09-07.log
(2) Access 日志(访问日志)
  • 文件名localhost_access_log.<yyyy-MM-dd>.txt
  • 说明 :记录所有 HTTP 请求(需配置 <Valve> 启用)。
  • 示例localhost_access_log.2025-09-07.txt

如果认证采用GET传参,可能泄露账号密码!

(3) 应用级日志(Host/Context 日志)
  • 文件名localhost.<yyyy-MM-dd>.log
  • 说明 :记录特定 Web 应用(如 localhost 虚拟主机)的错误。
  • 示例localhost.2025-09-07.log
(4) Manager/Host-Manager 日志
  • 文件名manager.<yyyy-MM-dd>.log / host-manager.<yyyy-MM-dd>.log
  • 说明:记录 Tomcat 管理应用的日志。

2. 命名规则详解

  • 日期格式 :固定为 <yyyy-MM-dd>(ISO 8601 格式,区分大小写)。
  • 分隔符 :点号 . 分隔名称组件,日期前后无额外符号。
  • 扩展名
    • 默认日志为 .log(如 catalina.2025-09-07.log)。
    • 访问日志为 .txt(如 localhost_access_log.2025-09-07.txt)。

3. 配置自定义命名

通过修改 conf/logging.propertiesserver.xml 可调整命名规则:

示例:修改 Access 日志命名
xml 复制代码
<Valve className="org.apache.catalina.valves.AccessLogValve"
       directory="logs"
       prefix="access_log"
       suffix=".log"
       pattern="%h %l %u %t &quot;%r&quot; %s %b"
       fileDateFormat="yyyy-MM-dd.HH" />  <!-- 按小时分割 -->
  • 效果 :生成 access_log.2025-09-07.14.log(小时级分割)。
示例:修改 Catalina 日志命名

logging.properties 中:

properties 复制代码
java.util.logging.FileHandler.pattern = %h/tomcat/logs/catalina-%g.log
  • 效果 :生成 catalina-0.logcatalina-1.log(按轮转编号)。

4. 关键注意事项

  • 大小写敏感 :Linux 系统严格区分 catalina.2025-09-07.logCatalina.2025-09-07.log
  • 轮转机制 :默认按天分割,历史日志会被压缩为 .gz(如 catalina.2025-09-06.log.gz)。
  • 时区影响 :日期基于系统时区,需确保服务器时区配置正确(如 Asia/Shanghai)。

5. 验证配置

检查 conf/server.xmlconf/logging.properties 中的以下参数:

  • directory:日志存储路径(默认 logs/)。
  • prefix/suffix:文件名前缀/后缀。
  • rotatable:是否启用按天分割(默认 true)。

通过以上规范,可确保日志文件名清晰、唯一,且便于自动化工具解析和归档。

相关推荐
二哈赛车手8 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
栗子~~8 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
YDS8298 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
未若君雅裁10 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
阿维的博客日记11 小时前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI11 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
辰海Coding12 小时前
MiniSpring框架学习-完成的 IoC 容器
java·spring boot·学习·架构
小小编程路12 小时前
C++ 多线程与并发
java·jvm·c++
AI视觉网奇12 小时前
linux 检索库 判断库是否支持
java·linux·服务器