幾種經常使用的Java數據源解決方案 java
Java中的數據源就是javax.sql.DataSource。DataSource的建立能夠有不一樣的實現。 mysql
JNDI方式建立DataSource web
以JNDI方式建立數據源首先要配置數據源的相關鏈接信息,也就是數據源鏈接池。該配置應該在Tomcat安裝目錄下的conf/context.xml文件中配置。其配置以下: sql
<Context> 數據庫
…… apache
<!-- MySql --> api
<Resource name="jdbc/NutzDemo" auth="Container" 框架
type="javax.sql.DataSource"maxActive="100" maxIdle="30" post
maxWait="10000"username="root" password="root" 性能
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/cheng"/>
……
</Context>
而後,在程序中以JNDI的方式建立數據源,獲得數據庫鏈接已進行相應的操做。代碼以下:
// 初始化JNDI上下文,建立DataSource對象
Context initContext = new InitialContext();
Context context = (Context)initContext.lookup("java:comp/env");
DataSourcedataSource = (DataSource)context.lookup("jdbc/NutzDemo");
Apache提供的簡單鏈接池建立數據源
以這種方式建立數據源必須先準備兩個jar文件:commons-dbcp.jar 和 commons-pool.jar。
以這種方式建立的數據源就再也不是javax.sql.DataSource。DataSource了,而是org.apache.commons.dbcp.BasicDataSource。並且再也不須要配置任何文件就能夠直接使用。代碼以下:
// 建立BasicDataSource對象
BasicDataSource ds = new BasicDataSource();
ds.setDriverClassName("com.mysql.jdbc.Driver");
ds.setUrl("jdbc:mysql://localhost:3306/cheng");
ds.setUsername("root");
ds.setPassword("root");
ds.setInitialSize(50);
ds.setMaxActive(100);
ds.setMaxIdle(30);
ds.setMaxWait(10000);
// 關閉數據源鏈接
ds.close();
C3P0方式建立數據源
使用C3P0方式建立數據源應該首先準備一個jar文件:c3p0-0.9.1.2.jar,將其放到web/lib目錄下,就能夠在項目中使用C3P0建立數據源,C3P0建立的數據源對象也不是DataSource對象,而是ComboPooledDataSource,代碼以下:
// 建立ComboPooledDataSource對象
ComboPooledDataSource ds = new ComboPooledDataSource();
ds.setDriverClass("com.mysql.jdbc.Driver");
ds.setJdbcUrl("jdbc:mysql://localhost:3306/cheng");
ds.setUser("root");
ds.setPassword("root");
ds.setInitialPoolSize(50);
ds.setMaxPoolSize(100);
ds.setMaxIdleTime(10000);
Proxool方式建立數據源
應該準備的jar文件爲:proxool-01.9.0RC3.jar,以後在項目中建立ProxoolDataSource對象,其代碼以下:
// 建立ProxoolDataSource對象
ProxoolDataSource ds = new ProxoolDataSource();
ds.setDriver("com.mysql.jdbc.Driver");
ds.setDriverUrl("jdbc:mysql://localhost:3306/cheng");
ds.setUser("root");
ds.setPassword("root");
BoneCP方式建立數據源
BoneCP是一個快速高效,開源免費的Java數據庫接池。
創做者稱,BoneCP在性能上會徹底超越全部主流的Java鏈接池。它能夠幫你管理數據鏈接,讓你的應用程序能更快速地訪問數據庫。比C3P0/DBCP(DataBaseconnection pool,數據庫鏈接池)鏈接池快25倍。這個數據庫鏈接池採用Google Collection做爲內部的集合類框架,並且如今的版本已經很穩定。
要使用BoneCP,必須用到的jar文件有:
· bonecp-0.6.5.jar
· google-collections-1.0.jar
· slf4j-api-1.5.11.jar
· slf4j-log4j12-1.5.11.jar
·log4j-1.2.15.jar
在程序中建立BoneCPDataSource對象,代碼以下:
// 建立BoneCPDataSource對象
BoneCPDataSource ds = new BoneCPDataSource();
ds.setDriverClass("com.mysql.jdbc.Driver");
ds.setJdbcUrl("jdbc:mysql://localhost:3306/cheng");
ds.setUsername("root");
ds.setPassword("root");
ds.setAcquireIncrement(1);
ds.setAcquireRetryDelay(10000);
ds.setIdleConnectionTestPeriod(100);
ds.setMinConnectionsPerPartition(2);
ds.setMaxConnectionsPerPartition(20);
ds.setPartitionCount(2);