Java-连接池使用简介

涎涎原创约 747 字大约 2 分钟...JavaJava

Java-连接池使用简介

注意

本博文仅供学术研究和交流参考,严禁将其用于商业用途。如因违规使用产生的任何法律问题,使用者需自行负责。

连接池简介

连接池 是为了解决资源的频繁分配﹑释放所造成的问题而采用的技术。数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去。我们可以通过设定连接池最大连接数来防止系统无尽的与数据库连接。更为重要的是我们可以通过连接池的管理机制监视数据库的连接的数量﹑使用情况,为系统开发﹑测试及性能调整提供依据。

连接池技术在项目中的使用

  1. 在WebContent\META-INF\目录下新建一个context.xml文件,如图:

context.xml

<?xml version="1.0" encoding="UTF-8"?>
<Context>
	<Resource name="jdbc/oracle/my12306" 
	auth="Container" 
	type="javax.sql.DataSource"
	username="scott"
	password="scott123"
	url="jdbc:oracle:thin:@localhost:1521:ORCL"
	driverClassName="oracle.jdbc.driver.OracleDriver"
	maxIdle="2"
	maxWait="5000"
	maxActive="4" />
</Context>
  1. 在util包中新建一个DBUtils_pool类

DBUtils_pool.java

package net.ptcs.my12306.util;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.naming.Context;
import javax.naming.InitialContext;
import javax.sql.DataSource;

/**
 * 启用连接池技术的DBUtil工具类
 * 
 * 步骤:
 * 1.在META-INF目录下创建配置文件context.xml
 * 2.编写DBUtils_pool工具类
 * 在里面定义getConnection方法
 * 
 * 3.这个方法定义完之后不可以马上写main方法测试,因为这个池子是基于Tomcat容器实现的,所以
 * 必须把web应用部署到Tomcat服务器上之后才可以测试
 * @author xianxian
 *
 */
public class DBUtils_pool {
	public static Connection getConnection()
	{
		Connection conn=null;
		try{
			//实例化Context对象,其实读取Context.xml文件中的资源
			Context context = new InitialContext();
			//使用lookup方法寻找数据源资源并且造型成DataSource
			 DataSource ds = (DataSource) context.lookup("java:comp/env/jdbc/oracle/my12306");
			 conn = ds.getConnection();
		}catch(Exception e)
		{
			e.printStackTrace();
		}
		return conn;
	}
	
	/**
	 * 释放资源的方法
	 * @param conn
	 * @param stmt
	 * @param rs
	 */
	public static void release(Connection conn, Statement stmt, ResultSet rs) {
		try {
			if (rs != null) {
				rs.close();
			}
			if (stmt != null) {
				stmt.close();
			}
			if (conn != null) {
				conn.close();
			}
		} catch (SQLException e) {
			e.printStackTrace();
		}
	}
}
  1. 在dao层中使用连接池

参考链接

Java连接池详解open in new window

Java数据库连接池实现原理open in new window

Java数据库连接池的几种配置方法(以MySQL数据库为例)open in new window

Java jdbc数据库连接池总结!open in new window

主流Java数据库连接池比较及前瞻open in new window

几种常见数据库连接池的使用比较open in new window


分割线


相关信息

以上就是我关于 Java-连接池使用简介 知识点的整理与总结的全部内容,希望对你有帮助。。。。。。。

上次编辑于:
贡献者: 涎涎
评论
  • 按正序
  • 按倒序
  • 按热度
Powered by Waline v2.15.4