gpt4 book ai didi

java - 使用 JDBC 时如何为 SQL 语句启用日志记录

转载 作者:IT老高 更新时间:2023-10-28 20:23:08 30 4
gpt4 key购买 nike

我正在尝试通过连接到 Eclipse IDE 中的 Oracle 数据库来使用我的 JDBC 程序启用日志。

我已经浏览了这篇 SO 帖子 JDBC logging to file然后我创建了下面的 java 程序并从我的 eclipse IDE 运行它,但我无法看到 JDBC 驱动程序类生成的任何日志。

import java.io.File;
import java.io.FileInputStream;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Properties;
import java.util.logging.LogManager;
import java.util.logging.Logger;

public class Logging {

static Logger log = Logger.getLogger(Logging.class.toString());
static Connection con = null;

public static void main(String[] args) throws SQLException,
ClassNotFoundException {
System.setProperty("oracle.jdbc.Trace", Boolean.TRUE.toString());
System.setProperty("java.util.logging.config.file",
"OracleLog.properties");
log.info("Test Message");
enableLogging(false);
getConnection();
closeConnection();
}

static private void enableLogging(boolean logDriver) {
try {
oracle.jdbc.driver.OracleLog.setTrace(true);

// compute the ObjectName
String loader = Thread.currentThread().getContextClassLoader()
.toString().replaceAll("[,=:\"]+", "");
javax.management.ObjectName name = new javax.management.ObjectName(
"com.oracle.jdbc:type=diagnosability,name=" + loader);

// get the MBean server
javax.management.MBeanServer mbs = java.lang.management.ManagementFactory
.getPlatformMBeanServer();

// find out if logging is enabled or not
System.out.println("LoggingEnabled = "
+ mbs.getAttribute(name, "LoggingEnabled"));

// enable logging
mbs.setAttribute(name, new javax.management.Attribute(
"LoggingEnabled", true));

File propFile = new File("path/to/properties");
LogManager logManager = LogManager.getLogManager();
logManager.readConfiguration(new FileInputStream(propFile));

if (logDriver) {
DriverManager.setLogWriter(new PrintWriter(System.err));
}
} catch (Exception e) {
e.printStackTrace();
}
}

public static Connection getConnection() throws SQLException,
ClassNotFoundException {
Properties connectionProps = new Properties();
connectionProps.put("user", "test_app");
connectionProps.put("password", "test");

Class.forName("oracle.jdbc.driver.OracleDriver");
con = DriverManager.getConnection(
"jdbc:oracle:thin:@"+HOST_IP+":1521:"+SID,
connectionProps);
System.out.println("Connected to database");
return con;
}

public static void closeConnection() throws SQLException {
if (con != null) {
con.close();
}
}

}

我的 OracleLog.properties 文件中有以下内容:

.level=SEVERE
oracle.jdbc.level=INFO
oracle.jdbc.handlers=java.util.logging.ConsoleHandler
java.util.logging.ConsoleHandler.level=INFO
java.util.logging.ConsoleHandler.formatter=java.util.logging.SimpleFormatter

但是当我通过在类路径中放置 ojdbc6-11.2.0.3.jar 来运行我的程序时,我得到了异常:

INFO: Test Message
javax.management.InstanceNotFoundException: com.oracle.jdbc:type=diagnosability,name=sun.misc.Launcher$AppClassLoader@73d16e93
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getMBean(DefaultMBeanServerInterceptor.java:1095)
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getAttribute(DefaultMBeanServerInterceptor.java:643)
at com.sun.jmx.mbeanserver.JmxMBeanServer.getAttribute(JmxMBeanServer.java:678)
at myjdbc.Logging.enableLogging(Logging.java:45)
at myjdbc.Logging.main(Logging.java:24)
Connected to database

如果我在类路径中有 ojdbc6_g.jar,那么我也会遇到同样的异常。

请告诉我如何为我的 JDBC 程序启用日志记录?基本上我希望看​​到内部 JDBC 代码生成的日志。

更新:现在我将 ojdbc6dms.jar 文件放在类路径中,我的程序给出以下异常:

Nov 28, 2014 9:09:02 PM jdbc.chap2.Logging main
INFO: Test Message
javax.management.InstanceNotFoundException: com.oracle.jdbc:type=diagnosability,name=sun.misc.Launcher$AppClassLoader@73d16e93
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getMBean(DefaultMBeanServerInterceptor.java:1095)
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getAttribute(DefaultMBeanServerInterceptor.java:643)
at com.sun.jmx.mbeanserver.JmxMBeanServer.getAttribute(JmxMBeanServer.java:678)
at jdbc.chap2.Logging.enableLogging(Logging.java:45)
at jdbc.chap2.Logging.main(Logging.java:24)
Exception in thread "main" java.lang.NoClassDefFoundError: oracle/dms/console/DMSConsole
at oracle.jdbc.driver.DMSFactory.<clinit>(DMSFactory.java:48)
at oracle.jdbc.driver.PhysicalConnection.createDMSSensors(PhysicalConnection.java:2121)
at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:730)
at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:433)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:32)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:608)
at java.sql.DriverManager.getConnection(DriverManager.java:664)
at java.sql.DriverManager.getConnection(DriverManager.java:208)
at jdbc.chap2.Logging.getConnection(Logging.java:70)
at jdbc.chap2.Logging.main(Logging.java:25)
Caused by: java.lang.ClassNotFoundException: oracle.dms.console.DMSConsole
at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 10 more

最佳答案

2019 年更新:自 2015 年以来未维护 log4jdbc。p6spy似乎仍在积极维护中。

原答案

有很多 Spy 框架可用于此目的,请查看 log4jdbc ,我觉得这就是你要找的。

特点

  • 完全支持 JDBC 3 和 JDBC 4!
  • 在大多数情况下易于配置您需要做的就是将驱动程序类名称更改为net.sf.log4jdbc.DriverSpy 并将“jdbc:log4”添加到您现有的jdbc url,设置您的日志记录类别,您就可以开始了!
  • 在记录的输出中,对于准备好的语句,绑定(bind)参数是自动插入到 SQL 输出中。这大大提高了许多情况下的可读性和调试。
  • 可以生成 SQL 计时信息,以帮助确定 SQL 语句运行所需的时间,帮助识别运行速度过慢的语句,这可以使用附带的工具对数据进行后处理以生成分析报告数据以快速识别应用程序中的慢速 SQL。
  • 生成SQL连接号信息,帮助识别连接池或线程问题。适用于任何底层证券JDBC驱动,JDK 1.4及以上,SLF4J 1.x。
  • 开源软件,根据商业友好型 Apache 2.0 许可证获得许可

用法

  • 将 log4jdbc jar(基于 JDK 版本)放入应用程序的类路径中。
  • 选择使用的日志系统,支持log4j、logback、commons logging..等
  • 在应用程序的配置中将 JDBC 驱动程序类设置为 net.sf.log4jdbc.DriverSpy。在许多情况下被监视的底层驱动程序将自动加载,无需任何额外配置。
  • 将 jdbc:log4 添加到您正在使用的普通 jdbc url。

    例如,如果您的正常 jdbc url 是 jdbc:derby://localhost:1527//db-derby-10.2.2.0-bin/databases/MyDatabase那么您将其更改为: jdbc:log4jdbc:derby://localhost:1527//db-derby-10.2.2.0-bin/databases/MyDatabase

  • 设置您的记录器。

    jdbc.sqlonly:仅记录 SQL。在准备好的语句中执行的 SQL 会自动显示,其绑定(bind)参数替换为在该位置绑定(bind)的数据,从而大大提高了可读性。 1.0

    jdbc.sqltiming:记录 SQL,执行后,包括有关 SQL 执行时间的计时统计信息。 1.0

    jdbc.audit:记录除 ResultSets 之外的所有 JDBC 调用。这是一个非常庞大的输出,通常不需要,除非跟踪特定的 JDBC 问题。 1.0

    jdbc.resultset:更多,因为所有对 ResultSet 对象的调用都被记录下来。 1.0

    jdbc.connection:记录连接打开和关闭事件以及转储所有打开的连接号。这对于查找连接泄漏问题非常有用。

关于java - 使用 JDBC 时如何为 SQL 语句启用日志记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27060563/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com