我正在使用 Apache Commons DBCP。有一个任务来跟踪 DBCP 的内部行为 - 活动和空闲连接的数量。
我发现 DBCP 根本没有任何此类日志记录。是的,当从池中借用连接时,可以编写输出 BasicDataSource 状态的代码。但是,当连接返回或关闭时,无法跟踪 BasicDataSource 的状态,因为连接对象对池一无所知。
有任何想法吗?
我认为方面可能可以解决您的困惑。查看:
- http://static.springsource.org/spring/docs/current/spring-framework-reference/html/aop.html#aop-introduction-spring-defn http://static.springsource.org/spring/docs/current/spring-framework-reference/html/aop.html#aop-introduction-spring-defn
- http://www.ibm.com/developerworks/java/library/j-ajdt/ http://www.ibm.com/developerworks/java/library/j-ajdt/
- http://www.eclipse.org/aspectj/doc/released/progguide/index.html http://www.eclipse.org/aspectj/doc/released/progguide/index.html
基本上,您可以编写一两个方面来“锁定”DBCP 内某些方法的执行。
就像是:
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.ProceedingJoinPoint;
@Aspect
public class AroundExample {
@Around("org.apache.commons.dbcp.PoolingDataSource.getConnection()")
public Object doBasicPStuff(ProceedingJoinPoint pjp) throws Throwable {
// write code to do what you want
final PoolingDataSource ds = (PoolingDataSource) pjp.getThis();
// log whatever you want
// let it finish
Object retVal = pjp.proceed();
// stop stopwatch
return retVal;
}
}
这只是一个小例子。方面确实很强大,并且有很多不同的方法可以实现您想要的功能。代码取决于您是否使用 Spring,以及您到底想要记录什么。
附:我没有测试过上面的代码。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)