tomcat中连接池的java理想结构
看看我在下面提出的问题,每当我想使用连接池访问我的数据库时,总是需要调用servlet中的Init方法来检索连接,对我来说这是一个问题,我已经在页面上回顾了几个问题
我的想法是调用我的第一个servlet init,然后连接发送会话以对我的数据库进行更改,而不必调用init方法,但我的问题是,我应该在哪里关闭连接
我试图找到一个理想的连接池结构来解决这个问题
我的init方法包含以下内容
public void init(ServletConfig config) throws ServletException {
Context ctx;
try {
ctx = new InitialContext();
sourceDb = (DataSource) ctx.lookup("java:comp/env/jdbc/Practica5");
} catch (NamingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
我将在以下时间参加会议:
synchronized (sourceDb) {
con = sourceDb.getConnection();
}
if (con == null) {
throw new ServletException("Problemas con la conexion");
}
request.getSession().setAttribute("con",con);
# 1 楼答案
在会话中共享数据库连接在任何时候都会很麻烦。。。 我觉得在执行过程中可能会导致序列化问题
如果要求在会话中使用单个连接对象,那么最好将连接对象返回到池中,并在另一个servlet中再次获取它
在这种情况下,我们将确保通过数据源在servlet之间维护连接对象