深入体验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自带的数据源进行获取连接的操作了。好了,自己动手试试吧!

 


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值