JDBC / Connectorj:何时加载驱动程序?

时间:2011-06-26 13:38:39

标签: java mysql jdbc

我想知道为我的Java servlet加载驱动程序的“正确”方法是什么。

目前,我有一个InitializeDrivers()函数,我在应用程序的开头调用。

public static boolean InitializeDrivers()
{
    try {
        Class.forName("com.mysql.jdbc.Driver");
        return true;
    } catch (ClassNotFoundException ex) {
        // log error
        return false;
    }
}

完成后,我继续根据收到的HTTP请求对数据库执行各种请求/插入。但是,由于我的servlet每秒可以接收数百个请求,因此每次请求都会调用一次InitializeDrivers()。

这是正确的方法,还是有办法只加载一次驱动程序?

1 个答案:

答案 0 :(得分:2)

当您在servlet中使用数据库时,最好让servlet容器通过连接池管理数据库连接,而不是直接在servlet中获取数据库连接。

打开与数据库服务器的连接是一个相对较慢的操作。此外,数据库可以同时处理的连接数也是有限的。每次需要访问数据库时打开数据库连接时,您的应用程序将很慢并且不具有很高的可伸缩性。此外,数据库连接不是线程安全的,因此您不能将数据库连接存储在servlet的静态成员变量中,并且每次都使用它。

连接池为您管理多个打开的连接(这样您不必在每次需要访问数据库时都打开连接),并管理同时打开的连接数。例如,在Apache Tomcat中,您可以对其进行配置,以便通过JNDI查找javax.sql.DataSource对象,然后使用该对象从中获取Connection对象。

本页介绍如何配置Tomcat并在servlet中使用DataSource

JNDI Datasource HOW-TO

如果您不想这样做并且想继续使用servlet中的数据库连接(我不建议这样做),那么您可以在servlet的静态初始化程序块中加载驱动程序:

public class MyServlet extends HttpServlet {
    static {
        Class.forName("com.mysql.jdbc.Driver");
    }

    // ...
}

请注意,在JDBC 4.0中,不再需要显式加载驱动程序;只要它们在类路径中,JDBC就会自动查找驱动程序。