`
rq2_79
  • 浏览: 239763 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

试用log4jdbc

    博客分类:
  • jdbc
阅读更多

近日发现一个好东东log4jdbc,他是一个JDBC驱动器,能够记录SQL日志和SQL执行时间等信息。log4jdbc使用SLF4J(Simple Logging Facade For Java)作为日志系统。特性:
1.支持JDBC3和JDBC4,其中JDBC3对应于JDK 1.4 or 1.5,JDBC4要求JDK 1.6或以上。
2.支持现有大部分JDBC驱动。
3.易于配置(在大部分情况下,只需要改变驱动类名并在jdbc url前加上”jdbc:log4“,设置好日志输出级别)。
4.能够自动把SQL变量值加到SQL输出日志中,改进易读性和方便调试。
5.能够快速标识出应用程序中执行比较慢的SQL语句。
6.能够生成SQL连接数信息帮助识别连接池/线程问题。

由于我们的持久层框架采用Ibatis,而系统操作的数据量也非常的大,所有的SQL前线前都必须通过DBA的审核和调优;而为了提升性能,要求所 有的SQL都必须用动态绑定的方式,而不能拼装SQL;这样在调试SQL时就会有些不方便,而且自己不知道各SQL执行所消耗的时间(公司也有提供 SQLTrace工具,但是用起来比较复杂);以前国际站自己也写了一个类似的框架alibaba-intl-ark来对Oracle的JDBC驱动进行 封装,也尝试过使用,使用的结果并不是很理想,兼容性比较差,功能也不是很完善,所以该框架也就没多少人使用了;

发现log4jdbc之后立马试用了一把,感觉还不错的,下面简单介绍下使用步骤和方法:
1、到官网下载log4jdbc和slf4j的jar包;比如log4jdbc3-1.1.jar、slf4j-api-1.5.0.jar,对于slf4j要看系统到底使用什么log框架,若使用log4j,则需要slf4j-log4j12-1.5.0.jar;
2、 将应用中的driver-class设置为net.sf.log4jdbc.DriverSpy;对于常用的jdbc驱动无需其他设置,比如oracle 驱动oracle.jdbc.driver.OracleDriver也已经在默认设置中了,若默认驱动列表中不包括你的应用系统中需要的驱动,那需要通 过-Dlog4jdbc.drivers来进行设置系统属性,支持的默认驱动列表可到官网查看,网址见后;
3、在应用中jdbc url最前面添加jdbc:log4;比如oracle的url就变成了jdbc:log4jdbc:oracle:thin:@x.x.x.x:1521:dbname;
4、在日志系统中设置jdbc.sqlonly、jdbc.sqltiming等日志级别,可直接将log4jdbc doc中的日志内容copy过去;
5、运行系统测试,到对应日志文件中查看SQL相关信息;

前面提到了基本的log4jdbc配置和功能,除了这些之外,他也还提供一些比较复杂的功能, 比如可以通过-Dlog4jdbc.sqltiming.warn.threshold参数设置SQL耗时多少以上就打印warn信息;另 外,log4jdbc还提供了一个对日志文件进行分析的脚本;
经测试,log4jdbc不能在XA环境下使用,比如jboss datasource配置中,若以非XA形式local-tx-datasource配置,则没有问题;若以xa-datasource配置,则无法生 效,系统运行时不能取得connection;究其原因的话,是由于log4jdbc针对的是driver-class的封装,而不是 datasource-class;所以对系统中使用XA的用户来说就无法使用该框架了,若一定要使用,只能修改成local-tx- datasource类型;

PS:以下是相关链接地址
log4jdbc:http://log4jdbc.sourceforge.net/
slf4j:http://slf4j.org/

分享到:
评论
1 楼 四个石头 2011-04-11  

相关推荐

    WebSphere部署war项目

    默认情况下,日志会记录在文件中,但可以修改配置使日志直接输出到控制台,例如将${SERVER_LOG_ROOT}/SystemOut.log和${SERVER_LOG_ROOT}/SystemErr.log改为console。记得在正式运行时恢复原来的设置,以便更好地...

    WebSphere安装手册(中文版)

    - 修改`${SERVER_LOG_ROOT}/SystemOut.log`和`${SERVER_LOG_ROOT}/SystemErr.log`为`console`。 ##### 3. 数据源配置 为了与数据库(如SQL Server 2005)集成,需要配置相应的JDBC数据源: - 在概要文件管理控制台...

    JBuilder+SQL Server开发hibernate

    5. 将Hibernate源代码中的`hibernate.properties`和`log4j.properties`文件复制到`testhibernate`项目的`src`目录下。 6. 修改`hibernate.properties`文件以适应MS SQL Server 2000。原文件中默认配置是针对...

    演示版

    8. **日志记录**:可能会使用Log4j、SLF4J等日志框架来记录程序运行过程中的信息,帮助调试和问题排查。 这个“演示版”项目对于初学者来说,是一个了解和学习Java数据库操作的好资源,同时也适用于有经验的开发者...

    java_Java_订阅管理系统_大作业

    使用Log4j、SLF4J或Java内置的日志框架记录系统运行时信息,有助于定位和解决问题。 10. **部署与运维**:最后,系统需要部署到服务器上,可以使用Docker容器化技术简化部署过程,同时监控系统性能,如使用...

    Linux环境Websphere超详细安装配置文档

    如果在安装过程中遇到问题,如profileType参数缺失,可能是由于使用了试用版,应使用服务器集群版。 3. **静默安装**:以root用户身份,进入`/websphere/WAS/`目录,执行`sh install -options "responsefile_edit....

    帆软FCRA题库20181231(积分是系统自动上调,变高了通知我改下)

    - **知识点**: %WebReport%\\WEB-INF\\logdb 文件夹用于存放日志记录。 - 日志记录有助于追踪系统运行状态和调试问题。 **21. 默认预览端口** - **知识点**: FineReport 在本机进行报表预览时,默认使用的端口号为...

Global site tag (gtag.js) - Google Analytics