Log4j 日志文件Linux/Mac/Windows通用存放位置设置方法

 更新时间:2017年01月23日 10:56:24   投稿:jingxian  
下面小编就为大家带来一篇Log4j 日志文件Linux/Mac/Windows通用存放位置设置方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

log4j1/log4j2中category的配置以及log的输出位置(windows和linux通用的log输出位置)

一、场景和需求

假设我现在有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 日志文件Linux/Mac/Windows通用存放位置设置方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • shell脚本使用两个横杠接收外部参数的方法

    shell脚本使用两个横杠接收外部参数的方法

    这篇文章主要介绍了shell脚本使用两个横杠接收外部参数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • 三分钟学会Linux基本指令

    三分钟学会Linux基本指令

    本文小马将把Linux一般比较常见的指令给大家一一列举出来,为了大家忘记某些指令后,可以方便查询记忆,再次小马建议,Linux指令并不需要去特别花时间专门记忆,只需要多进行操作实现就行,这篇文章主要介绍了Linux基本指令,需要的朋友可以参考下
    2022-12-12
  • 使用bash shell删除目录中的特定文件的3种方法

    使用bash shell删除目录中的特定文件的3种方法

    这篇文章主要介绍了使用bash shell删除目录中的特定文件的3种方法,分别为扩展模式匹配符、GLOBIGNORE 变量和find 命令,需要的朋友可以参考下
    2014-06-06
  • 一天一个shell命令 linux文本内容操作系列-grep命令详解

    一天一个shell命令 linux文本内容操作系列-grep命令详解

    这篇文章主要介绍了一天一个shell命令 linux文本内容操作系列-grep命令详解 ,需要的朋友可以参考下
    2016-06-06
  • 两个备份数据库的shell脚本

    两个备份数据库的shell脚本

    这篇文章主要是分享两个备份数据库的shell脚本,需要的朋友可以参考下,功能略有不同
    2013-02-02
  • Shell常用操作符总结

    Shell常用操作符总结

    这篇文章主要介绍了Shell常用操作符总结,本文讲解了算术操作 符、关系操作符、测试操作符等内容,需要的朋友可以参考下
    2015-05-05
  • shell脚本怎样判断文件是否存在

    shell脚本怎样判断文件是否存在

    这篇文章主要介绍了shell脚本怎样判断文件是否存在问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • shell中函数的应用

    shell中函数的应用

    今天这个脚本其实很简单,但很实用,讲的是shell中函数的应用,需要的朋友可以参考下
    2016-08-08
  • bash shell中的if-then语句

    bash shell中的if-then语句

    bash shell的 if 语句会运行 if 后面的那个命令,如果该命令的退出状态码是0,位于 then 部分的命令就会被执行,这篇文章主要介绍了bash shell中的if-then语句,需要的朋友可以参考下
    2023-12-12
  • Linux内核链表实现过程

    Linux内核链表实现过程

    本文讲解Linux内核链表实现的过程,说了链表的定义及初始化宏定义、操作和删除操作等内容,详细看下面
    2013-11-11

最新评论