Tomcat配置JNDI数据源

数据库连接池这个概念应该都不陌生,在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);  
    } 

Tomcat配置JNDI数据源_第1张图片

你可能感兴趣的:(tomcat,JNDI)