在tomcat6下配置log4j日志

2024-04-24 14:08
文章标签 配置 日志 log4j tomcat6

本文主要是介绍在tomcat6下配置log4j日志,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

tomcat默认的日志是使用commons.logging,下面以tomcat6.0.18为例说明log4j日志的配置。tomcat默认的也是输出日志日志的,可以把conf文件夹下的logging.properties删除或者改个其它名字,原来的日志就不会输出了。
看了网上的一些介绍,大多是下载tomcat-juli.jar放到TOMCAT安装目录的bin文件夹下,tomcat-juli-adapters.jar放到lib文件夹下,然后把log4j.jar、log4j.properties放到lib目录下。在我用的tomcat6.0.18下,tomcat-juli.jar在bin文件夹已经有了,至于tomcat-juli-adapters.jar则是又没有都可以,然后log4j的放置方法是一样的。下面给出一个 log4j.properties的例子:
#
# Configures Log4j as the Tomcat system logger
# to output info level messages into a rolling log file.
#
# To continue using the "catalina.out" file (which grows forever),
# comment out the above line and uncomment the next.
org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JLogger
#

log4j.rootLogger=Debug,A1,A2

log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t][%x] %C{8}@(%F:%L):%m%n

# 设定输出位置,此处设定tomcat目录的logs下,文件名为 all.log。
log4j.appender.A2=org.apache.log4j.RollingFileAppender
log4j.appender.A2.File=${catalina.home}/logs/all.log
log4j.appender.A2.MaxFileSize=1024KB

log4j.appender.A2.layout=org.apache.log4j.PatternLayout
log4j.appender.A2.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t][%x] %C{8}@(%F:%L):%m%n

log4j.logger.org.apache=Debug

然后建立一个简单的应用,此处只使用一个简单的jsp文件进行测试:
<%@page import="org.apache.log4j.Logger"%>
<%
Logger log = Logger.getLogger(this.getClass());
log.debug("test 日志测试");
%>
page content here.
运行这个jsp文件,就会看到在logs文件夹下面有all.log的日志文件。同时,如果是linux操作系统,在logs下面会有catalina.out文件,也输出的日志信息,在windows操作系统的控制台上会看到输出的日志信息。
如果在windows操作系统上,也输出一个catalina.out文件,就需要做一些修改:
1、打开bin下面的startup.bat文件,把call "%EXECUTABLE%" start %CMD_LINE_ARGS%改为call "%EXECUTABLE%" run %CMD_LINE_ARGS% 。
2、打开bin下面的catalina.bat文件,会发现共有4处 %ACTION% ,在后面分别加上 >> %CATALINA_HOME%/logs/catalina.out 。
重启tomcat,就会发现在logs文件夹下出现了catalina.out文件,把原来控制台的信息全写进去了。
但输出的这个catalina.out文件,是一直增长的,也就是文件会越来越大。而通过log4j.appender.A2=org.apache.log4j.RollingFileAppender这种方式配置的日志文件,是根据设定的文件大小自动切换的,如设置为最大1M,当文件达到1M,会把日志文件备份为另一个文件,原有日志文件则清空继续记录日志。
这种方式配置的日志,是把tomcat所有应用的日志都记录在一起了,也可以分别对每个应用记录各自的日志文件。如在一个应用的WEB-INF/classes建立一个log4j.properties文件(log4j默认找classpath下的log4j.properties):
log4j.rootLogger=Debug,A1,A2

log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t][%x] %C{8}@(%F:%L):%m%n

#设定输出位置,此处设定tomcat目录的logs下,文件名为testA.log,是按文件大小切换的。
log4j.appender.A2=org.apache.log4j.RollingFileAppender
log4j.appender.A2.File=${catalina.home}/logs/testA.log
log4j.appender.A2.MaxFileSize=1024KB

log4j.appender.A2.layout=org.apache.log4j.PatternLayout
log4j.appender.A2.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t][%x] %C{8}@(%F:%L):%m%n
在另一个应用的WEB-INF/classes建立一个log4j.properties文件:
log4j.rootLogger=Debug,A1,A2

log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t][%x] %C{8}@(%F:%L):%m%n

#设定输出位置,此处设定tomcat目录的logs下,文件名为testB.log,是按一天一个日志文件切换的。
log4j.appender.A2=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A2.File=${catalina.home}/logs/testB.log
log4j.appender.A2.DatePattern='.'yyyy-MM-dd

log4j.appender.A2.layout=org.apache.log4j.PatternLayout
log4j.appender.A2.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t][%x] %C{8}@(%F:%L):%m%n
这样不同的应用就把日志记录到不同的日志文件中去了。
如果日志中出现汉字乱码问题,可以加上类似log4j.appender.A1.Encoding=ISO8859-1这样的语句,但是否有效果还要根据实际作调整才可以。

这篇关于在tomcat6下配置log4j日志的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/931972

相关文章

Redis多种内存淘汰策略及配置技巧分享

《Redis多种内存淘汰策略及配置技巧分享》本文介绍了Redis内存满时的淘汰机制,包括内存淘汰机制的概念,Redis提供的8种淘汰策略(如noeviction、volatile-lru等)及其适用场... 目录前言一、什么是 Redis 的内存淘汰机制?二、Redis 内存淘汰策略1. pythonnoe

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

关于Maven中pom.xml文件配置详解

《关于Maven中pom.xml文件配置详解》pom.xml是Maven项目的核心配置文件,它描述了项目的结构、依赖关系、构建配置等信息,通过合理配置pom.xml,可以提高项目的可维护性和构建效率... 目录1. POM文件的基本结构1.1 项目基本信息2. 项目属性2.1 引用属性3. 项目依赖4. 构

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

SpringBoot如何使用TraceId日志链路追踪

《SpringBoot如何使用TraceId日志链路追踪》文章介绍了如何使用TraceId进行日志链路追踪,通过在日志中添加TraceId关键字,可以将同一次业务调用链上的日志串起来,本文通过实例代码... 目录项目场景:实现步骤1、pom.XML 依赖2、整合logback,打印日志,logback-sp

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

gradle安装和环境配置全过程

《gradle安装和环境配置全过程》本文介绍了如何安装和配置Gradle环境,包括下载Gradle、配置环境变量、测试Gradle以及在IntelliJIDEA中配置Gradle... 目录gradle安装和环境配置1 下载GRADLE2 环境变量配置3 测试gradle4 设置gradle初始化文件5 i

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R