`
eggbucket
  • 浏览: 184547 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

tomcat 连接池

 
阅读更多

     tomcat局部连接池配置

    这里我的Tomcat版本为6.0,这个版本应该说是Tomcat比较稳定的一个版本。
    首先备份你的$TomcatHome$/conf/server.xml文件($TomcatHome$是指你的tomcat安装路径),然后在<Host>节点下添加:

Java代码  收藏代码
  1. <Context path= "/pool"  docBase= "pool" >  
  2.   <Resource name="jdbc/test"  scope= "Shareable"  type= "javax.sql.DataSource" />  
  3.   <ResourceParams name="jdbc/test" >  
  4.     <parameter>  
  5.       <name>factory</name>  
  6.       <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>  
  7.     </parameter>  
  8.     <!-- DBCP database connection settings -->  
  9.     <parameter>  
  10.       <name>url</name>  
  11.       <value>jdbc:jtds:sqlserver://localhost:1433;DatabaseName=pubs</value>   
  12.     </parameter>  
  13.     <parameter>  
  14.       <name>driverClassName</name>  
  15.       <value>net.sourceforge.jtds.jdbc.Driver</value>  
  16.     </parameter>  
  17.     <parameter>  
  18.       <name>username</name>  
  19.       <value>sa</value>  
  20.     </parameter>  
  21.     <parameter>  
  22.       <name>password</name>  
  23.       <value>sa</value>  
  24.     </parameter>  
  25.     <!-- DBCP connection pooling options -->  
  26.     <parameter>  
  27.       <name>maxWait</name>  
  28.       <value>3000 </value>  
  29.     </parameter>  
  30.     <parameter>  
  31.       <name>maxIdle</name>  
  32.       <value>100 </value>  
  33.     </parameter>  
  34.     <parameter>  
  35.       <name>maxActive</name>  
  36.       <value>10 </value>  
  37.     </parameter>  
  38.   </ResourceParams>  
  39. </Context>  


    其中红色部分是你需要修改的。
    <Context path="/pool" docBase="pool">这里的pool是指你的项目在tomcat发布目录webapps下的目录路径,这里我的项目目录为:.../webapps/pool
    <Resource name="jdbc/test"..>jdbc/test为需要通过jndi调用的数据源名称。
    <value>org.apache.commons.dbcp.BasicDataSourceFactory</value> 这里我们用的是dbcp连接池包,这是apache提供的一个免费开源连接池,而且效率和稳定性都不错。如果你使用的是tomcat5x或以上的版本,可 以在$TomcatHome$/common/lib目录下找到它。
    关于数据库的设置,这里就不在多说。

    下面打开web.xml文件,在其根节点下添加数据源的引用设置。

Java代码  收藏代码
  1. <resource-ref>  
  2.   <res-ref-name>jdbc/test</res-ref-name>  
  3.   <res-type>javax.sql.DataSource</res-type>  
  4.   <res-auth>Container</res-auth>  
  5. </resource-ref>  


    最后我们在代码中从连接池获得Connection对象。

Java代码  收藏代码
  1. Context context =  new  InitialContext();  
  2. //获得数据源   
  3. DataSource ds = context.lookup("java:comp/env/jdbc/test" );  
  4. //获取连接   
  5. Connection conn = ds.getConnection();  


    这样我们就在代码中获得了Connection对象,至于剩下的操作,就完全是jdbc操作了。

 

 

 

tomcat全局连接池配置

 

1).不管是tomcat5 还是tomcat6 ,都首先找到Tomcat目录下面的conf目录中的server.xml文件.

           找到<GlobalNamingResources> </GlobalNamingResources>这对标签.

        将这样的一段配置加到标签中间.

 

Xml代码  收藏代码
  1. < Resource    
  2.     name = "jdbc/TestDB"    
  3.     auth = "Container"           
  4.                 type = "javax.sql.DataSource"   
  5.     driverClassName = "com.mysql.jdbc.Driver"    
  6. url = "jdbc:mysql://localhost:3306/test?autoReconnect=true"   
  7.         maxActive = "50"    
  8.     maxldle = "10"    
  9.     maxWait = "5000"   
  10.     username = "root"   
  11.     password = "admin"   />   

        当然,样例是使用 MYSQL配置, 根据不同的需要,将url,driverClassName,username,passsword等参数改变就行.

         然后再找到和server.xml同目录下面的context.xml文件.

   在<Context></Context>标签中添加如下配置.

Xml代码  收藏代码
  1. < ResourceLink   global = "jdbc/TestDB"   name = "jdbc/TestDB"   type = "javax.sql.DataSource" />   

     global="jdbc/TestDB" 中的参数值("jdbc/TestDB")必须和上一段<Resource >配置中的name属性的值保持一样.

     name="jdbc/TestDB" 这个可以随便取,但是在程序中调用的时候,就应该与name的值保持一致.

     到这里,连接池已经配置好啦.

 

   写个jsp测试吧:

 

Java代码  收藏代码
  1. <%@ page language= "java"  pageEncoding= "gbk" %>  
  2. <%@page   import = "java.sql.Connection" %>  
  3. <%@page   import = "javax.naming.Context" %>  
  4. <%@page   import = "javax.naming.InitialContext" %>  
  5. <%@page   import = "javax.sql.DataSource" %>  
  6. <%@page   import = "java.sql.Statement" %>  
  7. <%@page   import = "java.sql.ResultSet" %>  
  8. <%   
  9.    //连接池的获取   
  10.     Connection conn = null ;  
  11.     DataSource ds = null ;  
  12.     ResultSet rs  =null ;  
  13.     Statement stmt = null ;  
  14.     Context initCtx = new  InitialContext();  
  15.     ds =(DataSource)initCtx.lookup("java:comp/env/jdbc/TestDB" );  
  16.    if (ds!= null ){  
  17.         out.println("已经获得DataSource!" );   
  18.         out.println("<br>" );  
  19.         conn = ds.getConnection();  
  20.        try {  
  21.         stmt = conn.createStatement();  
  22.         String sql ="select * from tree_table" ;  
  23.         rs = stmt.executeQuery(sql);  
  24.         out.println("以下是从数据库中读取出来的数据:<br>" );  
  25.             while (rs.next()){  
  26.                 out.println("<br>" );  
  27.                 out.println(rs.getString("nodeName" ));  
  28.             }  
  29.        }catch (Exception ex){  
  30.          ex.printStackTrace();  
  31.        }finally {  
  32.           conn.close();  
  33.           rs.close();  
  34.           stmt.close();  
  35.        }  
  36.    }  
  37. %>  

    在这ds =(DataSource)initCtx.lookup("java:comp/env/jdbc/TestDB");这句代码中的jdbc/TestDB必须和

    <ResourceLink global="jdbc/TestDB" name="jdbc/TestDB" ........ />中的name 属性保持一样.

     "lookup("java:comp/env/..."这都是固定写法.

 

    2.  应该算是局部的连接池的配置吧.(针对工程而言)

       本身我们的工程中META-INF 中,没有context.xml文件,

       例如 :E:\apache-tomcat-5.5.16\webapps\myproj\META-INF\

 

       此时我们可以在META-INF目录下面新建一个context.xml文件.

      里面写下如下的配置,具体的配置参数,按需改变.

 

Xml代码  收藏代码
  1. <? xml   version = "1.0"   encoding = "UTF-8" ?>   
  2. < Context   reloadable = "true"   crossContext = "true" >   
  3. < Resource    
  4. name = "jdbc/TestDB"    
  5. auth = "Container"    
  6. type = "javax.sql.DataSource"   
  7. driverClassName = "com.mysql.jdbc.Driver"    
  8. url = "jdbc:mysql://localhost:3306/test?autoReconnect=true"   
  9. maxActive = "50"    
  10. maxldle = "10"    
  11. maxWait = "5000"   
  12. username = "root"   
  13. password = "admin"    
  14. />   
  15. </ Context >   

 

        这样子,连接池,也就配置好啦,并不需要修改tomcat里面的文件。仅仅在我们的工程中的META-INF目录加入一个context.xml配置文件就好啦.换tomcat版本,更容易.

 

 注:也许你认为配置这边文章很简单,配置数据源连接池也很简单.但是对于初学者来说,可能是困窘他好久的问题.这方面以前我深有体会.大家都是这样过来的.  仅供参考.

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics