寫了個連線池的類,和大家一起探討,歡迎交流
寫了個連線池的類,和大家一起探討,歡迎交流
package com.dalong.connectionpool;
import java.util.HashMap;
import java.util.Vector;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.*;
public class ConnectionPool {
//連線池的管理器,首先初始化,僅僅有一個物件,管理連線池
private static HashMap connectionPoolManager=new HashMap();
//沒有用過的連線池,用vector實現同步
private static Vector noUseConnectionPool;
//沒有用過的連線池
private static HashMap nowUseConnectionPool;
private static String dbDriver="odbc:jdbc:OdbcJdbcDriver";
private static String dbUrl="dalong@XX";
private static String userName="dalong";
private static String userPassword="dalong";
//預設為100個連線池
private static int MAX_POOL=100;
//singleTon 設計模式
private ConnectionPool(String driver,String url,String name,String password,int max)
throws ClassNotFoundException {
Class.forName(driver);
dbUrl=url;
userName=name;
userPassword=password;
MAX_POOL=max;
}
public static ConnectionPool getConnManagerInstance(String poolName)
throws ClassNotFoundException{
ConnectionPool tempPool=(ConnectionPool)connectionPoolManager.get(poolName);
if(tempPool==null){
tempPool=new ConnectionPool(dbDriver,dbUrl,userName,userPassword,MAX_POOL);
connectionPoolManager.put(poolName,tempPool);
return tempPool;
}else
return tempPool;
}
//透過連線池獲得真正的連結
public static Connection getConnection() throws java.sql.SQLException{
Connection conn=null;
synchronized(noUseConnectionPool){
if(noUseConnectionPool.size()>0){
conn=(Connection)noUseConnectionPool.firstElement();
noUseConnectionPool.remove(conn);
return conn;
}
}
//如果資料庫連線池沒有連結了,自己建立一個
if(conn==null){
conn=createConnection(dbDriver,dbUrl,userName,userPassword);
}else if(conn.isClosed()){
nowUseConnectionPool.remove(conn);
conn=createConnection(dbDriver,dbUrl,userName,userPassword);
}
conn.setAutoCommit(false);
nowUseConnectionPool.put(conn,conn);
return conn;
}
//如果連線池沒有連結了,就需要產生一個連結
private static Connection createConnection(String driver,String url,String user,String password)
throws java.sql.SQLException{
Connection conn=DriverManager.getConnection(url,user,password);
return conn;
}
public static void releaseConnection(Connection conn,boolean isCommit)
throws java.sql.SQLException{
if(isCommit)
conn.commit();
else
conn.rollback();
nowUseConnectionPool.remove(conn);
if(noUseConnectionPool.size() + nowUseConnectionPool.size()<MAX_POOL){
synchronized(noUseConnectionPool){
noUseConnectionPool.add(conn);
}
}else{
conn.close();
}
}
public static void main(String[] args) {
//測試模擬10個客戶
for (int i = 0; i < 10; i++) {
try {
//xxxx 一般為屬性檔案讀取
ConnectionPool pool = ConnectionPool.getConnManagerInstance("xxxx");
Connection conn = pool.getConnection();
}catch (SQLException ex1) {
//處理異常
}
catch (ClassNotFoundException ex) {
//處理異常
}
}
}
}
package com.dalong.connectionpool;
import java.util.HashMap;
import java.util.Vector;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.*;
public class ConnectionPool {
//連線池的管理器,首先初始化,僅僅有一個物件,管理連線池
private static HashMap connectionPoolManager=new HashMap();
//沒有用過的連線池,用vector實現同步
private static Vector noUseConnectionPool;
//沒有用過的連線池
private static HashMap nowUseConnectionPool;
private static String dbDriver="odbc:jdbc:OdbcJdbcDriver";
private static String dbUrl="dalong@XX";
private static String userName="dalong";
private static String userPassword="dalong";
//預設為100個連線池
private static int MAX_POOL=100;
//singleTon 設計模式
private ConnectionPool(String driver,String url,String name,String password,int max)
throws ClassNotFoundException {
Class.forName(driver);
dbUrl=url;
userName=name;
userPassword=password;
MAX_POOL=max;
}
public static ConnectionPool getConnManagerInstance(String poolName)
throws ClassNotFoundException{
ConnectionPool tempPool=(ConnectionPool)connectionPoolManager.get(poolName);
if(tempPool==null){
tempPool=new ConnectionPool(dbDriver,dbUrl,userName,userPassword,MAX_POOL);
connectionPoolManager.put(poolName,tempPool);
return tempPool;
}else
return tempPool;
}
//透過連線池獲得真正的連結
public static Connection getConnection() throws java.sql.SQLException{
Connection conn=null;
synchronized(noUseConnectionPool){
if(noUseConnectionPool.size()>0){
conn=(Connection)noUseConnectionPool.firstElement();
noUseConnectionPool.remove(conn);
return conn;
}
}
//如果資料庫連線池沒有連結了,自己建立一個
if(conn==null){
conn=createConnection(dbDriver,dbUrl,userName,userPassword);
}else if(conn.isClosed()){
nowUseConnectionPool.remove(conn);
conn=createConnection(dbDriver,dbUrl,userName,userPassword);
}
conn.setAutoCommit(false);
nowUseConnectionPool.put(conn,conn);
return conn;
}
//如果連線池沒有連結了,就需要產生一個連結
private static Connection createConnection(String driver,String url,String user,String password)
throws java.sql.SQLException{
Connection conn=DriverManager.getConnection(url,user,password);
return conn;
}
public static void releaseConnection(Connection conn,boolean isCommit)
throws java.sql.SQLException{
if(isCommit)
conn.commit();
else
conn.rollback();
nowUseConnectionPool.remove(conn);
if(noUseConnectionPool.size() + nowUseConnectionPool.size()<MAX_POOL){
synchronized(noUseConnectionPool){
noUseConnectionPool.add(conn);
}
}else{
conn.close();
}
}
public static void main(String[] args) {
//測試模擬10個客戶
for (int i = 0; i < 10; i++) {
try {
//xxxx 一般為屬性檔案讀取
ConnectionPool pool = ConnectionPool.getConnManagerInstance("xxxx");
Connection conn = pool.getConnection();
}catch (SQLException ex1) {
//處理異常
}
catch (ClassNotFoundException ex) {
//處理異常
}
}
}
}
相關文章
- QuickCHM2.01破解小記,歡迎大家一起交流UI
- 關於最近學習的Less預編譯語言的筆記,歡迎大家一起探討~編譯筆記
- 尋求解決之道.歡迎探討!!!
- 關於連線bean中可能發生多執行緒的問題請教,歡迎大家一起討論Bean執行緒
- C語言寫的磁碟排程演算法,歡迎大家來討論C語言演算法
- 講座:資料庫專案生命週期中的優化 歡迎大家光臨探討資料庫優化
- 微信分享,交流學習oracle技術,歡迎大家關注Oracle
- go 寫了個部落格,歡迎圍觀Go
- JAVA開原始碼交流QQ群!!歡迎加入並討論!!Java原始碼
- 自創一個簡單的Web分散式解決方案,歡迎大家討論Web分散式
- 關於DAO的封裝,請板橋幫助,歡迎大家討論封裝
- 在專案中使用設計模式的淺見,歡迎大家討論:)設計模式
- 億憶網客戶端原始碼開源!歡迎探討!客戶端原始碼
- 一起探討JavaScript的物件JavaScript物件
- livewire加tailwindcss寫了一個部落格歡迎starAICSS
- 擼了一個Golang的包管理/自動化構建工具,歡迎大家拍磚Golang
- 「譯」一起探討 JavaScript 的物件JavaScript物件
- 桌面桌布分享【歡迎大家參與】
- 探討.net Socket支援線上連線數量
- 【案例討論】災難與拯救 資料安全精彩案例大討論!歡迎大家踴躍參與!
- 討論:大家來討論一些連線涉及到的引數
- 我寫了一個從DATASOURCE取得CONNECTION的工具類,大家看看
- 連線池和連線數詳解
- 最近自己開發了個人部落格站,歡迎大家來看看
- HHDESK新功能釋出,歡迎大家使用
- 探討阻塞佇列和執行緒池原始碼佇列執行緒原始碼
- 手寫資料庫連線池資料庫
- 最近學習了Http連線池HTTP
- 《四 資料庫連線池原始碼》手寫資料庫連線池資料庫原始碼
- 日常練習:寫了個grpc 連線池,希望各位前輩能提下意見RPC
- 多層架構的討論,歡迎拍磚架構
- 歡迎大家觀顧【圖靈教育社群】圖靈
- 介面測試平臺,歡迎大家體驗
- 小閃對話:微信長連線設計的探討(三)
- 小閃對話:微信長連線設計的探討(二)
- 如何在多個Web專案中共享資訊,歡迎討論Web
- ADO.NET連線池寫法
- 在weblogic中配置mysql的連線池的問題??希望大家進來看看了,謝謝了WebMySql