数据库连接池这个概念应该都不陌生,在Java中连接池也就是数据库的连接池,它是一种采用连接复用的思想避免多次连接造成资源的浪费机制。
最常见的连接池就是DBCP和C30P了,在tomcat中默认使用的DBCP的连接池,在Hibernate中则默认使用的是C3P0。他们的区别对于使用者来说最明显的就是,默认情况下DBCP不提供空闲连接的释放,需要手动开启。
tomcat目录下的context.xml里面配置数据源:
<Resource name="jndi/mytest" auth="Container" type="javax.sql.DataSource"
driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/php_test"
username="root" password="xxxxx" maxActive="20" maxIdle="10" maxWait="10000" />
<Resource name="jndi/mytest1" auth="Container" type="javax.sql.DataSource"
driverClassName="oracle.jdbc.OracleDriver" url="jdbc:oracle:thin:@localhost:1521:xe"
username="heying" password="xxxxx" maxActive="20" maxIdle="10" maxWait="10000" />
Java测试代码:
public void testJNDI() throws NamingException, SQLException{
Context ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup("java:comp/env/jndi/mytest");
Connection conn = ds.getConnection();
System.out.println(conn);
}
public void testJNDI1() throws NamingException, SQLException{
Context ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup("java:comp/env/jndi/mytest1");
Connection conn = ds.getConnection();
System.out.println(conn);
}