java - 使用 Liberty 配置文件配置 log4jdbc-log4j2

标签 java db2 log4j2 websphere-liberty log4jdbc

我有一个本地部署到 Liberty Profile 服务器的 Web 应用程序,并且已经在使用 log4j2。我的最终目标是在针对 DB2 数据库运行之前,记录所有的PreparedStatements及其包含在查询字符串中的参数值。

我一直按照 https://code.google.com/p/log4jdbc-log4j2 上的说明进行操作设置 log4jdbc-log4j2。我能够使用 Maven 获取依赖文件:

<dependency>
    <groupId>org.bgee.log4jdbc-log4j2</groupId>
    <artifactId>log4jdbc-log4j2-jdbc4</artifactId>
    <version>1.16</version>
</dependency>

但是,我已经在步骤 3.1 和 3.2 上停留了一段时间,到目前为止,stackoverflow 或教学博客上没有任何内容可以帮助我前进,所以我认为是时候问自己的问题了。

有人可以告诉我应该在哪个文件中以及如何进行步骤 3.1(“更改您的 JDBC URL”)和 3.2(“更改使用的驱动程序”)中提到的更改吗?如果有什么我可以进一步澄清的内容,请告诉我,以帮助回答我的问题,并提前感谢您提供的任何帮助或指导。

更新

对 server.xml 建议的 aguibert 进行更改并包含 db2 驱动程序目录中依赖项中的所有 log4j*.jar 文件后,我的 server.xml 条目如下所示:

<dataSource id="myDataSource" jndiName="jdbc/myDataSource" type="javax.sql.DataSource">
    <jdbcDriver javax.sql.DataSource="net.sf.log4jdbc.sql.jdbcapi.DataSourceSpy">
        <library>
            <fileset dir="<path to dir>/db2" includes="db2jcc_license_cisuz.jar db2jcc4.jar log4j-api-2.3.jar log4j-core-2.3.jar log4jdbc-log4j2-jdbc4-1.16-sources.jar log4jdbc-log4j2-jdbc4-1.16.jar"/>
        </library>
    </jdbcDriver>   
    <properties
        password="password"
        user="user"
        URL="jdbc:log4jdbc:db2://<normal jdbc url>" />
</dataSource>

现在,当进行第一个查询时,我在 net.sf.log4jdbc.sql.jdbcapi.DataSourceSpy 上收到 InstantiationException:

java.lang.Exception:
    at <my files>
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:595) [com.ibm.ws.javaee.servlet.3.0_1.0.8.jar:?]
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:668) [com.ibm.ws.javaee.servlet.3.0_1.0.8.jar:?]
    at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1285) [com.ibm.ws.webcontainer_1.0.8.jar:?]
    at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:776) [com.ibm.ws.webcontainer_1.0.8.jar:?]
    at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:473) [com.ibm.ws.webcontainer_1.0.8.jar:?]
    at com.ibm.ws.webcontainer.filter.WebAppFilterManager.invokeFilters(WebAppFilterManager.java:1104) [com.ibm.ws.webcontainer_1.0.8.jar:?]
    at com.ibm.ws.webcontainer.webapp.WebApp.handleRequest(WebApp.java:4845) [com.ibm.ws.webcontainer_1.0.8.jar:?]
    at com.ibm.ws.webcontainer.osgi.DynamicVirtualHost$2.handleRequest(DynamicVirtualHost.java:297) [com.ibm.ws.webcontainer_1.0.8.jar:?]
    at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:981) [com.ibm.ws.webcontainer_1.0.8.jar:?]
    at com.ibm.ws.webcontainer.osgi.DynamicVirtualHost$2.run(DynamicVirtualHost.java:262) [com.ibm.ws.webcontainer_1.0.8.jar:?]
    at com.ibm.ws.http.dispatcher.internal.channel.HttpDispatcherLink$TaskWrapper.run(HttpDispatcherLink.java:955) [com.ibm.ws.transport.http_1.0.8.jar:?]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) [?:1.7.0_60]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) [?:1.7.0_60]
    at java.lang.Thread.run(Thread.java:745) [?:1.7.0_60]
Caused by: javax.naming.NamingException: CWWKN0008E: An object could not be obtained for name jdbc/myDataSource.
    at com.ibm.ws.jndi.internal.WSContext.resolveObject(WSContext.java:128) ~[?:?]
    at com.ibm.ws.jndi.internal.WSContext.lookup(WSContext.java:364) ~[?:?]
    at com.ibm.ws.jndi.internal.WSContext.lookup(WSContext.java:359) ~[?:?]
    at org.apache.aries.jndi.DelegateContext.lookup(DelegateContext.java:161) ~[?:?]
    at javax.naming.InitialContext.lookup(InitialContext.java:411) ~[?:1.7.0_60]
    at  <my files>
    ... 16 more
[ERROR   ] CWWKE0701E: FrameworkEvent ERROR Bundle:com.ibm.ws.jdbc(id=69) org.osgi.framework.ServiceException: Exception in com.ibm.ws.resource.internal.ResourceFactoryTrackerData$1.getService()
    at org.eclipse.osgi.internal.serviceregistry.ServiceFactoryUse.factoryGetService(ServiceFactoryUse.java:222)
    at [internal classes]
    at javax.naming.InitialContext.lookup(InitialContext.java:411)
    at  <my files>
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:595)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:668)
    at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1285)
    at [internal classes]
Caused by: java.lang.RuntimeException: java.sql.SQLNonTransientException: java.lang.InstantiationException: net.sf.log4jdbc.sql.jdbcapi.DataSourceSpy
    at com.ibm.ws.resource.internal.ResourceFactoryTrackerData$1.getService(ResourceFactoryTrackerData.java:109)
    ... 10 more
Caused by: java.sql.SQLNonTransientException: java.lang.InstantiationException: net.sf.log4jdbc.sql.jdbcapi.DataSourceSpy
    at com.ibm.ws.jdbc.internal.JDBCDriverService.create(JDBCDriverService.java:287)
    ... 10 more
Caused by: java.lang.InstantiationException: net.sf.log4jdbc.sql.jdbcapi.DataSourceSpy
    at java.lang.Class.newInstance(Class.java:359)
    at com.ibm.ws.jdbc.internal.JDBCDriverService$1.run(JDBCDriverService.java:228)
    ... 10 more
 Event:org.osgi.framework.FrameworkEvent[source=com.ibm.ws.jdbc_1.0.8.cl50520150305-2202 [69]]

如果我遗漏了什么,请告诉我。在堆栈跟踪中搜索错误没有找到任何解决方案。

最终状态

正如阿吉伯特指出的那样,似乎不同的方向在这里是最好的。基于 Logging PreparedStatements in Java 中的评论,我决定实现一个 LoggableStatement 包装器,如下所述:ibm.com/developerworks/java/library/j-loggable

最佳答案

对于 WebSphere Liberty 服务器,所有全局服务器配置都在 server.xml 文件中完成(默认位于 WLP_INSTALL/usr/servers//server.xml)。

您可能需要在 server.xml 中添加以下内容:

<dataSource id="myDataSource" jndiname="jdbc/myDataSource" type="javax.sql.DataSource">
    <jdbcDriver javax.sql.DataSource="net.sf.log4jdbc.sql.jdbcapi.DataSourceSpy">
      <library>
        <fileset dir="C:/path/to/libs" includes="thedb2jar.jar log4j.jar" />
      </library>
    </jdbcDriver>
    <properties user="user" password="password"
                url="jdbc:log4jdbc:<the normal jdbc url>"/>
</dataSource>

这里的关键部分是该元素设置了“javax.sql.DataSource”属性,并且该值是 log4j jar 的 DataSource 类的名称。此外,在该元素中,您将看到 url 是使用“jdbc:log4jdbc”前缀指定的,如第 3.1 节中所述。

这是未经测试的建议,但您可能需要将两个 jar(db2 jar 和 log4j jar)包含在同一文件夹中,以便在同一元素中选取它们。

关于java - 使用 Liberty 配置文件配置 log4jdbc-log4j2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31123738/

相关文章:

java - 从 hibernate 映射文件生成类

java - 日志记录异常问题

java - log4j2 双美元 $$ 符号在配置中的含义

java - 为什么只有根记录器在具有 JSON 配置的 Log4j 2 中工作?

Java - 使用 .class 文件编译

java - 有没有办法在使用java锁定窗口时获取屏幕截图?

java - 从 3.4.d 迁移扩展到 4.2.e(和 5.0.a)后,Alfresco 无法加载 spring 上下文

c - 当从 C 代码中检索到来自 db2 的空值时,它是什么样子的?

sql - 如何显式显示 count(*) 等于 0 的行

sql-server - 不同数据库中的位图索引支持