首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | HR | 镜像
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
搜索中心 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>编程开发>java>Java基础>正文

J2SE综合--对于log4j的深层次的理解

http://www.oklinux.cn  2008-03-03  赛迪网 十年  会员收藏  游客收藏  【 】 
您查看的文章来源于http://www.oklinux.cn

log4j的好处在于:

1.

通过修改配置文件,就可以决定log信息输出到何处(console,文件,...),是否输出。
这样,在系统开发阶段可以打印详细的log信息以跟踪系统运行情况,而在系统稳定后可以关闭log输出,从而在能跟踪系统运行情况的同时,又减少了垃圾代码(System.out.println(...)等)。

2.

使用log4j,需要整个系统有一个统一的log机制,有利于系统的规划。

log4j的使用本身很简单。但合理地规划一个系统的统一log机制需要周全的考虑。

其他关于log4j的信息参看log4j自带的文档。

PART II 配置文件详细解释
先看一个配置文件的例子:

1.

配置文件的例子
  1. log4j.rootLogger=DEBUG
  2. #将DAO层log记录到DAOLog,allLog中
  3. log4j.logger.DAO=DEBUG,A2,A4
  4. #将逻辑层log记录到BusinessLog,allLog中
  5. log4j.logger.Businesslog=DEBUG,A3,A4
  6. #A1--打印到屏幕上
  7. log4j.appender.A1=org.apache.log4j.ConsoleAppender
  8. log4j.appender.A1.layout=org.apache.log4j.PatternLayout
  9. log4j.appender.A1.layout.ConversionPattern=%-5p [%t] 7c %3x - %m%n
  10. #A2--打印到文件DAOLog中--专门为DAO层服务log4j.appender.A2=org.apache.log4j.DailyRollingFileAppender
  11. log4j.appender.A2.file=DAOLog
  12. log4j.appender.A2.DatePattern='.'yyyy-MM-dd
  13. log4j.appender.A2.layout=org.apache.log4j.PatternLayout
  14. log4j.appender.A2.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
  15. #A3--打印到文件BusinessLog中--专门记录逻辑处理层服务log信息log4j.appender.A3=org.apache.log4j.DailyRollingFileAppender
  16. log4j.appender.A3.file=BusinessLog
  17. log4j.appender.A3.DatePattern='.'yyyy-MM-dd
  18. log4j.appender.A3.layout=org.apache.log4j.PatternLayout
  19. log4j.appender.A3.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
  20. #A4--打印到文件alllog中--记录所有log信息log4j.appender.A4=org.apache.log4j.DailyRollingFileAppender
  21. log4j.appender.A4.file=alllog
  22. log4j.appender.A4.DatePattern='.'yyyy-MM-dd
  23. log4j.appender.A4.layout=org.apache.log4j.PatternLayout
  24. log4j.appender.A4.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n


2.

Appender的使用
一个Appender代表log信息要写向的一个地方。log4j可使用的Appender有很多类型,这里只考虑3种:ConsoleAppender,FileAppender,DailyRollFileAppender
2.1
ConsoleAppender
如果使用ConsoleAppender,那么log信息将写到Console。就是直接把信息打印到System.out上了。
2.2
FileAppender
使用FileAppender,那么log信息将写到指定的文件中。这应该是比较经常使用到的情况。
相应地,在配置文件中应该指定log输出的文件名。如下配置指定了log文件名为demo.txt
log4j.appender.A2.File=demo.txt
注意将A2替换为具体配置中Appender的别名。
2.3
DailyRollingAppender
使用FileAppender可以将log信息输出到文件中,但是如果文件太大了读起来就不方便了。这时就可以使用DailyRollingAppender。DailyRollingAppender可以把Log信息输出到按照日期来区分的文件中。如下配置文件就会每天产生一个log文件,每个log文件只记录当天的log信息:

  1. log4j.appender.A2=org.apache.log4j.DailyRollingFileAppender
  2. log4j.appender.A2.file=demo
  3. log4j.appender.A2.DatePattern='.'yyyy-MM-dd
  4. log4j.appender.A2.layout=org.apache.log4j.PatternLayout
  5. log4j.appender.A2.layout.ConversionPattern=%m%n


3.

Layout的配置
Layout指定了log信息输出的样式。
详细信息请查看PatternLayout的javadoc。
例子1:显示日期和log信息
  1. log4j.appender.A2.layout=org.apache.log4j.PatternLayout
  2. log4j.appender.A2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %m%n

打印的信息是:
2002-11-12 11:49:42,866 SELECT * FROM Role WHERE 1=1 order by createDate desc

例子2:显示日期,log发生地方和log信息
  1. log4j.appender.A2.layout=org.apache.log4j.PatternLayout
  2. log4j.appender.A2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %l "#" %m%n
  3. 2002-11-12 11:51:46,313 cn.net.unet.weboa.system.dao.RoleDAO.select(RoleDAO.java:409) "#" SELECT * FROM Role WHERE 1=1 order by createDate desc

例子3:显示log级别,时间,调用方法,log信息
  1. log4j.appender.A2.layout=org.apache.log4j.PatternLayout
  2. log4j.appender.A2.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%nlog信息:[DEBUG] 2002-11-12 12:00:57,376 method:cn.net.unet.weboa.system.dao.RoleDAO.select(RoleDAO.java:409)
  3. SELECT * FROM Role WHERE 1=1 order by createDate desc


PART 3 log4j的使用
log4j使用步骤有3个:
3.1
.根据配置文件初始化log4j
配置文件如PART 2所叙述。现在讲的是如何在程序中配置log4j。
log4j可以使用3中配置器来初始化:BasicConfigurator,DOMConfigurator,PropertyConfigurator
这里用的是PropertyConfigurator。使用PropertyConfigurator适用于所有的系统。
如下的语句
PropertyConfigurator.configure("log4j.properties");
就以log4j.properties为配置文件初始化好了log4j环境。
注意一点:这个语句只需要在系统启动的时候执行一次。例如:在unet webOA项目中可以这么用:
在ActionServlet的init()方法中调用一次。
共2页: 上一页 1 [2] 下一页

上一篇:J2SE综合--关于字符串的一些处理技巧   下一篇:J2EE综合--java语言不一定就跨平台

收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·J2SE综合--关于字符串的一些处理技巧
·基础:Java中两个特殊变量this和super
·Java语言深入--Java中日期的使用方法
·进阶--对Java/JSP中文乱码问题解决心得
·eclispe下开发struts完整解决乱码问题
·走出abstract class与interface的困惑
·Java语言深入--讨论什么叫面向接口编程
·JAVA基础:JSP中监测JVM的内存使用情况
·Java语言深入--深入浅析Java的反射机制
·J2SE综合:介绍一个解析日期格式的方法
·基础:Java初学者都必须理解的六大问题
·高手对 CLASSPATH 的详解
·高级:lucene全文检索应用示例及代码简析
·Java语言深入:浅析Java语言中的内部类
·Java语言深入--抽象类和接口的区别
·Java语言深入:C#与Java相似之处的对比
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·Java开发下的设计模式简单说明
·JAVA语言关于字符串替换的思考
·编写高级JavaScript应用代码
·常用的JDBC连接数据库方法大全
·解决JSP开发中Web程序中文显示三种方法
·对于Spring初学者的学习建议
·Java开发编程规范大分享
·站在巨人肩膀上学好J2EE全攻略
·Java网络编程基础(四) ServerSocket类
·Java网络编程基础(三) Datagram类使用
·Java学习过程中应该深入理解的一些重点
·Java网络编程基础(二) Socket类的使用
  阅读排行
·Java语言深入--java调用C/C 的过程
·一个非常有趣的使用spring框架AOP例子
·初学者Structs中基本配置入门
·使用AJAX技术实现网页无闪自动局部刷新
·关于java中相对路径,绝对路径问题总结
·JAVA基础:一个struts hibernate入门实
·高级:lucene全文检索应用示例及代码简
·一个基于Java Socket实现文件传输示例
·Hibernate配置文件中的映射元素详解
·关于角色访问控制(RBAC)
·快速教您Apache Tomcat SSL的配置
·使用WEBWORK实现文件上传方法实例详解
·JSP/Servlet:< jsp-config>标签使用详
·在struts里实现dtree通用树型结构讲解
·JSP JavaBean Servlet工作原理实例讲解
网摘收藏: