虽然说log4j自己会用,但是还是觉得对配置文件还不是很熟悉,最近看了一个博客,感觉很不多,我提炼出自己的理解.

地址

案例我就不贴了,可以直接看上面的地址,我这里主要讲讲配置文件的意思
贴一下代码以及解释

### 设置###
###第一个参数为日志记录的优先级,后面三个都是输出源的别名,可以看到后面三个不同的输出源,分别是stout,D,E
log4j.rootLogger=debug,stdout,D,E ### 输出信息到控制台 ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n ### 输出DEBUG 级别以上的日志到=E://logs/error.log ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = E://logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n ### 输出ERROR 级别以上的日志到=E://logs/error.log ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =E://logs/error.log
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n

注意:

1.Log4j由三个重要的组件构成:日志信息的优先级,日志信息的输出目的地,日志信息的输出格式。
2.日志信息的优先级从高到低有ERROR、WARN、 INFO、DEBUG,分别用来指定这条日志信息的重要程度
3.日志信息的输出目的地指定了日志将打印到控制台还是文件中
4.输出格式则控制了日志信息的显示内容。

###1.根Logger配置
语法

log4j.rootLogger = [ level ] , appenderName, appenderName, …

解释

level 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。Log4j建议只使用四个级别,优 先级从高到低分别是ERROR、WARN、INFO、DEBUG。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。比如在这里定 义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来。 appenderName就是指B日志信息输出到哪个地方。您可以同时指定多个输出目的地。

###2.目的地Appender
语法

log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1

log4j.appender.appenderName.option = valueN

Log4j提供的appender

org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

###3.配置日志信息的格式(布局)

语法

log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1

log4j.appender.appenderName.layout.option = valueN

layout种类

org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

打印格式格式化日志信息

%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)

转载于:https://my.oschina.net/u/2615530/blog/868927

最新文章

  1. iOS 利用webView加载html代码,在代理中获取html页面的链接时出现的问题
  2. php 小试 mysql-zmq-plugin 和 pthreads
  3. PHP入门part2
  4. 20145225《Java程序设计》 第5周学习总结
  5. nslog
  6. php的urlencode()URL编码函数浅析
  7. jdk和tomcat环境部署
  8. Linux安全攻防笔记
  9. angular依赖注入的理解(转)
  10. JS分页 + 获取MVC地址栏URL路径的最后参数
  11. 九度OJ 1512 用两个栈实现队列 【数据结构】
  12. Mybatis 控制台打出Sql-Log的设置
  13. 【更新日志】售后CP更新日志
  14. 【贪心+中位数】【新生赛3 1007题】 Problem G (K)
  15. index.js:13 Uncaught TypeError: Cannot read property 'split' of undefined
  16. React Fiber源码分析 第二篇(同步模式)
  17. 微信公众号UX分析—— 学生作业小结
  18. *1LL在c++中的意义
  19. Dubbo 实例
  20. Visual Studio 项目模板制作(二)

热门文章

  1. wifi无线桥接
  2. 1066 Root of AVL Tree (25分)(AVL树的实现)
  3. Linux系统安装java jdk
  4. 今天无意中看到了str_split这个函数
  5. php simplexml_load_string 返回的对象print_r后,丢失信息?
  6. json格式的文件操作
  7. Python中关于字符串你应该知道这些...
  8. pgsql中的lateral使用小结
  9. 讲讲HashMap的理解,以及HashMap在1.7和1.8版本的变化(2020/4/16)
  10. Gradle系列之Groovy基础篇