0

我已阅读此页面:http ://www.javaranch.com/journal/200601/JDBCConnectionPooling.html

Method Scope Connections 的方法对我来说似乎相当不错。但是我有一个问题,我什么时候初始化 JDBCServlet 类?每次我想要一个连接?因为我认为每次我想要一个连接我只是打电话给getConnection()......

public class JDBCServlet extends HttpServlet {

  private DataSource datasource;

  public void init(ServletConfig config) throws ServletException {
    try {
      // Look up the JNDI data source only once at init time
      Context envCtx = (Context) new InitialContext().lookup("java:comp/env");
      datasource = (DataSource) envCtx.lookup("jdbc/MyDataSource");
    }
    catch (NamingException e) {
      e.printStackTrace();
    }
  }

  private Connection getConnection() throws SQLException {
    return datasource.getConnection();
  }

  public void doGet (HttpServletRequest req, HttpServletResponse res) throws ServletException {
    Connection connection=null;
    try {
      connection = getConnection();
      ..<do JDBC work>..
    } 
    catch (SQLException sqlException) {
      sqlException.printStackTrace();
    }
    finally {
      if (connection != null) 
        try {connection.close();} catch (SQLException e) {}
      }
    }
  }
}
4

3 回答 3

2

当您导航到 servlet 映射到的链接时,将调用 JDBCServlet servlet。

因此,除了在 web.xml 中完成从 URL 到 servlet 的映射之外,您不必做任何事情。

然后,Web 容器使用 init 方法创建 servlet 的实例,然后调用 doGet。

这是一个带有 tomcat 的 servlet 教程的 PDF,但基础是相同的。

http://www.tutorialspoint.com/servlets/servlets_tutorial.pdf

查看 servlet 部署部分

对于 DBUtil 类,这是一个很好的例子。

public class DBUtil {

private static DataSource dataSource;

static {
    try {
        dataSource = new InitialContext().lookup("jdbc/MyDataSource");
    } catch (NamingException e) { 
        throw new ExceptionInInitializerError("'jdbc/MyDataSource' not found in JNDI", e);
    }
}

public static Connection getConnection() {
    return dataSource.getConnection();
}

}

这使您的类可以被 Web 应用程序中的所有 servlet 使用。

您将调用 DBUtil 类

try {
    connection = DBUtil.getConnection();
    statement = connection.prepareStatement("SELECT id, foo, bar FROM table");
    resultSet = statement.executeQuery();

   //Do what you need to do. 

} finally {
    if (resultSet != null) try { resultSet.close(); } catch (SQLException ignore) {}
    if (statement != null) try { statement.close(); } catch (SQLException ignore) {}
    if (connection != null) try { connection.close(); } catch (SQLException ignore) {}
}
于 2012-10-07T11:07:09.477 回答
1

Servlet 由容器初始化,容器将根据需要调用 init 并由web.xml配置文件定义。

使用以标准方式执行相同操作的Apache Tomcat JDBC 连接池。

于 2012-10-07T11:10:55.043 回答
0

有许多连接池库,包括 MySQL 自己的。很多人都使用非常成熟的C3P0。

常见的想法是您在服务器容器中定义数据源并从您的代码中访问 JNDI 引用。在 servlet 初始化期间,您只是在查找数据源,因此这是执行此操作的理想场所。在您实际执行操作之前,这不会使用任何连接。

如果您希望使用 C3P0 C3P0 Tomcat 配置,请参阅Tomcat DBCP以获得良好的介绍

于 2012-10-07T11:00:21.313 回答