一、场景和需求
假设我现在有3个独立的用project(暂时用maven关联起来,当然也可以不用maven),一个是提供公共服务的infrastructure,一个是提供存储的persister,一个是提供搜索的searcher,其中提供基础服务的所有的类,例如DateUtils,HttpUtils等工具类都位于目录com.chuanliu.platform.activity下,而提供存储服务的所有类都位于com.chuanliu.platform.activity.persist目录下,提供搜索服务的所有类都位于com.chuanliu.platform.activity.solr下。
现在项目的需求是有一个log文件叫full.log,需要记录所有的日志,不管是infrastructure下的,还是persister下的,还是seracher下的,另外还需要一个日志文件叫solr.log,记录所有发生在搜索目录下的日志。当然将来还应该将searcher目录下的日志放在searcer.log中。
除此之外还应该支持根据不同的部署环境设置不同的log输出位置,因为windows和linux具有不同的目录结构。
二、无论是log4j1还是log4j2中,都可以使用如下配置:
log4j.rootLogger = info log4j.debug = false log4j.category.com.chuanliu.platform.activity = info, full, stdout #The child logger appender will not inherit the parent logger's appender, or the logs will be output twice in the file log4j.additivity.com.chuanliu.platform.activity.platform.activity = false log4j.category.com.chuanliu.platform.activity.solr = info, solr log4j.additivity.com.chuanliu.platform.activity.platform.activity.solr = false ###### activity full log: contains all of the log #### #full log4j.appender.full = org.apache.log4j.DailyRollingFileAppender log4j.appender.full.File = ${LogFile.Location}/full.log log4j.appender.full.DatePattern = '.'yyyy-MM-dd log4j.appender.full.layout = org.apache.log4j.PatternLayout log4j.appender.full.layout.conversionPattern = %d [%t] %-5p %c{1} - %m%n log4j.appender.full.ImmediateFlush = true log4j.appender.full.append = true ######activity full log #### ######activity solr log : only contain the log in searcher#### #solr log4j.appender.solr = org.apache.log4j.DailyRollingFileAppender log4j.appender.solr.File = ${LogFile.Location}/solr.log log4j.appender.solr.DatePattern = '.'yyyy-MM-dd log4j.appender.solr.layout = org.apache.log4j.PatternLayout log4j.appender.solr.layout.conversionPattern = %d [%t] %-5p %c{1} - %m%n log4j.appender.solr.ImmediateFlush = true log4j.appender.solr.append = true ######activity solr log #### # Console output... log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=[%d][%p]%t: %m%n # log sql for mybatis log4j.logger.mybatis =TRACE org.springframework.web=debug
这样经过测试,你会发现,所有的log都进入了full.log中,而只有com.chuanliu.platform.activity.solr下的日志输出进入了solr.log.
另外对于日志的输出位置, ${LogFile.Location},我们可以在不同环境的配置文件中自定义LogFile.Location的值,比如在代表本地环境的dev.properties中,定义LogFile.Location=C://logs
代表测试环境的qa.properties中,定义LogFile.Location=/usr/local/var/logs,同样在生产环境中定义相同的值为:LogFile.Location=/usr/local/var/logs,这样在不同环境下就会在不同路径下生成不同的log文件。
其实,经过测试后,没有这么麻烦,我们可以统一将windows和linux的log输出配置到同一个地方,即上面我们可以统一的将输出设置为/usr/local/var/logs,这样的设置在linux中,大家都能理解,但在windows中,可能不是那么好理解,在windows中,/usr/local/var/log有2层含义:
1、如果是在eclipse中执行这些日志输出的类的方法,那么将在workspace所在的磁盘,例如E盘中创建目录/usr/local/var/log,并输出full.log和solr.log.
2、如果是在tomcat中应用执行日志的输出,那边就是在tomcat所在的磁盘中,例如D盘中创建目录/usr/local/var/log,并输出full.log和solr.log,即便是在eclipse中启动tomcat,这时tomcat的wtpapps目录是在eclipse所在的目录,如E盘中,但是真正使用的tomcat是在D盘中的,那么同样是在/usr/local/var/logs中输出如上的日志文件。
相关推荐
Log4j想要生效,我们需要在web.xml中进行配置,以告诉工程去哪加载log4j的配置文件和定义一个扫描器。相比之下,Log4j2就比较简单,我们只需要把log4j2.xml文件放到工程的resource目录下就行了。 Log调用 Log4j和...
总的来说,通过合理配置Log4j,可以轻松地实现跨平台的日志管理,使得在Windows和Linux系统中日志路径保持一致,同时也方便了日志的管理和分析。在`webapp`项目中,你可以将上述配置文件添加至类路径,并在代码中...
log4j1/log4j2中category的配置以及log的输出位置(windows和linux通用的log输出位置) 一、场景和需求 假设我现在有3个独立的用project(暂时用maven关联起来,当然也可以不用maven),一个是提供公共服务的...
Log4j 是一个功能强大且广泛使用的日志记录工具,特别是在 SSM(Spring、Spring MVC、Mybatis)整合项目中,合理地配置 Log4j 对项目的日志记录和输出至关重要。本文将详细介绍 SSM 整合中的 Log4j 配置详情,帮助...
### log4j实用配置扩展 #### 一、log4j简介与重要性 Log4j是一种广泛使用的开源日志框架,由Apache软件基金会维护。它主要用于记录Java应用程序的运行时信息,帮助开发者追踪应用程序的行为、调试问题以及进行性能...
*灵活的配置:Log4j2 提供了非常灵活的配置机制,可以根据需要定义不同的日志级别、输出格式和文件名等属性。 *高性能:Log4j2具有非常高的性能,可以handle大量的日志信息。 *灵活的appender:Log4j2 提供了多种...
2. **配置文件**:创建`log4j2.xml`或`log4j2.json`文件,定义日志级别和输出目的地。例如: ```xml <!-- log4j2.xml 示例 --> [%t] %-5level %logger{36} - %msg%n"/> </Console> ...
总结来说,Log4j的动态配置日志输出路径主要涉及对配置文件的解析和重新加载,以及在运行时使用API直接调整日志设置。理解并熟练运用这些方法,可以帮助我们在开发过程中更灵活地管理和监控日志,提高开发效率和问题...
Log4j2 结合 Slf4j 配置使用 Log4j2 是一个功能强大且广泛使用的日志记录工具,它提供了灵活的日志记录机制和高性能的日志记录能力。Slf4j 则是一个简单的日志记录门面,提供了统一的日志记录接口。今天,我们将...
总结来说,Log4j-1.2.17提供了灵活的日志管理功能,通过配置文件可以定制化日志输出的方式和内容,对于开发、调试和维护Java应用具有极大的帮助。尽管有更新的版本如Log4j2可用,但Log4j 1.x仍然在许多项目中得到...
Log4j是一款由Apache出品的日志记录工具,它提供了灵活的日志级别控制和多样化的日志输出方式,广泛应用于Java应用的开发中。本文将深入解析log4j的配置与加载机制,帮助开发者更好地理解和应用log4j。 #### Log4j...
标题中的“log4jdbc-log4j2配置简记”指的是在Java开发中使用log4jdbc-log4j2库来监控和记录SQL查询的过程。log4jdbc是一个开源项目,它允许开发者通过日志系统来追踪数据库操作,而log4j2是log4j的升级版,提供了更...
2. **配置Log4j**:在项目的类路径下创建`log4j.properties`或`log4j.xml`配置文件,指定日志级别、输出目的地等。例如: ```properties # log4j.properties log4j.rootLogger=DEBUG, stdout log4j.appender....
这些接口包括最基本的`org.apache.logging.log4j.Logger`,它是所有日志记录的起点,以及`org.apache.logging.log4j.LogManager`,它负责管理日志配置和日志器实例。API库的主要目标是与实现层解耦,允许开发者在不...
2. **配置全局 Log4j 属性文件**:在任意位置创建 `log4j.properties` 文件,并设置全局的日志级别、输出格式及存储路径等。通常会将该文件放置在 Tomcat 的 `conf` 目录下。 ```properties log4j.rootLogger=...
在Log4j1的配置文件(通常是log4j.properties或log4j.xml)中,我们需要添加JSONLayout的相关配置。例如: ```xml <appender name="jsonFileAppender" class="org.apache.log4j.FileAppender"> ...
本文将详细介绍如何通过修改`log4j.properties`配置文件来解决log4j中的乱码问题。 #### 二、问题背景 在使用log4j时,经常会在控制台或日志文件中看到乱码,尤其是在涉及中文字符的情况下。这通常是由于日志系统...
### Log4j中配置日志文件相对路径方法详解 #### 概述 在软件开发过程中,日志记录是一项重要的功能,它有助于开发者调试程序、监控应用程序的运行状态以及追踪问题。`Log4j`作为一款优秀的日志管理工具,被广泛应用...
总结来说,Log4j提供了一套强大的日志管理框架,通过自定义Appender和PrintStream,我们可以轻松地将`System.out.println()`的输出整合到Log4j中,从而实现日志的集中管理和分析。这对于大型项目或者需要严格监控的...
2. **异常可见性**:Log4j2允许配置异常通知机制,即当Appender中发生异常时可以将异常信息发送给应用程序。这与Logback不同,后者不允许Appender中的异常对应用程序不可见。 3. **强大的异步日志功能**:Log4j2...