国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

Oracle數據庫 關于連接池一

2024-08-29 13:42:32
字體:
來源:轉載
供稿:網友
  到目前為目,JDBC2的連結池只是一個接口,沒有真正的實現,JDBC3正在開發中,據報已經支持連結池,但JDBC3用了JNDI技術,連結池的配置可以讓一個高手都煩死.
  
  目前第三方已經實現的連結池當然是poolman,1.0版對一般用戶來說已經足夠用了.配置也簡單,2.0版雖然增加了一些功能,但配置也是采用JNDI,對RMI和EJB不懂的朋友可能很煩.建議用1.0的了.
  
  假如有愛好,自己也可以實現連結池,最要害的技術也就是把連結作為參數傳給一個BEAN,用完后返回這個參數連結而不是關閉.
  
  下面是一個簡單的實現:
  
  DBConnectionManager.java程序清單如下:
  
  001 import java.io.*;
  002 import java.sql.*;
  003 import java.util.*;
  004 import java.util.Date;
  005
  006 /**
  007 * 治理類DBConnectionManager支持對一個或多個由屬性文件定義的數據庫連接
  008 * 池的訪問.客戶程序可以調用getInstance()方法訪問本類的唯一實例.
  009 */
  010 public class DBConnectionManager {
  011 static PRivate DBConnectionManager instance; // 唯一實例
  012 static private int clients;
  013
  014 private Vector drivers = new Vector();
  015 private PrintWriter log;
  016 private Hashtable pools = new Hashtable();
  017
  018 /**
  019 * 返回唯一實例.假如是第一次調用此方法,則創建實例
  020 *
  021 * @return DBConnectionManager 唯一實例
  022 */
  023 static synchronized public DBConnectionManager getInstance() {
  024 if (instance == null) {
  025 instance = new DBConnectionManager();
  026 }
  027 clients++;
  028 return instance;
  029 }
  030
  031 /**
  032 * 建構函數私有以防止其它對象創建本類實例
  033 */
  034 private DBConnectionManager() {
  035 init();
  036 }
  037
  038 /**
  039 * 將連接對象返回給由名字指定的連接池
  040 *
  041 * @param name 在屬性文件中定義的連接池名字
  042 * @param con 連接對象//r
  
  043 */
  044 public void freeConnection(String name, Connection con) {
  045 DBConnectionPool pool = (DBConnectionPool) pools.get(name);
  046 if (pool != null) {
  047 pool.freeConnection(con);
  048 }
  049 }
  050
  051 /**
  052 * 獲得一個可用的(空閑的)連接.假如沒有可用連接,且已有連接數小于最大連接數
  053 * 限制,則創建并返回新連接
  054 *
  055 * @param name 在屬性文件中定義的連接池名字
  056 * @return Connection 可用連接或null
  057 */
  058 public Connection getConnection(String name) {
  059 DBConnectionPool pool = (DBConnectionPool) pools.get(name);
  060 if (pool != null) {
  061 return pool.getConnection();
  062 }
  063 return null;
  064 }
  065
  066 /**
  067 * 獲得一個可用連接.若沒有可用連接,且已有連接數小于最大連接數限制,
  068 * 則創建并返回新連接.否則,在指定的時間內等待其它線程釋放連接.
  069 *
  070 * @param name 連接池名字
  071 * @param time 以毫秒計的等待時間//r
  
  072 * @return Connection 可用連接或null
  073 */
  074 public Connection getConnection(String name, long time) {
  075 DBConnectionPool pool = (DBConnectionPool) pools.get(name);
  076 if (pool != null) {
  077 return pool.getConnection(time);
  078 }
  079 return null;
  080 }
  081
  082 /**
  083 * 關閉所有連接,撤銷驅動程序的注冊//r
  
  084 */
  085 public synchronized void release() {
  086 // 等待直到最后一個客戶程序調用
  087 if (--clients !
= 0) {
  088 return;
  089 }
  090
  091 Enumeration allPools = pools.elements();
  092 while (allPools.hasMoreElements()) {
  093 DBConnectionPool pool = (DBConnectionPool) allPools.nextElement();
  094 pool.release();
  095 }
  096 Enumeration allDrivers = drivers.elements();
  097 while (allDrivers.hasMoreElements()) {
  098 Driver driver = (Driver) allDrivers.nextElement();
  099 try {
  100 DriverManager.deregisterDriver(driver);
  101 log("撤銷JDBC驅動程序 " + driver.getClass().getName()+"的注冊///");
  102 }
  103 catch (SQLException e) {
  104 log(e, "無法撤銷下列JDBC驅動程序的注冊: " + driver.getClass().getName());
  105 }
  106 }
  107 }
  108
  109 /**
  110 * 根據指定屬性創建連接池實例.
  111 *
  112 * @param props 連接池屬性
  113 */
  114 private void createPools(Properties props) {
  115 Enumeration propNames = props.propertyNames();
  116 while (propNames.hasMoreElements()) {
  117 String name = (String) propNames.nextElement();
  118 if (name.endsWith(".url")) {
  119 String poolName = name.substring(0, name.lastIndexOf("."));
  120 String url = props.getProperty(poolName + ".url");
  121 if (url == null) {
  122 log("沒有為連接池" + poolName + "指定URL");
  123 continue;
  124 }
  125 String user = props.getProperty(poolName + ".user");
  126 String passWord = props.getProperty(poolName + ".password");
  127 String maxconn = props.getProperty(poolName + ".maxconn", "0");
  128 int max;
  129 try {
  130 max = Integer.valueOf(maxconn).intValue();
  131 }
  132 catch (NumberFormatException e) {
  133 log("錯誤的最大連接數限制: " + maxconn + " .連接池: " + poolName);
  134 max = 0;
  135 }
  136 DBConnectionPool pool =
  137 new DBConnectionPool(poolName, url, user, password, max);
  138 pools.put(poolName, pool);
  139 log("成功創建連接池" + poolName);
  140 }
  141 }
  142 }
  143
  144 /**
  145 * 讀取屬性完成初始化
  146 */
  147 private void init() {
  148 InputStream is = getClass().getResourceAsStream("/db.properties");
  149 Properties dbProps = new Properties();
  150 try {
  151 dbProps.load(is);
  152 }
  153 catch (Exception e) {
  154 System.err.println("不能讀取屬性文件. " +
  155 "請確保db.properties在CLASSPATH指定的路徑中");
  156 return;
  157 }
  158 String logFile = dbProps.getProperty("logfile", "DBConnectionManager.log");
  159 try {
  160 log = new PrintWriter(new FileWriter(logFile, true), true);
  161 }
  162 catch (IOException e) {
  163 System.err.println("無法打開日志文件: " + logFile);
  164 log = new PrintWriter(System.err);
  165 }
  166 loadDrivers(dbProps);

  167 createPools(dbProps);
  168 }
  169
  170 /**
  171 * 裝載和注冊所有JDBC驅動程序//r
  
  172 *
  173 * @param props 屬性
  174 */
  175 private void loadDrivers(Properties props) {
  176 String driverClasses = props.getProperty("drivers");
  177 StringTokenizer st = new StringTokenizer(driverClasses);
  178 while (st.hasMoreElements()) {
  179 String driverClassName = st.nextToken().trim();
  180 try {
  181 Driver driver = (Driver)
  182 Class.forName(driverClassName).newInstance();
  183 DriverManager.registerDriver(driver);
  184 drivers.addElement(driver);
  185 log("成功注冊JDBC驅動程序///" + driverClassName);
  186 }
  187 catch (Exception e) {
  188 log("無法注冊JDBC驅動程序: " +
  189 driverClassName + ", 錯誤: " + e);
  190 }
  191 }
  192 }
  193
  194 /**
  195 * 將文本信息寫入日志文件
  196 */
  197 private void log(String msg) {
  198 log.println(new Date() + ": " + msg);
  199 }
  200
  201 /**
  202 * 將文本信息與異常寫入日志文件
  203 */
  204 private void log(Throwable e, String msg) {
  205 log.println(new Date() + ": " + msg);
  206 e.printStackTrace(log);
  207 }
  208
  209 /**
  210 * 此內部類定義了一個連接池.它能夠根據要求創建新連接,直到預定的最//r

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 年辖:市辖区| 陇西县| 农安县| 钟山县| 剑川县| 盱眙县| 建水县| 锦州市| 长丰县| 桓台县| 会理县| 贺兰县| 江阴市| 巴林右旗| 马鞍山市| 连云港市| 鄂尔多斯市| 宝应县| 米脂县| 梅州市| 宜丰县| 图木舒克市| 岚皋县| 鄂伦春自治旗| 宜昌市| 云林县| 商丘市| 宁陕县| 芷江| 磐石市| 德清县| 新邵县| 马龙县| 扎囊县| 姚安县| 枞阳县| 中宁县| 准格尔旗| 田东县| 晋江市| 忻州市|