到目前为目 JDBC 的连结池只是一个接口 没有真正的实现 JDBC 正在开发中 据报已经支持连结池 但JDBC 用了JNDI技术 连结池的配置可以让一个高手都烦死 目前第三方已经实现的连结池当然是poolman 版对一般用户来说已经足够用了 配置也简单 版虽然增加了一些功能 但配置也是采用JNDI 对RMI和EJB不懂的朋友可能很烦 建议用 的了 如果有兴趣 自己也可以实现连结池 最关键的技术也就是把连结作为参数传给一个BEAN 用完后返回这个参数连结而不是关闭 下面是一个简单的实现:DBConnectionManager java程序清单如下 import java io ; import java sql ; import java util ; import java util Date; / 管理类DBConnectionManager支持对一个或多个由属性文件定义的数据库连接 池的访问 客户程序可以调用getInstance()方法访问本类的唯一实例 / public class DBConnectionManager { static private DBConnectionManager instance; // 唯一实例 static private int clients; private Vector drivers = new Vector(); private PrintWriter log; private Hashtable pools = new Hashtable(); / 返回唯一实例 如果是第一次调用此方法 则创建实例 @return DBConnectionManager 唯一实例 / static synchronized public DBConnectionManager getInstance() { if (instance == null) { instance = new DBConnectionManager(); } clients++; return instance; } / 建构函数私有以防止其它对象创建本类实例 / private DBConnectionManager() { init(); } / 将连接对象返回给由名字指定的连接池 @param name 在属性文件中定义的连接池名字 @param con 连接对象\\r / public void freeConnection(String name Connection con) { DBConnectionPool pool = (DBConnectionPool) pools get(name); if (pool != null) { pool freeConnection(con); } } / 获得一个可用的(空闲的)连接 如果没有可用连接 且已有连接数小于最大连接数 限制 则创建并返回新连接 @param name 在属性文件中定义的连接池名字 @return Connection 可用连接或null / public Connection getConnection(String name) { DBConnectionPool pool = (DBConnectionPool) pools get(name); if (pool != null) { return pool getConnection(); } return null; } / 获得一个可用连接 若没有可用连接 且已有连接数小于最大连接数限制 则创建并返回新连接 否则 在指定的时间内等待其它线程释放连接 @param name 连接池名字 @param time 以毫秒计的等待时间\\r @return Connection 可用连接或null / public Connection getConnection(String name long time) { DBConnectionPool pool = (DBConnectionPool) pools get(name); if (pool != null) { return pool getConnection(time); } return null; } / 关闭所有连接 撤销驱动程序的注册\\r / public synchronized void release() { // 等待直到最后一个客户程序调用 if ( clients != ) { return; } Enumeration allPools = pools elements(); while (allPools hasMoreElements()) { DBConnectionPool pool = (DBConnectionPool) allPools nextElement(); pool release(); } Enumeration allDrivers = drivers elements(); while (allDrivers hasMoreElements()) { Driver driver = (Driver) allDrivers nextElement(); try { DriverManager deregisterDriver(driver); log( 撤销JDBC驱动程序 + driver getClass() getName()+ 的注册\\\ ); } catch (SQLException e) { log(e 无法撤销下列JDBC驱动程序的注册: + driver getClass() getName()); } } } / 根据指定属性创建连接池实例 @param props 连接池属性 / private void createPools(Properties props) { Enumeration propNames = props propertyNames(); while (propNames hasMoreElements()) { String name = (String) propNames nextElement(); if (name endsWith( url )) { String poolName = name substring( name lastIndexOf( )); String url = props getProperty(poolName + url ); if (url == null) { log( 没有为连接池 + poolName + 指定URL ); continue; } String user = props getProperty(poolName + user ); String password = props getProperty(poolName + password ); String maxconn = props getProperty(poolName + maxconn ); int max; try { max = Integer valueOf(maxconn) intValue(); } catch (NumberFormatException e) { log( 错误的最大连接数限制: + maxconn + 连接池: + poolName); max = ; } DBConnectionPool pool = new DBConnectionPool(poolName url user password max); pools put(poolName pool); log( 成功创建连接池 + poolName); } } } / 读取属性完成初始化 / private void init() { InputStream is = getClass() getResourceAsStream( /db properties ); Properties dbProps = new Properties(); try { dbProps load(is); } catch (Exception e) { System err println( 不能读取属性文件 + 请确保db properties在CLASSPATH指定的路径中 ); return; } String logFile = dbProps getProperty( logfile DBConnectionManager log ); try { log = new PrintWriter(new FileWriter(logFile true) true); } catch (IOException e) { System err println( 无法打开日志文件: + logFile); log = new PrintWriter(System err); } loadDrivers(dbProps); createPools(dbProps); } / 装载和注册所有JDBC驱动程序\\r @param props 属性 / private void loadDrivers(Properties props) { String driverClasses = props getProperty( drivers ); StringTokenizer st = new StringTokenizer(driverClasses); while (st hasMoreElements()) { String driverClassName = st nextToken() trim(); try { Driver driver = (Driver) Class forName(driverClassName) newInstance(); DriverManager registerDriver(driver); drivers addElement(driver); log( 成功注册JDBC驱动程序\\\ + driverClassName); } catch (Exception e) { log( 无法注册JDBC驱动程序: + driverClassName + 错误: + e); } } } / 将文本信息写入日志文件 / private void log(String msg) { log println(new Date() + : + msg); } / 将文本信息与异常写入日志文件 / private void log(Throwable e String msg) { log println(new Date() + : + msg); e printStackTrace(log); } / 此内部类定义了一个连接池 它能够根据要求创建新连接 直到预定的最\\r lishixinzhi/Article/program/Oracle/201311/17331
数据库连接是一种有限的昂贵的资源,数据库连接影响到程序的性能指标。
数据库连接池正是针对这个问题提出来的。数据库连接池负责分配、
管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而再不是重新建立一个;
释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数
据库连接而引起的数据库连接遗漏。
这项技术能明显提高对数据库 *** 作的性能。
tomcat连接池的方法
1:连接池所要解决的问题:
应用程序每一次与数据库的连接都会由于网络传输和执行数据库查询而严重降低了程序的执行效率,因此我们需要用到连接池将将我们经常要用到的数据保存在连接池中,这样就减少了网络传输和因查询而给程序执行效率带来的影响。
2:连接池的本质:用一个集合保存查询出来的数据。
3:连接池的实现原理:
我们要使用Connect pool,首先要做的是访问datasource(所有的要访问的数据都放在这里面)。datasource数据源是通过LDAP(light directory access protocal)软件进行管理的(其本质就是将数据源以树状结构进行存储,这样的话,方便查询(树状结构的查询效率是最快的),java通过JNDI(java naming directory interface)访问LDAP里面的数据。
4:在tomcat种配置连接池:
1)打开tomcat目录下的conf/contextcfg:在里面加入如下配置
Xml代码
<Resource driverClassName="oraclejdbcdriverOracleDriver"url="jdbc:oracle:thin:@localhost:1521:orcl" username="scott" password="tiger" maxActive="20" type="javaxsqlDataSource" author="Container" name="ds"></Resource>
<Resource driverClassName="oraclejdbcdriverOracleDriver"url="jdbc:oracle:thin:@localhost:1521:orcl" username="scott" password="tiger" maxActive="20" type="javaxsqlDataSource" author="Container" name="ds"></Resource>
其中:maxActive:代表的是要配置的最大连接数。
type:资源类型
2)通过应用程序执行上述连接:
Java代码
<%@page contentType="text/html" %>
<%@page import="javasql"%>
<%@page import="javaxsql"%>
<%@page import="javaxnaming"%>
<html>
<body>
<% Context ctx=new InitialContext();
DataSource ds=(DataSource)ctxlookup("java:comp/env/ds");//必须要
Connection con=dsgetConnection();
outprintln("<h1>connection succeeful</h1>");
conclose();
%>
</body>
</html>
<%@page contentType="text/html" %>
<%@page import="javasql"%>
<%@page import="javaxsql"%>
<%@page import="javaxnaming"%>
<html>
<body>
<% Context ctx=new InitialContext();
DataSource ds=(DataSource)ctxlookup("java:comp/env/ds");//必须要
Connection con=dsgetConnection();
outprintln("<h1>connection succeeful</h1>");
conclose();
%>
</body>
</html>
connclose():连接池是被覆盖了的,本质上的含义,把连接池借过来的连接还回去。
从零开始学java web 开发书上的例子
以sql server 2005为例,讲解tomcat60上的配置。
下载sqljdbcjar放在tomcat的lib目录,tomcat/conf/contextxml文件,<Context></Context>中加入配置代码。
<Resource name="jdbc/dbplling" author="Container" type="javaxsqlDataSource" driverClassName="commicrosoftsqlserverdriverjdbcsqlserverdriverDriver"url="jdbc:sqlserver//127001:1433;databasename=testdemo" username="sa" password="123" maxActive="100" maxIdle="30"; maxWait="5000"></Resource>
webxml
<xml version="10" encoding="UTF-8">
<web-app version="24" xmlns=">
像打开关闭数据库连接这种和数据库的交互可能是很费时的,尤其是当客户端数量增加的时候,会消耗大量的资源,成本是非常高的。可以在应用服务器启动的时候建立很多个数据库连接并维护在一个池中。连接请求由池中的连接提供。在连接使用完毕以后,把连接归还到池中,以用于满足将来更多的请求。
开始本文之前,我们看一段Go连接数据库的代码:
本文内容我们将解释连接池背后是如何工作的,并 探索 如何配置数据库能改变或优化其性能。
转自:>
以上就是关于Oracle数据库 关于连接池一全部的内容,包括:Oracle数据库 关于连接池一、大数据用什么中间件设置数据库连接池linux(数据库连接池大小设置)、java 因为数据库反复的连接是很耗资源的,所以用连接池比较好等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)