1

我尝试了两种方法来将 p6Spy 功能添加到我的 spring 使用的项目中。

路线一,

http://templth.blogspot.com.tr/2004/11/integrate-p6spy-with-spring.html 我改变了我的驱动程序com.p6spy.engine.spy.P6SpyDriver并将realdriver添加 realdriver=com.ibm.db2.jcc.DB2Driverspy.properties文件中。

但不知何故,我的 realdriver 是在 p6spy 驱动程序 com.ibm.db2.jcc.DB2Driver 之前注册的,它是 spy.properties 中的真实驱动程序,但它在 p6spy 之前已加载。p6spy 不会包装这些连接。要么阻止驱动程序加载,要么尝试在 spy.properties 中将 'deregisterdrivers' 设置为 true

使用:p6spy:前缀对我不起作用。它说无法与该网址建立连接。

所以,我选择deregisterdrivers=true在属性文件中设置它。这次我在日志文件中获取 sql 但无法执行 sqls。我可以在另一个 sql 编辑器中执行 sql。似乎真正的联系消失了,一个虚拟的联系出现了。

路线二,我们用弹簧。所以我试过这个方法。将数据源明确地提供给 p6Spy。但是这次 spring 抱怨了多个 java.sql.DataSource 实例。两者都com.firm.BasicDataFill实现com.p6spy.engine.spy.P6DataSource了 DataSource。Spring 无法获得单例。

http://templth.blogspot.com.tr/2004/11/integrate-p6spy-with-spring.html

<bean id="dataSource" lazy-init="true"
    class="com.firm.BasicDataFill">
    <property name="driverClassName" value="${database.connection.driver_class}" />
    <property name="username" value="${database.connection.username}" />
    <property name="password" value="${database.connection.password}" />
    <property name="url" value="${database.connection.url}" />
       ...
    <property name="accessToUnderlyingConnectionAllowed" value="true" />                                
</bean>

<!-- bean id="myDataSource" class="com.p6spy.engine.spy.P6DataSource">
    <constructor-arg>
        <ref local="dataSource"/>
    </constructor-arg>
</bean-->

最后,我发现 p6spy v1.3 和 2.4.1 的设置有所不同。您对基于弹簧的应用程序有什么建议吗?

4

2 回答 2

1

我建议从最新版本的 P6Spy 2.x 开始。您还应该使用此处记录的 2.X 的默认版本替换您的 spy.properties 文件。根据您的应用程序服务器,您可能需要在 spy.properties 中设置“realdriver”设置以包含“com.ibm.db2.jcc.DB2Driver”。但是,仅当您使用阻止 JDBC 驱动程序自动注册的应用程序服务器时才需要这样做。

要将 P6Spy 与 Spring 一起使用,最简单的方法是使用 P6SpyDataSource 包装当前数据源 bean,如此处所述。该答案中的示例显示了一个被包装的 JNDI 数据源,但它可用于包装任何数据源。注意:如果你包装的数据源是 P6SpyDataSource,你不需要修改 JDBC URL。

如果您仍然有问题,请在您的问题中添加更多信息。以下信息将有助于故障排除:

  1. 正在使用的 P6Spy 版本
  2. spy.properties 的内容
  3. 数据源的定义(如果使用 JNDI,包括应用服务器配置)
  4. 正在使用的应用服务器类型和版本
  5. Stacktrace 包含您可能收到的任何错误。
于 2015-07-10T15:07:07.173 回答
-1

看看 Log4jdbc 它会完成这项工作https://code.google.com/p/log4jdbc/

于 2015-07-10T09:41:19.050 回答