前面我们提到过使用数据库连接池来获取连接以提高程序的性能,并简单介绍了使用JDCP和C3P0两种获取数据源的方法,那么如何使用TomCat自带的数据源来获取连接呢?
一、使用Tomcat数据源获取连接的一般步骤
使用TomCat数据源获取连接首先要在自定义的一个名为context.xml文件中进行配置说明;然后将数据库jar文件拷贝到TomCat下的lib(注:是安装TomCat的路径下的lib)文件加下;最后,在需要的类里使用即可。
二、使用使用Tomcat数据源获取连接会用到的技术JNDI
JNDI(Java Namingand Directory Interface),Java命名和目录接口,它对应于J2SE中的javax.naming包,
这套API的主要作用在于:它可以把Java对象放在一个容器中(JNDI容器),并为容器中的java对象取一个名称,以后程序想获得Java对象,只需通过名称检索即可。
其核心API为Context,它代表JNDI容器,其lookup方法为检索容器中对应名称的对象。
三、使用使用Tomcat数据源获取连接的具体实现
1、 context.xml文件的配置
具体(根据自己的实际情况)配置如下:
Context.xml
<Context>
<Resource
name="pool"
auth="Container"
type="javax.sql.DataSource"
username="root"
password="root"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/user"
maxActive="9"
maxIdle="5"
/>
</Context>
然后将该文件放在META-INF文件夹下即可。
2、 jar文件拷贝到TomCat下的lib里
3、 定义类调用相应的方法获取连接
publicclass JNDIServlet extends HttpServlet {
publicvoid doGet(HttpServletRequest request, HttpServletResponseresponse)
throwsServletException, IOException {
try {
//初始化context上下文
Context conIC = new InitialContext();
//检索到Container容器
Context conC = (Context) conIC.lookup("java:comp/env");
//在容器里获取数据源
DataSource ds = (DataSource) conC.lookup("pool");
//获取连接
Connection con = ds.getConnection();
//对连接进行测试输出
System.out.println(con);
} catch(Exception e) {
e.printStackTrace();
}
}
publicvoid doPost(HttpServletRequest request, HttpServletResponseresponse)
throws ServletException, IOException {
doGet(request, response);
}
}
经过这样几步之后你就可以使用TomCat自带的数据源进行获取连接的操作了。好了,自己动手试试吧!