log4j自定义日志单独输出到指定文件夹

log4j添加如下配置

log4j.logger.uat_log=info,uatlog
log4j.additivity.uatlog=false
log4j.appender.uatlog=org.apache.log4j.DailyRollingFileAppender
log4j.appender.uatlog.DatePattern='_'yyyy-MM-dd'.log'
log4j.appender.uatlog.File=D:/logs/uat/uat.log
log4j.appender.uatlog.layout=org.apache.log4j.PatternLayout
log4j.appender.uatlog.Threshold=info
log4j.appender.uatlog.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%C]-[%t]-[%p] %m -(\:%L)%n

第一行表示自定义的日志输出类起的别名叫做uat_log

第二行表示uatlog日志不输出到父类的日志文件中,因为我们所有自定义的日志类都是继承rootLogger根节点的日志类,默认子类的日志会输出到父类指定的文件夹中,默认additivity是为true的,我们修改为false则就不会输出到父类中

第三行表示使用每日产生一个日志文件的方式

第四行表示滚动后文件添加的标识,例:如果当前超过指定日志大小,那么就会将uat.log日志保存到uat.log_2020-06-16.log,清空uat.log,在继续往uat.log里面写

第五行表示日志输出的路径

第六行表示日志的布局

第七行表示输出的级别,如果低于当前级别,则不输出到文件,级别由高到低:debug

第八行表示打印日志信息的格式%d 表示显示时间格式,类似于java中的simpledatatformat,其他的如下:

%c:表示输出日志信息所属的类目,通常就是所在类的全名。
%d:表示输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,如:%-d{yyyy-MM-dd HH\:mm\:ss}
%F:表示输出日志消息产生时所在的文件名称。
%l:表示输出日志事件的发生位置,相当于%c.%M(%F:%L)的组合,包括类全名、方法、文件名以及在代码中的行数。
%L:表示输出代码中的行号。
%m:表示输出代码中指定的具体日志信息。
%M:表示输出产生日志信息的方法名。
%n:表示输出一个回车换行符,Windows平台为"rn",Unix平台为"n"。
%p:表示输出日志信息的优先级,如DEBUG,INFO,WARN,ERROR,FATAL。
%r:表示输出自应用程序启动到输出该log信息耗费的毫秒数。
%t:表示输出产生该日志事件的线程名。
%x:表示输出和当前线程相关联的NDC(嵌套诊断环境)。
%%:表示输出一个"%"字符。

当使用的时候这样去定义日志对象:

private static final Logger log = LoggerFactory.getLogger("uat_log");

这样我们就拿到了自定义的日志对象啦。

你可能感兴趣的:(log4j自定义日志单独输出到指定文件夹)