我这有一个Tomcat+Oracle连接池的例子,放上来和大家分享一下。 Tomcat 5.5.+Oracle 9.0.1.1. 连接池配置  
Author: Kenneth.Leaf@GalaxySoft Date: // Time: :: PM 环境: 
Windows  Advanced Server Tomcat 5.5. 
Oracle9i Enterprise Edition Release 9.0.1.1. JDK 1.5 
Eclipse 3.1. 
MyEclipse 4.1. GA  
项目名称:TestingProject  
配置步骤:  
. 因Tomcat与Oracle在8080端口处会产生冲突,因此在安装Tomcat 5.5.17时,设置端口为10240.  
. 将Oracle的驱动包classes12.jar复制到%CATALINA_HOME%\\common\\lib中;  
. 在jakarta-tomcat-5.0..exe以前是有默认的admin模块,在jakarta-tomcat-5.5..后则没有安装默认的admin模块,这时http://127.0.0.1:10240/admin打开时则会出现 
Tomcat\'s administration web application is no longer installed by default. Download and install the "admin" 
package to use it.  
因此我们现在需要到http://www.apache.org/dist/tomcat/tomcat-5/v5.5.17/bin/下载"admin"package 包: 
jakarta-tomcat-5.5..zip(Tomcat压缩版,已安装的无须再下载) 
jakarta-tomcat-5.5.-compat.zip(如用JDK1.,需要compat.zip; 用JDK1.5则可免。) jakarta-tomcat-5.5.-admin.zip  
. 从http://127.0.0.1:10240/admin进入Tomcat管理界面增加Data Sources: JNDI Name: jdbc/music  
Data Source URL: jdbc:oracle:thin:@127.0.0.1::GALAXY JDBC Driver Class: oracle.jdbc.driver.OracleDriver User Name: scott Password: tiger 
Max. Active Connections:  Max. Idle Connections:  
Max. Wait for Connection:  Validation Query: 可填可不填  2013年ACCA考试全攻略每日一练历年真题模拟测试章节知识点 输入完毕,点击“Save”按钮保存。点击页面右上侧“Commit Changes”按钮,保存刚才的设置。(这一步很重要哦!) 
也可以不使用图形界面直接写入Data Sources,去%CATALINA_HOME%\\conf中修改server.xml,<GlobalNamingResources>元素之间添加如下代码:     <Resource 
      name="jdbc/music" 
      type="javax.sql.DataSource"       password="tiger" 
      driverClassName="oracle.jdbc.driver.OracleDriver"       maxIdle=""       maxWait=""       username="scott" 
      url="jdbc:oracle:thin:@127.0.0.1:1521:GALAXY"       maxActive=""/>  
. 在%CATALINA_HOME%\\webapps\\TestingProject\\META-INF下增加context.xml(可以是任意名和xml文件),容如下: 
<?xml version="1.0" encoding="UTF-8"?> <Context 
path="/TestingProject" docBase="D:\\Program Files\\Apache Software Foundation\\Tomcat 5.\\webapps\\TestingProject" 
debug="" reloadable="true" crossContext="true">     <Resource 
      name="jdbc/music" 
      type="javax.sql.DataSource"       password="tiger" 
      driverClassName="oracle.jdbc.driver.OracleDriver"       maxIdle=""       maxWait=""       username="scott" 
      url="jdbc:oracle:thin:@127.0.0.1:1521:GALAXY"       maxActive=""/>     <ResourceLink 
    global="jdbc/music"     name="jdbc/music" 
    type="javax.sql.DataSource"/> </Context> 
. 编写一个Jsp来测试,测试代码如下: 
<%@page contentType="text/html; charset=GBK"%> 
<%@page import="javax.naming.*, java.sql.*, javax.sql.*"%> <html> <head> 
<title>TestDBConn22222222...</title> </head>  <body bgcolor="#ffffc0"> <% 
  //String oracleDriverName = "oracle.jdbc.driver.OracleDriver"; 
  //String oracleUrlToConnect = "jdbc:oracle:thin:@127.0.0.1:1521:GALAXY";   //String user = "scott";  //String pwd = "tiger"; 
  String sql = "select * from emp";   try { 
          Context initContext = new InitialContext(); 
          // Context envCtx = (Context) initCtx.lookup("java:comp/env");            // ds = (DataSource)envCtx.lookup("JDBC/Server2000"); 
          DataSource ds =(DataSource)initContext.lookup("java:comp/env/jdbc/music");           Connection conn = ds.getConnection();            Statement stmt = conn.createStatement();           ResultSet rs = stmt.executeQuery(sql);           while (rs.next()) { 
                  out.print(rs.getString()); 
                  out.print("&nbsp;&nbsp;&nbsp;");                   out.print(rs.getString()); 
                  out.print("&nbsp;&nbsp;&nbsp;");                  out.print(rs.getString());                  out.print("<br>");           } 
          rs.close();           stmt.close();           conn.close(); } catch (Exception e) {           e.printStackTrace();   } %> 
</body> </html> 
. 配置过程中可能出现错误,原因如下: 错误1: 
Cannot load JDBC driver class \' oracle.jdbc.driver.OracleDriver \'  
或java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 是没有将sql jdbc driver包放在common\\lib\\目录下。 错误2: 
Cannot create PoolableConnectionFactory ([Microsoft][SQLServer  Driver for JDBC]Error establishing socket.) 
在Oracle连接下不会出现此错误,但当你将本实例应用于SQLServer 2000时会出现此错误, 这是SQL数据库补丁包的问题,如果访问的数据库是SP3,任何问题没有。不是SP3就会出现上面的错误。 错误3:  Name jdbc/music is not bound in this Context 
在context.xml中加入 <ResourceLink 
    global="jdbc/music"     name="jdbc/music" 
type="javax.sql.DataSource"/>  
. 附: 
 连接池运作原理: 
  在实际应用开发中,特别是在WEB应用系统中,如果JSP、Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,如果频繁发生这种数据库操作,系统的性能必然会急剧下降,甚至会导致系统崩溃。数据库连接池技术是解决这个问题最常用的方法,在许多应用程序服务器(例如:Weblogic, WebSphere,JBoss)中,基本都提供了这项技术,无需自己编程,但是,深入了解这项技术是非常必要的。 
  数据库连接池技术的思想非常简单,将数据库连接作为对象存储在一个Vector对象中,一旦数据库连接建立后,不同的数据库访问请求就可以共享这些连接,这样,通过复用这些已经建立的数据库连接,可以克服上述缺点,极大地节省系统资源和时间。   数据库连接池的主要操作如下: 
    ()建立数据库连接池对象(服务器启动)。 
 ()按照事先指定的参数创建初始数量的数据库连接(即:空闲连接数)。 
 ()对于一个数据库访问请求,直接从连接池中得到一个连接。如果数据库连接池对象中没有空闲的连接,且连接数没有达到最大(即:最大活跃连接数),创建一个新的数据库连接。 
 ()存取数据库。 
 ()关闭数据库,释放所有数据库连接(此时的关闭数据库连接,并非真正关闭,而是将其放入空闲队列中。如实际空闲连接数大于初始空闲连接数则释放连接)。 
 ()释放数据库连接池对象(服务器停止、维护期间,释放数据库连接池对象,并释放所有连接)。 

Tomcat+Oracle配置连接池的例子的更多相关文章

  1. Tomcat上配置连接池{ connect error=Name [jdbc/OracleDB] is not bound in this Context. Unable to find [jdbc]}

    . 在学习期间,从未实践过在tomcat上配置连接池,今天终于实现一次,在tomcat玩了一把,不知道你是否现在有和我一样的困境.废话少说直接上代码   java  public static Con ...

  2. 在Tomcat中配置连接池和数据源

    1.DataSource接口介绍 (1)DataSource 概述 JDBC1.0原来是用DriverManager类来产生一个对数据源的连接.JDBC2.0用一种替代的方法,使用DataSource ...

  3. 在tomcat中配置连接池

    在tomcat的conf/Catalina/localhost目录下配置项目路径,tomcat启动是会直接根据配置去加载项目. 虽然配置就一句话,但经常忘,今天记下来. 如果你的项目成名是:mypro ...

  4. Tomcat配置连接池

    Tomcat配置DBCP连接池 配置tomcat服务器的时候,使用到jndi;通过Context配置文件实现配置池对象,通过new initialConext()对象的lookup()获取到数据池对象 ...

  5. c3p0、dbcp、tomcat jdbc pool 连接池配置简介及常用数据库的driverClass和驱动包

    [-] DBCP连接池配置 dbcp jar包 c3p0连接池配置 c3p0 jar包 jdbc-pool连接池配置 jdbc-pool jar包 常用数据库的driverClass和jdbcUrl ...

  6. 配置tomcat全局c3p0连接池

    由于项目中多个应用访问同一个数据库,并部署在同一个tomcat下面,所以没必要每个应用都配置连接池信息,这样可能导致数据库的资源分布不均,所以这种情况完全可以配置一个tomcat的全局连接池,所涉及应 ...

  7. Tomcat 配置连接池

    1. Tomcat 配置 JNDI 资源 JNDI(Java Naming and Directory Interface), Java 命名和目录接口; JNDI 作用: 在服务器上配置资源, 然后 ...

  8. DBCP,C3P0与Tomcat jdbc pool 连接池的比较

    hibernate开发组推荐使用c3p0; spring开发组推荐使用dbcp(dbcp连接池有weblogic连接池同样的问题,就是强行关闭连接或数据库重启后,无法reconnect,告诉连接被重置 ...

  9. 转!数据库连接池概念、种类、配置(DBCP\C3P0\JndI与Tomact配置连接池)

    数据库连接池概念.种类.配置(DBCP\C3P0\JndI与Tomact配置连接池) 一.DBCP 连接:DBCP 连接池是 Apache 软件基金组织下的一个开源连接池实现. 需要的 java 包c ...

随机推荐

  1. Unity Editor Console Pro 扩展点击定位到外部工程

    链接 http://blog.csdn.net/akof1314/article/details/53232981 http://forum.china.unity3d.com/thread-2689 ...

  2. 我的博客已经迁移到csdn

    博客已经迁移csdnhttp://blog.csdn.net/u013372900 博客园我很喜欢是源于他的可扩展性,可以自己去改,但遗憾的是博客园的速度似乎不是很给力.IT能有今天的 发展是源于无数 ...

  3. npm是什么NPM的全称是Node Package Manager

    npm是什么NPM的全称是Node Package Manager

  4. markdown语法简单总结

    最常用的十个MarkDown语法总结: 标题:只要在这段文字前加 # 号即可 # 一级标题 最大 ## 二级标题 ### 三级标题 无序列表:在文字前加上 - 或 * 有序列表:在文字前加1. 2.  ...

  5. [转]谷歌Chrome浏览器开发者工具教程—基础功能篇

    来源:http://www.xiazaiba.com/jiaocheng/5557.html Chrome(F12开发者工具)是非常实用的开发辅助工具,对于前端开发者简直就是神器,但苦于开发者工具是英 ...

  6. 转载:.NET Memory Leak: XmlSerializing your way to a Memory Leak

    原文地址:http://blogs.msdn.com/b/tess/archive/2006/02/15/532804.aspx I hate to give away the resolution ...

  7. 重构指南 - 引入参数对象(Introduce Parameter Object)

    当一个方法的参数超过3个以上,就可以考虑将参数封装成一个对象.将参数封装成对象后提高了代码的可读性,并且该参数对象也可以供多个方法调用,以后如果增加删除参数,方法本身不需要修改,只需要修改参数对象就可 ...

  8. Facebook 爬虫

    title: Facebook 爬虫 tags: [python3, facebook, scrapy, splash, 爬虫] date: 2018-06-02 09:42:06 categorie ...

  9. 在 CentOS 上安装 node.js

    进入到 /usr/local/ 目录中: cd /usr/local/ 创建 nodejs 文件夹: mkdir -p nodejs 进入到 nodejs 目录中: cd nodejs 下载 node ...

  10. Java入门到精通——调错篇之Spring2.5使用AOP时报错only available on JDK 1.5 and higher

    一.问题描述及原因. 在Spring2.5Aop例子中的时候会出现一个错误only available on JDK 1.5 and higher,大概意思就是需要JDK1.5甚至更高版本.但是我用的 ...