数据库服务器最大连接数和mysql 连接池 连接数最大活动数可否相等

Java 数据库连接池详解及简单实例
字体:[ ] 类型:转载 时间:
这篇文章主要介绍了Java 数据库连接池详解及简单实例的相关资料,需要的朋友可以参考下
Java 数据库连接池详解
数据库连接池的原理是:
连接池基本的思想是在系统初始化的时候,将数据库连接作为对象存储在内存中,当用户需要访问数据库时,并非建立一个新的连接,而是从连接池中取出一个已建立的空闲连接对象。使用完毕后,用户也并非将连接关闭,而是将连接放回连接池中,以供下一个请求访问使用。而连接的建立、断开都由连接池自身来管理。同时,还可以通过设置连接池的参数来控制连接池中的初始连接数、连接的上下限数以及每个连接的最大使用次数、最大空闲时间等等。也可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。
常用的数据库连接池:
常用的数据库连接池有JNDI,C3p0,Apache 的Jakarta 和DBCPBoneCP其中,sping框架依赖的第三方使用了c3p0和dbcp两种方式;而bonecp号称是速度最快的数据库连接池。JNDI方式创建实现的datasource是真正实现了javax.sql.datasource(其他的三种方式都不是)
现在我们主要来介绍如何使用JNDI方式, 这种方式,是由web服务器(例如:tomcat,weblogic,websphere,tomcat),实现了java.sql.datasource。由web服务器负责初始化数据源,创建connection,分配,管理connection。由于本身是由web服务器实现的功能,因此不需要在项目中引入特别的jar包,但是需要在服务器的某些配置文件中增加相关的配置。下面,以Tomcat服务器(数据库为MySQL)为例,讲述这种方式的使用。
数据库的创建与初始化数据:
create table test(id INT PRIMARY KEY,name VARCHAR(10),price FLOAT)
INSERT INTO test VALUES(1,'English',22.2);
INSERT INTO test VALUES(2,'Math',78.9);
INSERT INTO test VALUES(3,'History',77.9);
1.将 数据驱动mysql-connector-java-5.0.3-bin.jar 放入tomcat目录下的lib中
2.修改tomcat的conf下的context.xml文件,增加Resource的配置的支持
&Resource auth="Container" driverClassName="com.mysql.jdbc.Driver" maxActive="100" maxIdle="30" maxWait="10000"
name="jdbc/ewsdb" username="root" password="admin" type="javax.sql.DataSource" url="jdbc:mysql://localhost:3306/test1"
&Resource属性说明&
1)name:指定Resource的JNDI名字。
2)auth:指定管理Resource的Manager,它有两个可选值:Container和Application。Container表示由容器来创建和管理Resource,Application表示由web应用来创建和管理Resource。
3)type: 指定Resource的Java类名。
4)username:指定连接数据库的用户名。
5)password:指定连接数据库的口令。
6)driverClassName:指定连接数据库的JDBC驱动器中的Driver实现类的名字。
7)url:指定连接数据库的URL,127.0.0.1是要连接的数据库服务器的ip,3306是数据库服务器端口,BookDB是数据库名称。
8)maxActive:指定数据库连接池中处于活动状态的数据库连接的最大数目,取值为0,表示不受限制。
9)maxIdle:指定数据库连接池中处于空闲状态的数据库连接的最大数目,取值为0,表示不受限制。
10)maxWait:指定数据库连接池中的数据库连接处于空闲状态的最长时间(以毫秒为单位),超过这一时间,将会抛出异常。取值为-1,表示可以无限期等待。
maxActive="100"
表示并发情况下最大可从连接池中获取的连接数。如果数据库不是单独,供一个应用使用,通过设置maxActive参数可以避免某个应用无限制的获取连接对其他应用造成影响,如果一个数据库只是用来支持一个应用那么maxActive理论上可以设置成该数据库可以支撑的最大连接数。maxActive只是表示通过连接池可以并发的获取的最大连接数。连接的获取与释放是双向,当应用程序并发请求连接池时,连接池就需要从数据库获取连接,那么但应用程序使用完连接并将连接归还给连接池时,连接池是否也同时将连接归还给数据库呢?很显然答案是否定的,如果那样的话连接池就变得多此一举,不但不能提高性能,反而会降低性能,那么但应用成归还连接后,连接池如何处理呢?
maxIdle="30"
如果在并发时达到了maxActive=100,那么连接池就必须从数据库中获取100个连接来供应用程序使用,当应用程序关闭连接后,由于maxIdle=30,因此并不是所有的连接都会归还给数据库,将会有30个连接保持在连接池种中,状态为空闲。
minIdle=”2”
最小默认情况下并不生效,它的含义是当连接池中的连接少有minIdle,系统监控线程将启动补充功能,一般情况下我们并不启动补充线程。
问题:如何设置maxActive和maxIdle?
理论上讲maxActive应该设置成应用的最大并发数,这样一来即便是在最大并发的情况下,应用依然能够从连接池中获取连接,但是困难时的是我们很难准确估计到最大并发数,设置成最大并发数是一种最优的服务质量保证。
maxIdle对应的连接,实际上是连接池保持的长连接,这也是连接池发挥优势的部分,理论上讲保持较多的长连接,在应用请求时可以更快的响应,但是过多的连接保持,反而会消耗数据库大量的资源,因此maxIdle也并不是越大越好,同上例我们建议将 maxIdle设置成50-100中靠近50的数字,例如55。这样就能在兼顾最大并发同时,保持较少的数据库连接,而且在绝大多情况,能够为应用程序提供最快的相应速度。
3.打开应用程序的 Web.xml文件,添加以下配置
&resource-ref&
&description&DB Connection&/description&
&res-ref-name&jdbc/ewsdb&/res-ref-name&
&res-type&javax.sql.DataSource&/res-type&
&res-auth&Container&/res-auth&
&/resource-ref&
&&resource-ref&属性说明:
1)description:对所引用的资源的说明。
2)res-ref-name:指定所引用资源的JNDI名字,与&Resource&元素中的name属性对应。
3)res-type:指定所引用资源的类名,与&Resource&元素中的type属性对应。
4)res-auth:指定管理所引用资源的Manager,与&Resource&元素中的auth属性对应
4. 编写使用java代码,并放在tomcat环境下使用,如下
创建JSP范例:MyJsp.jsp
&%@ page language="java" contentType="text/ charset=utf-8" pageEncoding="utf-8"%&
&!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"&
&%@ page import="java.io.*" %&
&%@ page import="java.util.*" %&
&%@ page import="java.sql.*" %&
&%@ page import="javax.sql.*" %&
&%@ page import="javax.naming.*" %&
&title&Tomcat下JNDI数据库连接池&/title&
Context ctx = new InitialContext();
DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/ewsdb");
conn = ds.getConnection();
stmt = conn.createStatement();
//查询记录
rs = stmt.executeQuery("select ID,NAME,PRICE from test");
//输出查询结果
out.println("&table border=1 width=400&");
while (rs.next()){
String col1 = rs.getString(1);
String col2 = rs.getString(2);
float col3 = rs.getFloat(3);
//打印显示的数据
out.println("&tr&&td&"+col1+"&/td&&td&"+col2+"&/td&&td&"+col3+"&/td&&/tr&");}
out.println("&/table&");
//关闭结果集、SQL声明和数据库连接
rs.close();
stmt.close();
conn.close();
}catch(Exception e){
out.println(e.getMessage());
e.printStackTrace();
 在浏览器中输入http://localhost:8080/test/MyJsp.jsp,即可查看结果
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具联系我们:
400-662-5013
-; 2016, 思达商智(北京)软件技术有限公司 - 京ICP备号多个数据库连接池(多个数据源)连接同一个数据库服务器,空闲连接数会占用连接吗,会导致数据库连接过大? - 知乎10被浏览3477分享邀请回答12 条评论分享收藏感谢收起02 条评论分享收藏感谢收起温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!&&|&&
LOFTER精选
网易考拉推荐
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
阅读(10057)|
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
历史上的今天
loftPermalink:'',
id:'fks_',
blogTitle:'数据库连接池最大连接数与最小连接数',
blogAbstract:'数据库连接池最小连接数和最大连接数:\n\n\n 最小连接数是连接池一直保持的数据连接。如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费掉。\n 最大连接数是连接池能申请的最大连接数。如果数据连接请求超过此数,后面的数据连接请求将被加入到等待队列中,这会影响之后的数据库操作。\n\n',
blogTag:'',
blogUrl:'blog/static/',
isPublished:1,
istop:false,
modifyTime:0,
publishTime:5,
permalink:'blog/static/',
commentCount:3,
mainCommentCount:3,
recommendCount:0,
bsrk:-100,
publisherId:0,
recomBlogHome:false,
currentRecomBlog:false,
attachmentsFileIds:[],
groupInfo:{},
friendstatus:'none',
followstatus:'unFollow',
pubSucc:'',
visitorProvince:'',
visitorCity:'',
visitorNewUser:false,
postAddInfo:{},
mset:'000',
remindgoodnightblog:false,
isBlackVisitor:false,
isShowYodaoAd:false,
hostIntro:'',
hmcon:'1',
selfRecomBlogCount:'0',
lofter_single:''
{list a as x}
{if x.moveFrom=='wap'}
{elseif x.moveFrom=='iphone'}
{elseif x.moveFrom=='android'}
{elseif x.moveFrom=='mobile'}
${a.selfIntro|escape}{if great260}${suplement}{/if}
{list a as x}
推荐过这篇日志的人:
{list a as x}
{if !!b&&b.length>0}
他们还推荐了:
{list b as y}
转载记录:
{list d as x}
{list a as x}
{list a as x}
{list a as x}
{list a as x}
{if x_index>4}{break}{/if}
${fn2(x.publishTime,'yyyy-MM-dd HH:mm:ss')}
{list a as x}
{if !!(blogDetail.preBlogPermalink)}
{if !!(blogDetail.nextBlogPermalink)}
{list a as x}
{if defined('newslist')&&newslist.length>0}
{list newslist as x}
{if x_index>7}{break}{/if}
{list a as x}
{var first_option =}
{list x.voteDetailList as voteToOption}
{if voteToOption==1}
{if first_option==false},{/if}&&“${b[voteToOption_index]}”&&
{if (x.role!="-1") },“我是${c[x.role]}”&&{/if}
&&&&&&&&${fn1(x.voteTime)}
{if x.userName==''}{/if}
网易公司版权所有&&
{list x.l as y}
{if defined('wl')}
{list wl as x}{/list}}

我要回帖

更多关于 连接池超过最大连接数 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信