java 自己實現DataSource實現實例
java 自己實現DataSource實現代碼
DataSource 對象所表示的物理數據源的連接。作為 DriverManager 工具的替代項。DataSource能提供最高性能的對數據庫的并發(fā)訪問,數據源技術是Java操作數據庫的一個很關鍵技術,流行的持久化框架都離不開數據源的應用。
數據源提供了一種簡單獲取數據庫連接的方式,并能在內部通過一個池的機制來復用數據庫連接,這樣就大大減少了創(chuàng)建數據庫連接的次數,提高了系統性能。下面,我們自己動手實現個精簡的數據源,代碼如下:
public class MyDataSource {
private LinkedList<Connection> connectionPool = new LinkedList<Connection>();
public MyDataSource() {
for (int i = 0; i < 10; i++) {
connectionPool.add(new MyConnection(creatConnection(),this));
}
}
private Connection creatConnection() {
try {
return DriverManager.getConnection(
"jdbc:mysql://localhost:3306/test", "root", "root");
} catch (SQLException e) {
// TODO Auto-generated catch block
throw new ExceptionInInitializerError();
}
}
public Connection getConnection(){
System.out.println(connectionPool.size());
return connectionPool.removeFirst();
}
public void freeConnection(Connection conn){
System.out.println("DataSource Close Connection");
connectionPool.addLast(conn);
}
}
Java代碼
public class MyConnection implements Connection{
private Connection connection;
private MyDataSource datasource;
public Connection getConnection() {
return connection;
}
public void setConnection(Connection connection) {
this.connection = connection;
}
public MyConnection(Connection realconnection,MyDataSource datasource){
this.connection=realconnection;
this.datasource=datasource;
}
@Override
public void close() throws SQLException {
// TODO Auto-generated method stub
System.out.println("MyConnection Close");
datasource.freeConnection(this);
}
...
}
我們通過DataSource獲得的Connection是經過包裹后的對象,這里應用到了代理模式。下面我們使用jdk的動態(tài)代理來改寫MyDataSource:
Java代碼
public class MyDataSource {
private LinkedList<Connection> connectionPool = new LinkedList<Connection>();
public MyDataSource() {
for (int i = 0; i < 10; i++) {
connectionPool.add(GetProxy(creatConnection()));
}
}
private Connection GetProxy(final Connection connection) {
// TODO Auto-generated method stub
return (Connection)Proxy.newProxyInstance(this.getClass().getClassLoader(), new Class[]{Connection.class}, new InvocationHandler(){
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
// TODO Auto-generated method stub
Object value;
if(method.getName().equalsIgnoreCase("close")){
connectionPool.addLast((Connection)proxy);
System.out.println(connectionPool.size());
return null;
}else{
value=method.invoke(connection, args);
}
System.out.println(connectionPool.size());
return value;
}
});
}
private Connection creatConnection() {
try {
return DriverManager.getConnection(
"jdbc:mysql://localhost:3306/test", "root", "root");
} catch (SQLException e) {
// TODO Auto-generated catch block
throw new ExceptionInInitializerError();
}
}
public Connection getConnection(){
System.out.println(connectionPool.size());
return connectionPool.removeFirst();
}
public void freeConnection(Connection conn){
System.out.println("DataSource Close Connection");
connectionPool.addLast(conn);
}
}
通過這種方式獲得的Connection是通過jdk的動態(tài)代理生成的一個代理對象,該代理對象實現了Connection接口。
以上兩種方式實現了我們自己的DataSource,在我們通過DataSource獲得的Connection對象的close方法都已經被改寫過了。在Connection對象調用close方法時,會將該Connection對象放入到緩存池中,而不是關閉對象。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- Springboot mybatis plus druid多數據源解決方案 dynamic-datasource的使用詳解
- Spring Boot 自定義數據源DruidDataSource代碼
- 詳解spring cloud config實現datasource的熱部署
- 淺談利用Spring的AbstractRoutingDataSource解決多數據源的問題
- 詳解利用Spring的AbstractRoutingDataSource解決多數據源的問題
- Spring(AbstractRoutingDataSource)實現動態(tài)數據源切換示例
- 使用Spring的AbstractRoutingDataSource實現多數據源切換示例
- 如何在MyBatis中實現DataSource
相關文章
Spring Cloud 中@FeignClient注解中的contextId屬性詳解
這篇文章主要介紹了Spring Cloud 中@FeignClient注解中的contextId屬性詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
SpringMVC編程使用Controller接口實現控制器實例代碼
這篇文章主要介紹了SpringMVC編程使用Controller接口實現控制器實例代碼,具有一定參考價值,需要的朋友可以參考下。2017-11-11

