存档

文章标签 ‘tomcat’

[转载]TOMCAT 5设置数据连接池总结

2006年6月10日 没有评论

原文地址

TOMCAT 5设置数据连接池总结

 TOMCAT 5,要设置一个数据连接池,以MYSQL为例子(MS SQL SERVER 2000)也差不多,如何设置呢?查了下网上的资料,很多种说法,因此归纳了下,大概有两类做法是可以的。
我用的是TOMCAT 5.0.28,搭配MYSQL

做法1:
  修改conf目录下的server.xml,在<HOST></HOST>之间加入
<Context path=”/testmysql” docBase=”d:tomcat5webappstestmysql” debug=”0″ crosscontext=”true” reloadable=”true”>
  <Resource name=”jdbc/TestDB” auth=”Container”
            type=”javax.sql.DataSource”/>
  <ResourceParams name=”jdbc/TestDB”>
    <parameter>
      <name>factory</name>
      <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
    </parameter>
    <parameter>
      <name>username</name>
      <value>root</value>
    </parameter>
    <parameter>
      <name>password</name>
      <value>123456</value>
    </parameter>
    <parameter>
      <name>driverClassName</name>
      <value>com.mysql.jdbc.Driver</value>
    </parameter>
    <parameter>
      <name>url</name>
      <value>jdbc:mysql://localhost:3306/testmysql?useUnicode=true&amp;characterEncoding=gb2312</value>
    </parameter>
    <parameter>
      <name>maxActive</name>
      <value>20</value>
    </parameter>
    <parameter>
      <name>maxIdle</name>
      <value>5</value>
    </parameter>
    <parameter>
      <name>maxWait</name>
      <value>10000</value>
    </parameter>
  </ResourceParams>
</Context>
  其中,testmysql是为了测试而放在weapps下的一个目录。
Tomcat连接池中,部分参数说明如下:

  maxActive=”100″  <!–最大活跃连接数,这里取值为100,表示同时最多有100个数据库连接。设为0表示无限制。–>

  maxIdle=”30″ <!–最大的空闲连接数,这里取值为30,表示即使没有数据库连接时依然可以保持30个空闲的连接,而不被清除,随时处于待命状态。设为0表示无限制。–>

  maxWait=”10000″ <!–最大建立连接等待时间。如果超过此时间将接到异常。这里设置为10000,表示10秒后超时。设为-1表示无限制,直到超时为止。–>

jdbc:mysql://localhost/jcc <!–数据库连接字符串,同jdbc:mysql://localhost:3306/jcc?autoReconnect=true–>

PS:如果最大数据库活跃连接数过大,可想而知,内存占用量是非常惊人的!如果空闲连接数过大,则资源利用率低,连接池长期未释放,可导致连接池结点异常。所以选好maxActive和maxIdle是连接池性能的关键因素,当然这取决于服务器环境。

     然后再在web.xml下如下配置
<resource-ref>
  <res-ref-name>TestDB</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
  <res-auth>Container</res-auth>
 </resource-ref>
注意,这里的TestDB(名称)要和你在server.xml里设置的<ResourceParams name=”jdbc/TestDB”>
名称一样。
  设置的测试程序如下:
<%
try{
 Context initContext = new InitialContext();
 Context envContext  = (Context)initContext.lookup(“java:comp/env”);
 DataSource ds = (DataSource)envContext.lookup(“jdbc/TestDB”);
 Connection conn = ds.getConnection();
    Statement stmt = conn.createStatement();
     ResultSet rs = stmt.executeQuery(“SELECT * FROM testmysql”);
   out.println(“User-list”+”<br>”);
     while(rs.next())
     { 
       out.print(rs.getInt(1)+” “);  
     out.print(rs.getString(2)+”<br>”);
      }
        rs.close();
      stmt.close(); 
      conn.close();}
 catch(Exception e)
 {
  out.print(e);
  }
%>

 而在TOMCAT 5以上,也可以用另外的方法来配置
Tomcat5和Tomcat4在配置新的Web应用上有一些区别,在Tomcat4中如果要配置一个新的Web应用需要修改server.xml文件,在Tomcat5中只需要重新写一个配置文件就可以了,只有将这个文件放在相应的目录中,
   比如,我们可以在D:tomcat5confCatalinalocalhost目录下,新建立一个XML文件如下
  <?xml version=”1.0″ encoding=”UTF-8″?>
<Context path=”/tesymysql” docBase=”d:tomcat5webappstestmysql”
        debug=”5″ reloadable=”true” crossContext=”true”>

  <Resource name=”TestDB”
               auth=”Container”
               type=”javax.sql.DataSource”/>
  <ResourceParams name=”TestDB”>
    <parameter>
      <name>factory</name>
      <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
    </parameter>
    <!– Maximum number of dB connections in pool. Make sure you
         configure your mysqld max_connections large enough to handle
         all of your db connections. Set to 0 for no limit.
         –>
    <parameter>
      <name>maxActive</name>
      <value>100</value>
    </parameter>
    <!– Maximum number of idle dB connections to retain in pool.
         Set to 0 for no limit.
         –>
    <parameter>
      <name>maxIdle</name>
      <value>30</value>
    </parameter>
    <!– Maximum time to wait for a dB connection to become available
         in ms, in this example 10 seconds. An Exception is thrown if
         this timeout is exceeded.  Set to -1 to wait indefinitely.
         –>
    <parameter>
      <name>maxWait</name>
      <value>10000</value>
    </parameter>
    <!– MySQL dB username and password for dB connections  –>
    <parameter>
     <name>username</name>
     <value>root</value>
    </parameter>
    <parameter>
     <name>password</name>
     <value>123456</value>
    </parameter>
    <!– Class name for the old mm.mysql JDBC driver – uncomment this entry and comment next
         if you want to use this driver – we recommend using Connector/J though
    <parameter>
       <name>driverClassName</name>
       <value>org.gjt.mm.mysql.Driver</value>
    </parameter>
     –>
   
    <!– Class name for the official MySQL Connector/J driver –>
    <parameter>
       <name>driverClassName</name>
       <value>com.mysql.jdbc.Driver</value>
    </parameter>
   
    <!– The JDBC connection url for connecting to your MySQL dB.
         The autoReconnect=true argument to the url makes sure that the
         mm.mysql JDBC Driver will automatically reconnect if mysqld closed the
         connection.  mysqld by default closes idle connections after 8 hours.
         –>
    <parameter>
      <name>url</name>
      <value>jdbc:mysql://localhost:3306/testmysql?autoReconnect=true</value>
    </parameter>
  </ResourceParams>
</Context>
  而WEB.XML文件的修改同上,这样也可以的。
而在TOMCAT 5。5中,甚至可以这样修改,不用改其他
   在<%TOMCAT_HOME%>confserver.xml的<Host>…</Host>之间加入以下代码:

<Context path=”" docBase=”D:/tomcat5webappstestmysql”
        debug=”5″ reloadable=”true” crossContext=”true”>
  <Resource name=”jdbc/TestDB” auth=”Container” type=”javax.sql.DataSource”
               maxActive=”100″ maxIdle=”30″ maxWait=”10000″
               username=”jcc” password=”jsp.com.cn” driverClassName=”com.mysql.jdbc.Driver”
               url=”jdbc:mysql://localhost:3306/testmysql”/>
</Context>

2 注意的问题
  一开始,我下载的mysql的驱动包,解压出来,mysql-connector-java-3.1.10-bin.jar放在tomcatcommonlib目录下就可以了,没必要在自己的应用目录下,再建lib目录后再放该JAR文件。注意,mysql-connector-java-3.1.10-bin-g.jar文件没必要放在commonlib目录下的,我放了反而会出错,不知道为什么。
   SQL SERVER 2000的写法差不多,不同在于:
  <!– Class name for mssqlserver JDBC driver –>
   <parameter>
      <name>driverClassName</name>
      <value>com.microsoft.jdbc.sqlserver.SQLServerDriver</value>
   </parameter>

   <!– The JDBC connection url for connecting to your mssqlserver dB.–>
   <parameter>
     <name>url</name>
     <value>jdbc:microsoft:sqlserver://localhost:1433;databasename=Northwind</value>
   </parameter>
 </ResourceParams>

分类: 只谈技术 标签:

[转载]Tomcat+SQL Server2000连接池配置

2006年6月10日 没有评论

终于解决了困扰多天的连接池的问题,写下这编文章与大家一起分享。我是在tomcat5.5.9下配置的,tomcat5.5.X和以前的版本有一些差别,所以配置上也有差别。我就说一下在tomcat5.5.9配置的基本步骤:(确定你以安装好tomcat5.5.9、sql2000)
  
  1、把数据库JDBC驱动拷贝到%TOMCAT_HOME%/common/lib和%TOMCAT_HOME%/webapps/yourweb/WEB-INF/lib下(我的web文件夹名字叫quickstart)
  

  这一步大家都知道,不然tomcat无法与数据库连接。
  
  2、修改%TOMCAT_HOME%/conf/server.xml文件,在 <GlobalNamingResources></GlobalNamingResources>之间
  

  添加以下内容:
  <Resource
  name=”jdbc/quickstart”
  type=”javax.sql.DataSource”
  password=”123456″
  driverClassName=”com.microsoft.jdbc.sqlserver.SQLServerDriver”
  maxIdle=”2″
  maxWait=”5000″
  username=”sa”
  url=”jdbc:microsoft:sqlserver://localhost;DatabaseName=quickstart”   maxActive=”4″/>
  
  以上内容根据大家的具体情况进行相应修改,比如:把name=”jdbc/quickstart”中的quickstart改成和你web文件夹名称一样,把password=”123456″中的“123456”改成你数据库的密码。
  
  3、在%TOMCAT_HOME%/conf/Catalina/localhost下新建一个与你web文件夹同名的xml文件(我的是quickstart.xml)
  

  这一步非常重要,如果没有这步就会出错,会出现org.apache.tomcat.dbcp.dbcp.SQLNestedException: Cannot create JDBC driver of class ” for connect URL ‘null’
  
  这样的错误,在文件中加入第2步的内容,如下:
  
  <?xml version=”1.0″ encoding=”UTF-8″?><Context>
  <Resource
  name=”jdbc/quickstart”
  type=”javax.sql.DataSource”
  password=”123456″
  driverClassName=”com.microsoft.jdbc.sqlserver.SQLServerDriver”
  maxIdle=”2″
  maxWait=”5000″
  username=”sa”
  url=”jdbc:microsoft:sqlserver://localhost;DatabaseName=quickstart”
  maxActive=”4″/> </Context>
  
  根据个人具体情况进行相应修改。
  
  4、修改%TOMCAT_HOME%/webapps/yourweb/WEB-INF下的web.xml文件,在<web-app></web-app>之间添加以下内容
  

  <resource-ref>
  <description>sqlserverDB Connection</description>
  <res-ref-name>jdbc/quickstart</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
  <res-auth>Container</res-auth>
  </resource-ref>
  
  把<res-ref-name>jdbc/quickstart</res-ref-name>中的quickstart改成你的web文件夹名称。
  
  5、测试,在quickstart下新建一个index.jsp文件
  

  <%@ page contentType=”text/html; charset=gb2312″ %><%@ page import=”javax.naming.*” %><%@ page import=”javax.sql.*” %><%@ page import=”java.sql.*” %><html><head><title>JDBC Test</title></head><body><%
  Connection conn=null;
  Statement stmt=null;
  ResultSet rs=null;
  ResultSetMetaData md=null;
  try
  {
  Context initCtx=new InitialContext();
  DataSource ds=(DataSource)initCtx.lookup(“java:comp/env/jdbc/quickstart”);
  if(ds!=null)
  {
  out.println(“已经获得DataSource”);
  out.println(ds.toString());
  conn=ds.getConnection();
  stmt=conn.createStatement();
  out.println(“aa”);
  rs=stmt.executeQuery(“select * from cat”);
  md=rs.getMetaData();
  out.println(“<table border=1>”);
  out.println(“<tr>”);
  for(int i=0;i<md.getColumnCount();i++)
  {
  out.println(“<td>”+md.getColumnName(i+1)+”</td>”);
  }
  while(rs.next())
  {
  out.println(“<tr>”);
  out.println(“<td>”+rs.getString(1)+”</td>”);
  out.println(“<td>”+rs.getString(2)+”</td>”);
  out.println(“<td>”+rs.getString(3)+”</td>”);
  out.println(“<td>”+rs.getString(4)+”</td>”);
  out.println(“</tr>”);
  }
  out.println(“</table>”);
  conn.close();
  }
  }
  catch(Exception e)
  {
  out.println(e.toString());
  System.out.println(e.toString());
  }%></body></html>
  
  运行tomcat服务器,在浏览器中输入http://localhost:8080/quickstart/index.jsp看看成功了没有。

分类: 只谈技术 标签: ,

[转载]Tomcat下配置MySQL数据库连接池

2006年6月10日 没有评论

1.在$CATALINA_HOME/conf/server.xml中添加配置信息,声明连接池的具体信息,添加内容如下:
  
  <!–声明连接池–>
  
  <Resource name=”jdbc/mysql” auth=”Container” type=”javax.sql.DataSource”/>
  
  <!– 对连接池的参数进行设置 –>
  
  <ResourceParams name=”jdbc/mysql”>
  
  <parameter>
  
  <name>factory</name>
  
  <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
  
  </parameter>
  
  <parameter>
  
  <name>maxWait</name>
  
  <value>5000</value>
  
  </parameter>
  
  <parameter>
  
  <name>maxActive</name>
  
  <value>20</value>
  
  </parameter>
  
  <parameter>
  
  <name>username</name>
  
  <value>shopadm</value>
  
  </parameter>
  
  <parameter>
  
  <name>password</name>
  
  <value>123</value>
  
  </parameter>
  
  <parameter>
  
  <name>url</name>
  
  <value>jdbc:mysql://localhost/shopdb?useUnicode=true&charact-erEncoding=gb2312</value>
  
  </parameter>
  
  <parameter>
  
  <name>driverClassName</name>
  
  <value>com.mysql.jdbc.Driver</value>
  
  </parameter>
  
  <parameter>
  
  <name>maxIdle</name>
  
  <value>10</value>
  
  </parameter>
  
  </ResourceParams>
  
  2. 在$CATALINA_HOME/conf/web.xml的</web-app>前添加如下信息:
  
  <resource-ref>
  
  <description>DB Connection</description>
  
  <res-ref-name>jdbc/mysql</res-ref-name>
  
  <res-type>javax.sql.DataSource</res-type>
  
  <res-auth>Container</res-auth>
  
  </resource-ref>
  
  其中<res-ref-name>中的参数名必须和server.xml中声明的连接名一样。
  
  3. 在$CATALINA_HOME/conf/catalina/localhost目录下找到需要进行数据库连接的当前程序的配置信息,比如这里是shopping.xml,在这个文件中添加如下信息:
  
  <Context …>
  
  …
  
  <ResourceLink name=”jdbc/mysql” global=”jdbc/mysql” type=”javax.sql.DataSource”/>
  
  …
  
  </Context>
  
  大功告成!
  
  在此基础上,参考Tomcat官方网站的用户手册,摸索出另外一种配置连接池的方法,这个方法不需要对server.xml进行修改,只要对需要使用到连接池的程序的配置文档进行修改就可以了。方法如下:
  
  1.$CATALINA_HOME/conf/catalina/localhost目录下找到需要数据库连接池的程序的配置文档,此处是shopping.xml。在<Context> </Context>之间添加如下信息,声明一个数据库连接池:
  
  <Resource name=”jdbc/mysql” auth=”Container” type=”javax.sql.DataSource”/>
  
  <ResourceParams name=”jdbc/mysql”>
  
  <parameter>
  
  <name>factory</name>
  
  <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
  
  </parameter>
  
  <parameter>
  
  <name>maxWait</name>
  
  <value>5000</value>
  
  </parameter>
  
  <parameter>
  
  <name>maxActive</name>
  
  <value>20</value>
  
  </parameter>
  
  <parameter>
  
  <name>password</name>
  
  <value>123</value>
  
  </parameter>
  
  <parameter>
  
  <name>url</name>
  
  <value>jdbc:mysql://localhost/shopdb?useUnicode=true&characterEncoding=gb2312</value>
  
  </parameter>
  
  <parameter>
  
  <name>driverClassName</name>
  
  <value>com.mysql.jdbc.Driver</value>
  
  </parameter>
  
  <parameter>
  
  <name>maxIdle</name>
  
  <value>10</value>
  
  </parameter>
  
  <parameter>
  
  <name>username</name>
  
  <value>shopadm</value>
  
  </parameter>
  
  </ResourceParams>
  
  这里的参数和上一种方法中添加到server.xml里的信息几乎是完全一样的。
  
  2.在对应程序的WEB-INF下建立一个web.xml文档,添加如下信息:
  
  <?xml version=”1.0″ encoding=”ISO-8859-1″?>
  
  <web-app xmlns=”http://java.sun.com/xml/ns/j2ee”
  
  xmlns:xsi=”http://www.w3.org/2001/XMLSchema-instance”
  
  xsi:schemaLocation=”http://java.sun.com/xml/ns/j2ee
  
  http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd”
  
  version=”2.4″>
  
  <resource-ref>
  
  <description>DB Connection</description>
  
  <res-ref-name>jdbc/mysql</res-ref-name>
  
  <res-type>javax.sql.DataSource</res-type>
  
  <res-auth>Container</res-auth>
  
  </resource-ref>
  
  </web-app>

分类: 只谈技术 标签: ,

[转载]利用mod_ajp整合apache-2.2.0和tomcat-5.5.12

2006年1月16日 没有评论

今天偶然在网上发现apache-2.2.0增加了一个proxy-ajp模块,看了看它可以完全代替原来的mod-jk把tomcat和apache结合到一起。于是我就下载下来试了一下真的很方便比原来的方法简单多了。下面就说明一下我的安装步骤。tomcat和jdk的安装网上太多的教程我在这里就不再介绍了。大家可以去查看其他的教程。

首先从http://www.apache.org的网站上下载apache-2.2.0的源代码。apache-2.2.0的版本做了些改动大家需要注意一下。首先apr和apr-util需要单独的安装,还有配置文件由原来的一个变为现在的多个不过这样也好,可以清楚的知道那部分配置在那个配置文件里方便修改。安装步骤如下:

解压apache的源代码
# tar xvjf httpd-2.2.0.tar.bz2
# cd httpd-2.2.0

安装apr
# cd srclib/apr
# ./configure –prefix=/server/soft/apr
# make
# make install

安装apr-util
# cd ../apr-util/
# ./configure –prefix=/server/soft/apr-util
    –with-apr=/server/soft/apr
# make
# make install
# cd ../../

安装apache
# ./configure –prefix=/server/soft/apache
    –enable-so
    –enable-rewrite=share
    –enable-proxy=share
    –enable-proxy-ajp=share
    –enable-dav=share
    –with-apr=/server/soft/apr
    –with-apr-util=/server/soft/apr-util/
# make
# make install

# /server/soft/apache/bin/httpd -l //看看是否有proxy-ajp这个模块
如果有这个模块证明proxy-ajp模块安装成功,可以进行与tomcat的结合了。

# vi /server/soft/apache/conf/httpd.conf
把”#Include conf/extra/httpd-vhosts.conf” 前面的”#”去掉然后编辑
/server/soft/apache/conf/extra/httpd-vhosts.conf

编辑为如下的代码
<VirtualHost *:80>
    ServerAdmin admin@easyea.com
    ProxyPass / ajp://localhost:8009/
    ProxyPassReverse / ajp://localhost:8009/
    ServerName localhost
    ServerAlias www.easyea.com
    ErrorLog logs/easyea.com-error_log
    CustomLog logs/easyea.com-access_log common
</VirtualHost>

然后先启动tomcat,再启动apache
# /server/soft/apache/bin/apachctl start
打开浏览器看看是否看到了tomcat的欢迎页面,如果是说明apache和tomcat的结合成功

分类: 只谈技术 标签: ,