使用log4j使某些java类的日志信息输出到指定日志文件中

Log4j 是 Apache 的一个开放源代码项目,通过使用 Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI 组件、甚至是套接口服务器、NT 的事件记录器、UNIX Syslog 守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。

应项目需求,需要处理项目中某些java类所产生的跑批日志信息和平常操作产生的业务日志信息分开保存,故重新配置log4j.properties,使得满足要求。
1、 平常的业务日志文件有front_log.log和front_error_log.log,log4j.properties配置如下

log4j.rootLogger=DEBUG,CONSOLE,DATABASE,D,R 
log4j.addivity.org.apache=false
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.Threshold=INFO
log4j.appender.CONSOLE.layout.ConversionPattern= %d{yyyy-MM-dd HH:mm:ss} %5p [%c] (%L) - %m%n
log4j.appender.CONSOLE.Target=System.out
log4j.appender.CONSOLE.Encoding=gbk
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
##日志信息测试按天生成,有效期最低3个月,最多4个月
log4j.appender.D = com.sinosoft.utils.CustomDailyRollingFileAppender
log4j.appender.D.File =${catalina.home}/logs/front_log #log4j.appender.D.File =/eptms/eptms/log/logs/main/front_log
log4j.appender.D.datePattern = yyyy-MM-dd'.log'
log4j.appender.D.Append = true
log4j.appender.D.Threshold = info
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern =%d{yyyy-MM-dd HH:mm:ss} %5p [%c] (%L) - %m%n
##错误日志文件
log4j.appender.R = com.sinosoft.utils.CustomDailyRollingFileAppender
log4j.appender.R.File =${catalina.home}/logs/front_error_log
#log4j.appender.R.File =/eptms/eptms/log/logs/main/front_error_log
log4j.appender.R.datePattern = yyyy-MM-dd'.log'
log4j.appender.R.Append = true
log4j.appender.R.Threshold = error
log4j.appender.R.layout = org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern =%d{yyyy-MM-dd HH:mm:ss} %5p [%c] (%L) - %m%n

在log4j.properties中日志的生成方式,我这里根据jar里的方法重写了;
具体请参考:https://blog.csdn.net/su1573/article/details/86582678 

2、新增跑批日志配置,如下:

规则:保存的文件为front_batch.log
日志数量:90个

#跑批日志 log4j.logger.batch=INFO,ERROR,batchFile 
log4j.addivity.batchFile=false 
log4j.appender.batchFile = org.apache.log4j.DailyRollingFileAppender 
log4j.appender.batchFile.File =${catalina.home}/logs/front_batch 
#log4j.appender.D.File =/eptms/eptms/log/logs/batch/front_batch 
log4j.appender.batchFile.datePattern = yyyy-MM-dd'.log' 
log4j.appender.batchFile.Append = true #log4j.appender.D.Threshold = info 
log4j.appender.batchFile.MaxBackupIndex=90 
log4j.appender.batchFile.layout = org.apache.log4j.PatternLayout 
log4j.appender.batchFile.layout.ConversionPattern =%d{yyyy-MM-dd HH:mm:ss} %5p [%c] (%L) - %m%n

3、在具体的java类中引用

import org.apache.commons.logging.Log; 
import org.apache.commons.logging.LogFactory; 

public class TestDemo{ 
//指定跑批日志 
private static Log logger= LogFactory.getLog("batch"); 
public void test(){ 
    logger.info("凭证生成-开始执行自动跑批任务^_^"); 
    } 
}    

---------------------
作者:su1573
来源:CSDN
原文:https://blog.csdn.net/su1573/article/details/87882929
版权声明:本文为博主原创文章,转载请附上博文链接!

原文地址:https://www.cnblogs.com/xiaoshen666/p/10983044.html