研究了Proxool連接池的源代碼後完成下面的程序Proxool連接池的配置過程略
data:image/s3,"s3://crabby-images/bdebb/bdebb54f3da1574a6ad769e3800f9b7eae3d0183" alt=""
data:image/s3,"s3://crabby-images/cba4e/cba4ead911c24ada13b2a9a155bd4445a0ad1029" alt=""
/**//*
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
*@author 我為J狂 建立日期
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
*
data:image/s3,"s3://crabby-images/5aa77/5aa77518af61e5e7db19e4055dd870059c888248" alt=""
*/
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
package net
blogjava
lzqdiy;
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
import
URL;
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
import java
sql
*;
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
import org
logicalcobwebs
proxool
ProxoolException;
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
import org
logicalcobwebs
proxool
ProxoolFacade;
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
import org
logicanfiguration
JAXPConfigurator;
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
import org
logicalcobwebs
proxool
admin
SnapshotIF;
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
public class DBConnection
data:image/s3,"s3://crabby-images/bdebb/bdebb54f3da1574a6ad769e3800f9b7eae3d0183" alt=""
data:image/s3,"s3://crabby-images/cba4e/cba4ead911c24ada13b2a9a155bd4445a0ad1029" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
private static boolean initialized = false;
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
private static int activeCount =
;
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
public static Connection getConnection() throws SQLException
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
Connection connection = null;
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
if (!initialized)
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
init();
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
connection = DriverManager
getConnection(
proxool
Develop
);
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
try
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
SnapshotIF snapshot = ProxoolFacade
getSnapshot(
Develop
true);
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
int curActiveCount = snapshot
getActiveConnectionCount();// 獲得活動連接數
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
int availableCount = snapshot
getAvailableConnectionCount();// 獲得可得到的連接數
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
int maxCount = snapshot
getMaximumConnectionCount();// 獲得總連接數
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
if (curActiveCount != activeCount)// 當活動連接數變化時輸出信息
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
System
out
println(
);
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
System
out
println(curActiveCount +
(active)
+ availableCount
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
+
(available)
+ maxCount +
(max)
);
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
System
out
println(
);
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
activeCount = curActiveCount;
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
} catch (ProxoolException e)
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
// TODO Auto
generated catch block
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
e
printStackTrace();
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
if (connection != null)
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
return connection;
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
} else
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
throw new NullPointerException(
Didn
t get connection
which probably means that no Driver accepted the URL
);
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
private static void init()
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
String fileName =
proxool
xml
;
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
URL resourceURL = null;
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
try
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
if (Thread
currentThread()
getContextClassLoader() != null)
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
resourceURL = Thread
currentThread()
getContextClassLoader()
getResource(fileName);
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
if (resourceURL == null)
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
resourceURL = DBConnection
class
getClassLoader()
getResource(
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
fileName);
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
nfigure(resourceURL
getFile()
false);
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
Class
forName(
org
logicalcobwebs
proxool
ProxoolDriver
);
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
} catch (ClassNotFoundException e)
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
// TODO Auto
generated catch block
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
e
printStackTrace();
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
} catch (ProxoolException e)
data:image/s3,"s3://crabby-images/e668d/e668db0001d026034e4d97f7e463051a4bc01948" alt=""
data:image/s3,"s3://crabby-images/6e891/6e891e1b846bac10eb0eb3154c10b2f508ffeadf" alt=""
{
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
// TODO Auto
generated catch block
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
e
printStackTrace();
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/1b0c1/1b0c1a9230a97b46431592d2b3defd04eff26014" alt=""
initialized = true;
data:image/s3,"s3://crabby-images/b326c/b326c45eb9d8ad7233cd5fd08361025111fd7022" alt=""
}
data:image/s3,"s3://crabby-images/5aa77/5aa77518af61e5e7db19e4055dd870059c888248" alt=""
}
proxoolxml內容
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<?xml version=
encoding=
UTF
?>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<something
else
entirely>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<proxool>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<alias>Develop</alias>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<driver
url>jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=
)(PORT=
)))(CONNECT_DATA=(SID=lzqdiy)(SERVER=DEDICATED)))
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
</driver
url>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<driver
class>oracle
jdbc
driver
OracleDriver</driver
class>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<driver
properties>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<property name=
user
value=
lzqdiy
/>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<property name=
password
value=
lzqdiy
/>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
</driver
properties>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<maximum
connection
count>
</maximum
connection
count>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<minimum
connection
count>
</minimum
connection
count>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
<house
keeping
test
sql>select CURRENT_DATE</house
keeping
test
sql>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
</proxool>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
</something
else
entirely>
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
data:image/s3,"s3://crabby-images/94582/945823e7203509514f6d055094c253887ffaf3eb" alt=""
通過語句
Connection con=DBConnection
getConnection();來獲得一個數據庫連接
當活動連接數變化時向控制台輸出連接信息
From:http://tw.wingwit.com/Article/program/Java/hx/201311/25800.html