日志及log4j框架

Posted mike_chang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了日志及log4j框架相关的知识,希望对你有一定的参考价值。

日志分类

  SQL日志、异常日志、业务日志


日志实现

1、jdk也提供日志记录功能

  没有日志级别;
  如果想写出到文件,需要自己使用IO流来实现

2、log4j是一个非常优秀的开源日志记录工具

  a、控制日志的输出级别
  b、控制日志信息输送的目的地是控制台、文件等
  c、控制每一条日志的输出格式

3、slf4j

  slf4j 依赖 jdk日志实现、log4j日志框架,可以在这两者之间切换调用

  hibernate默认的日志框架是slf4j、log4j

4、logback

  logback效率更高,是log4j作者的新产品

  logback也可以在jdk和log4j之间切换调用


log4j的使用

1、添加 log4j 的jar包

  a、log4j-1.2.16.jar
  b、commons-logging-1.1.3.jar

2、创建log4j.properties文件并配置

3、代码实现

   private Logger log = Logger.getLogger(this.getClass());

   log.info("方法开始...");


配置实例

# 设置日志级别和输出目的地
# 日志级别 fatal>error>warn>info>debug,开发时一般设置为debug最低级别,生产上可设置为info或warn级别
# 输出目的地的名称自定义,这里定义了stdout和logfile;其中stdout代表输出到控制台
log4j.rootLogger=debug,stdout,logfile
# 把日志信息输出到控制台
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
# 打印出来是红色字体
log4j.appender.stdout.Target=System.err
# 输出简单格式
log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout
# 把日志信息输出到文件
log4j.appender.logfile=org.apache.log4j.FileAppender
# 指定文件名
log4j.appender.logfile.File=zr.log
# 这里没有使用 simpleLayout,而是使用 PatternLayout
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
# 使用 PatternLayout 还要为其指定格式
log4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss}%l%F%p%m%n

输出格式配置

%p:输出日志级别,即debug、info、warn、error、fatal
%d:输出日志发生时间
%r:输出从应用启动到输出该log信息耗费的毫秒数
%l:输出日志发生位置,相当于%C.%M(%F:%L)的组合,包括类名、发生的线程、产生日志的文件、代码中的行数
如:TestLog4j.main(TestLog4j.java:10)
    TestLog4j         ------ 类名
    main           ------ 发生的线程
    TestLog4j.java      ------ 由哪个文件产生的日志
    10         ------ 代码中的行数
%F:输出产生日志文件,%l已经包含了%F
%L:输出代码中的行数,%l已经包含了%L
%m:输出日志内容
%n:输出换行符,windows为" ",unix为" "

 

















以上是关于日志及log4j框架的主要内容,如果未能解决你的问题,请参考以下文章

log4j怎样控制只输出自己写的代码的日志,不输出框架中的日志

Java接口自动化之log4j日志框架

程序源代码Log4J 日志分割

Java学习-007-Log4J 日志记录配置文件详解及实例源代码

dubbo之日志适配及访问日志

Java日志框架-logback的介绍及配置使用方法(转)