0

このページを読みました: http://www.javaranch.com/journal/200601/JDBCConnectionPooling.html

Method Scope Connections のアプローチは、私にとって非常に良いようです。しかし、1 つ質問があります。いつ 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

JDBCServlet サーブレットは、サーブレットがマップされているリンクに移動すると呼び出されます。

したがって、web.xml で行われる URL からサーブレットへのマッピング以外に何もする必要はありません。

Web コンテナーは、init メソッドを使用してサーブレットのインスタンスを作成し、doGet を呼び出します。

これは、Tomcat を使用したサーブレット チュートリアルの PDF ですが、基本は同じです。

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

サーブレット展開セクションを見てください

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 アプリケーション内のすべてのサーブレットで使用できるクラスが得られます。

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

サーブレットは、必要に応じて init を呼び出すコンテナによって初期化され、web.xml構成ファイルによって定義されます。

標準的な方法で同じことを行うApache Tomcat JDBC 接続プールを使用します。

于 2012-10-07T11:10:55.043 に答える
0

MySQL 独自のものを含む多くの接続プーリング ライブラリがあります。多くの人が非常に成熟した C3P0 を使用しています。

一般的な考え方は、サーバー コンテナーでデータソースを定義し、コードから JNDI 参照にアクセスするというものです。サーブレットの初期化中は、データソースを検索しているだけなので、これを行うのに理想的な場所です。実際にアクションを実行するまで、これは接続を使用しません。

良いイントロについてはTomcat DBCPを参照してください。C3P0 を使用したい場合はC3P0 Tomcat Configuration

于 2012-10-07T11:00:21.313 に答える