设为首页 加入收藏

TOP

通过动态代理(Proxy)实现的数据库连接池的创建连接与归还链接的操作的简单的实现流程(一)
2014-11-23 23:12:09 来源: 作者: 【 】 浏览:17
Tags:通过 动态 代理 Proxy 实现 数据库 连接 池的 创建 归还 链接 操作 简单 流程
package tk.dong.connection.util;

import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.SQLFeatureNotSupportedException;
import java.util.LinkedList;
import java.util.Properties;
import java.util.logging.Logger;

import javax.sql.DataSource;

//这是通过动态代理(Proxy)实现的数据库连接池的创建连接与归还链接的操作
public class JdbcPoolProxy implements DataSource {

	// 创建连接池
	private static LinkedList connections = new LinkedList();
	static {
		// 获取properties的配置文件,并以流的方式存储
		InputStream inputStream = JdbcPoolProxy.class.getClassLoader()
				.getResourceAsStream("jdbc.properties");
		// 创建properties的属性处理对象
		Properties properties = new Properties();
		try {
			// 将属性文件载入
			properties.load(inputStream);
			// 获取连接的驱动文件
			Class.forName(properties.getProperty("driverClassName"));
			// 循环创建连接并放入连接池
			for (int i = 0; i < 10; i++) {
				// 创建连接对象
				final Connection conn = DriverManager.getConnection(
						properties.getProperty("url"),
						properties.getProperty("user"),
						properties.getProperty("pass"));

				// 将创建分连接对象添加到连接池
				// 通过动态代理处理close的方法实现取出的连接对象返回连接池的效果
				connections.add((Connection) Proxy.newProxyInstance(
						JdbcPoolProxy.class.getClassLoader(),
						new Class[] { Connection.class },
						new InvocationHandler() {

							@Override
							public Object invoke(Object proxy, Method method,
									Object[] args) throws Throwable {
								// 判断当前执行的方法名是不是close时还执行自己的方法体
								if (!method.getName().equals("close")) {
									// 执行目标方法
									return method.invoke(conn, args);
								}
								// 如果是close方法
								// 向连接池中添加连接对象
								connections.add(conn);
								System.out.println("又一个连接用玩完了,返回个连接池,当前连接池有"
										+ connections.size() + "个连接对象");
								return null;
							}
						}));
				System.out.println("线连接池添加了一个链接对象,当前连接池有======"
						+ connections.size() + "=====个连接对象");
			}

		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

	}

	@Override
	public Connection getConnection() throws SQLException {
		// 声明连接对象
		Connection conn = null;
		// 判断连接池中是否有连接对象
		if (connections.size() > 0) {
			// 从连接池取出连接对象
			conn = connections.removeFirst();
			System.out.println("有一个连接对象被占用,连接池还有=========" + connections.size()
					+ "个连接");
		}

		return conn;
	}

	@Override
	public Connection getConnection(String username, String password)
			throws SQLException {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public PrintWriter getLogWriter() throws SQLException {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public void setLogWriter(PrintWriter out) throws SQLException {
		// TODO Auto-generated method stub

	}

	@Override
	public void setLoginTimeout(int seconds) throws SQLException {
		// TODO Auto-generated method stub

	}

	@Override
	public int getLoginTimeout() throws SQLException {
		// TODO Auto-generated method stub
		return 0;
	}

	@Override
	public Logger getParentLogger() throws SQLFeatureNotSupportedException {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public  T unwrap(Class iface) throws SQLException {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public boolean isWrapperFor(Class< > iface) throws SQLException {
		// TODO Auto-generated method stub
		return false;
	}

}
下面是测试代码
package tk.dong.connectionPool.test;

import java.sql.Connection;
import java.sql.SQLException;

import org.junit.Test;

import tk.dong.connection.util.JdbcPoolProxy;

public class JdbcPoolProxyTest {

	@Test
	public void test() throws SQLException {
		// 创建连接池对象
		JdbcPoolProxy jdbcPoolProxy = new JdbcPoolProxy();

		// 从连接池中取出连接
		jdbcPoolProxy.getConnection();
		jdbcPoolProxy.getConnection();
		jdbcPoolProxy.getConnection();
		jdbcPoolProxy.getConnection();

		Connection conn = jdbcPoolProxy.getConnection();
		conn.close();

		jdbcPoolProxy.getConnection();
		jdbcPoolProxy.getConnection();

	}

}

下面是运行结果

线连接池添加了一个链接对象,当前连接池有======1=====个连接对象
线连接池添加了一个链接对象,当前连接池有======2=====个连接对象
线连接池添加了一个链接对象,当前连接池有======3=====个连接对象
线连接池添加了一个链接对象,当前连接池有======4=====个连接对象
线连接池添加了一个
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇动态创建ACCESS数据库及其表结构 下一篇EBS动态创建账户组合实现

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: