[置顶] 深入体验JavaWeb开发内幕——配置TomCat数据源

      

        前面我们提到过使用数据库连接池来获取连接以提高程序的性能,并简单介绍了使用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自带的数据源进行获取连接的操作了。好了,自己动手试试吧!

 


你可能感兴趣的:([置顶] 深入体验JavaWeb开发内幕——配置TomCat数据源)