mysql 连接池配置有哪些方式

mysql 连接池配置有哪些方式,第1张

数据库连接池的主要 *** 作如下: (1)建立数据库连接池对象(服务器启动)。 (2)按照事先指定的参数创建初始数量的数据库连接(即:空闲连接数)。 (3)对于一个数据库访问请求,直接从连接池中得到一个连接。如果数据库连接池对象中没有空闲

jdbc是提供给java访问数据库的连接方式,在任何时候都可以创建,而在实际应用中,因为创建连接和销毁连接都会有系统(创建时间、内存等)的损耗,为了减少这种损耗,在系统启动时就创建一定数量的jdbc连接,在需要使用时派发一个连接,使用完以后收回,而不再需要临时创建,那么这些jdbc连接就统称为数据库连接池

我们知道,Weblogic是用于开发、集成、部署和管理大型分布式Web应用、网络应用和数据库应用的Java应用服务器。将Weblogic与Oracle数据库连接池搭配成的平台为Java应用程序的开发提供了便利条件。本文我们主要介绍Weblogic8搭配Oracle数据库连接池的知识,接下来就让我们来一起了解这一过程吧。

1、搭配连接池

首先在浏览器的地址栏输入: >

ps:(以上文字摘抄网上老鸟的,嘿嘿描述太多就懒得写了,我还是总结实现原理在这就树下乘凉了哈哈!!!)

就是在连接池初始化的时候存入一定数量的连接,用的时候通过方法获取,不用的时候归还连接即可

所有的连接池必须实现一个接口 javaxsqlDataSource接口

查看api:(DataSource)

获取连接方法:

Connection getConnection()

我们发现只有连接的方法 没有归还的方法归还连接的方法就是以前的释放资源的方法调用connectionclose();

小结: 终于又总结完了一张,通过本篇掌握jdbc连接池相关的作用及其思想,以及装饰者模式就行。

参考:dbcp c3p0其dbutils总结

到目前为目 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

类似一个银行营业厅,开了几个窗口,然后大厅里还有等待的座位。

人们去银行办理业务,就类似于使用连接池。

你去办理业务就是使用端口,你在大厅里就是等待使用资源。

如有不明白的,请继续追问下,谢谢。

以上就是关于mysql 连接池配置有哪些方式全部的内容,包括:mysql 连接池配置有哪些方式、数据库连接池与JDBC的区别、weblogic 用什么连接池等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9503565.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存