当前位置:首页 » 数据仓库 » javaweb数据库连接池
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

javaweb数据库连接池

发布时间: 2022-08-29 05:28:32

Ⅰ java中建立数据库连接池,有哪几个步骤

Context context=new InitialContext();
DataSource ds=(DataSource)context.lookup("java:comp/env/jdbc/"+projectName);这里的projectName指的是你的项目名称然后在tomcatde 的\conf\Catalina\localhost目录下配置一个和你项目名称相同的xml文件文件的配置方法可以去网络下很多的,这样就可以使用连接池了。

Ⅱ java web项目中怎么使用连接池是不是在tomcat中配置就好了。我使用了SSH框架

这个有几个思路:
一个是本身项目文件应该有访问权限限制,生产环境的系统不应让开发人员可以察看,开发环境和生产环境应分开。

如果不能分开,还有个方法是用J2EE服务器容器提供数据库Datasource,应用程序直接从web容器获取,不需要提供用户名密码。

还有一个方法,配置数据库服务器限制用户只能从Web容器IP连接,这样甚至可以不需要密码。

Ⅲ Java web连接池

请看JNDI 。。。。至于是不是同一个对象,那要看情况的了

Ⅳ java web数据库连接池

,,,,,,,
这个你咋不会呢。。。。。。都开发网站了。。。
蛮麻烦的 建议你多看看书 现在告诉你 你也不明白的

Ⅳ java web开发 数据库连接池什么时候初始化

数据库连接池处言喻现部application server都提供自数据库连接池案要按照application server文档说明确配置即应用享受数据库连接池处 些候我应用独立java application并普通WEB/J二EE应用且单独运行要application server配合种情况我需要建立自数据库连接池案 一、 DBCP DBCPApache源项目: commons.dbcp DBCP依赖Apache另外二源项目 commons.collectionscommons.pool dbcp包目前版本一.二.一:中国jakarta.apache.org/commons/dbcp/ pool包目前版本一.三:中国jakarta.apache.org/commons/pool/ common-collections包:中国jakarta.apache.org/commons/collections/ 载些包并些包路径添加classpath使用dbcp做项目数据库连接池使用 建立我自数据库连接池使用xml文件传入需要参数使用hard code式简单介绍所需要我自写代码少要建立文件: import org.apache中国mons.dbcp.BasicDataSource; import org.apache中国mons.dbcp.BasicDataSourceFactory; import java.sql.SQLException; import java.sql.Connection; import java.util.Properties; public class ConnectionSource { private static BasicDataSource dataSource = null; public ConnectionSource() { } public static void init() { if (dataSource != null) { try { dataSource.close(); } catch (Exception e) { } dataSource = null; } try { Properties p = new Properties(); p.setProperty("driverClassName", "oracle.jdbc.driver.OracleDriver"); p.setProperty("url", "jdbc:oracle:thin:@一9二.一陆吧.0.一:一5二一:testDB"); p.setProperty("password", "scott"); p.setProperty("username", "tiger"); p.setProperty("maxActive", "三0"); p.setProperty("maxIdle", "一0"); p.setProperty("maxWait", "一000"); p.setProperty("removeAbandoned", "false"); p.setProperty("removeAbandonedTimeout", "一二0"); p.setProperty("testOnBorrow", "true"); p.setProperty("logAbandoned", "true"); dataSource = (BasicDataSource) BasicDataSourceFactory.createDataSource(p); } catch (Exception e) { } } public static synchronized Connection getConnection() throws SQLException { if (dataSource == null) { init(); } Connection conn = null; if (dataSource != null) { conn = dataSource.getConnection(); } return conn; } } 接我应用要简单使用ConnectionSource.getConnection()取连接池数据库连接享受数据库连接带给我处我使用完取数据库连接要简单使用connection.close()连接返连接池至于直接关闭连接返给连接池dbcp使用委派模型实现Connection接口 使用Properties创建BasicDataSource参数设置比较重要: testOnBorrow、testOnReturn、testWhileIdle意思取连接、返连接或连接空闲否进行效性验证(即否数据库连通)默认都false所数据库连接某种原断掉再连接池取连接实际能效连接所确保取连接效 些属性设true进行校验需要另参数:validationQueryoracle说:SELECT COUNT(*) FROM DUAL实际简单SQL语句验证SQL语句数据库跑已连接结返 二参数:timeBetweenEvictionRunsMillis minEvictableIdleTimeMillis 两配合持续更新连接池连接象timeBetweenEvictionRunsMillis 于0每timeBetweenEvictionRunsMillis 间启线程校验连接池闲置间超minEvictableIdleTimeMillis连接象 其些参数参考源代码 二、 C三P0: C三P0放源代码JDBC连接池C三PO 连接池优秀连接池推荐使用C三PO实现JDBC三.0规范部功能性能更加突,包括实现jdbc三jdbc二扩展规范说明Connection Statement 池DataSources 象 载址:中国sourceforge.net/projects/c三p0 package com.systex.utils.web; import java.beans.PropertyVetoException; import java.sql.Connection; import java.sql.SQLException; import javax.sql.DataSource; import com.mchange.v二.c三p0.ComboPooledDataSource; public class C三PODataSource { private static ComboPooledDataSource dataSource = null; private static final String driver = "com.mysql.jdbc.Driver"; private static final String url = "jdbc:mysql://localhost:三三0陆/wyd"; private static final String userName = "root"; private static final String password = "root"; public static DataSource getDataSource() { if (dataSource == null) { dataSource = new ComboPooledDataSource(); try { dataSource.setDriverClass(driver); } catch (PropertyVetoException e) { System.out.println("DataSource Load Driver Exception!!"); e.printStackTrace(); } dataSource.setJdbcUrl(url); dataSource.setUser(userName); dataSource.setPassword(password); // 设置连接池连接容量 dataSource.setMaxPoolSize(二0); // 设置连接池连接容量 dataSource.setMinPoolSize(二); // 设置连接池statements象容量 dataSource.setMaxStatements(一00); } return dataSource; } public static Connection getConnection() throws SQLException { return C三PODataSource.getDataSource().getConnection(); } } 三、 Proxool Java SQL Driver驱程序提供选择其类型驱程序连接池封装非简单移植现存代码完全配置快速熟健壮透明现存JDBC驱程序增加连接池功能 官中国站: 中国proxool.sourceforge.net/ 载址:中国proxool.sourceforge.net/download.htm

Ⅵ java web的数据库连接池配置和jboss里的数据连接池配置的区别

主要差别就是,
1如果数据库信息变更,web的数据库连接池方式需要重新发布应用。而jboss连接池只要修改配置。
2 出于安全目的。有时生产数据库密码是保密的。而放在代码里就太不安全了。
3 如果有测试和生产多套环境,使用jboss数据源可以使一个包在不同环境使用。

Ⅶ 什么是Java web开发中数据库的连接池技术,它的原理大致是什么

什么是连接池
数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个。
为什么要使用连接池
数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。 一个数据库连接对象均对应一个物理数据库连接,每次操作都打开一个物理连接,使用完都关闭连接,这样造成系统的 性能低下。 数据库连接池的解决方案是在应用程序启动时建立足够的数据库连接,并讲这些连接组成一个连接池(简单说:在一个“池”里放了好多半成品的数据库联接对象),由应用程序动态地对池中的连接进行申请、使用和释放。对于多于连接池中连接数的并发请求,应该在请求队列中排队等待。并且应用程序可以根据池中连接的使用率,动态增加或减少池中的连接数。 连接池技术尽可能多地重用了消耗内存地资源,大大节省了内存,提高了服务器地服务效率,能够支持更多的客户服务。通过使用连接池,将大大提高程序运行效率,同时,我们可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。

Ⅷ JavaWeb中用apache的数据库连接池连接数据库,在Linux环境下报错

其中sei7为Linux主机名,你怎么能去连接sqlserver呢。我看是你的配置有问题吧,改写数据库连接地址。如果这部没问题,那就看看你的sqlserver的版本如果是2000的话就需要打上补丁,不然不发从其他机器访问的。

Ⅸ Java开发常用的几个数据库连接池

数据库连接池的好处是不言而喻的,现在大部分的application
server都提供自己的数据库连接池方案,此时,只要按照application server的文档说明,正确配置,即可在应用中享受到数据库连接池的好处。

但是,有些时候,我们的应用是个独立的java
application,并不是普通的WEB/J2EE应用,而且是单独运行的,不要什么application
server的配合,这种情况下,我们就需要建立自己的数据库连接池方案了。

1、 DBCP

DBCP是Apache的一个开源项目:
commons.dbcp

DBCP依赖Apache的另外2个开源项目
commons.collections和commons.pool

dbcp包,目前版本是1.2.1:http://jakarta.apache.org/commons/dbcp/

pool包,目前版本是1.3:http://jakarta.apache.org/commons/pool/,

common-collections包:http://jakarta.apache.org/commons/collections/

下载这些包并将这些包的路径添加到classpath中就可以使用dbcp做为项目中的数据库连接池使用了。

在建立我们自己的数据库连接池时,可以使用xml文件来传入需要的参数,这里只使用hard
code的方式来简单介绍,所有需要我们自己写的代码很少,只要建立一个文件如下:
import
org.apache.commons.dbcp.BasicDataSource;
import
org.apache.commons.dbcp.BasicDataSourceFactory;
import
java.sql.SQLException;
import java.sql.Connection;
import
java.util.Properties;

public class ConnectionSource {

private static BasicDataSource dataSource =
null;

public ConnectionSource() {
}

public static void init() {

if (dataSource != null) {
try
{
dataSource.close();
} catch (Exception e)
{
}

dataSource = null;
}

try {
Properties p = new
Properties();

p.setProperty("driverClassName",
"oracle.jdbc.driver.OracleDriver");
p.setProperty("url",
"jdbc:oracle:thin:@192.168.0.1:1521:testDB");

p.setProperty("password", "scott");
p.setProperty("username",
"tiger");
p.setProperty("maxActive", "30");

p.setProperty("maxIdle", "10");
p.setProperty("maxWait",
"1000");
p.setProperty("removeAbandoned",
"false");
p.setProperty("removeAbandonedTimeout",
"120");
p.setProperty("testOnBorrow", "true");

p.setProperty("logAbandoned", "true");

dataSource = (BasicDataSource)
BasicDataSourceFactory.createDataSource(p);

} catch (Exception e) {
}

}

public static synchronized Connection
getConnection() throws SQLException {

if (dataSource == null) {

init();
}

Connection conn = null;

if (dataSource != null) {

conn = dataSource.getConnection();
}

return conn;
}
}

接下来,在我们的应用中,只要简单地使用ConnectionSource.getConnection()就可以取得连接池中的数据库连接,享受数据库连接带给我们的好处了。当我们使用完取得的数据库连接后,只要简单地使用connection.close()就可把此连接返回到连接池中,至于为什么不是直接关闭此连接,而是返回给连接池,这是因为dbcp使用委派模型来实现Connection接口了。

在使用Properties来创建BasicDataSource时,有很多参数可以设置,比较重要的还有:

testOnBorrow、testOnReturn、testWhileIdle,他们的意思是当是取得连接、返回连接或连接空闲时是否进行有效性验证(即是否还和数据库连通的),默认都为false。所以当数据库连接因为某种原因断掉后,再从连接池中取得的连接,实际上可能是无效的连接了,所以,为了确保取得的连接是有效的,
可以把把这些属性设为true。当进行校验时,需要另一个参数:validationQuery,对oracle来说,可以是:SELECT COUNT(*) FROM
DUAL,实际上就是个简单的SQL语句,验证时,就是把这个SQL语句在数据库上跑一下而已,如果连接正常的,当然就有结果返回了。

还有2个参数:timeBetweenEvictionRunsMillis 和
minEvictableIdleTimeMillis,
他们两个配合,可以持续更新连接池中的连接对象,当timeBetweenEvictionRunsMillis
大于0时,每过timeBetweenEvictionRunsMillis
时间,就会启动一个线程,校验连接池中闲置时间超过minEvictableIdleTimeMillis的连接对象。

还有其他的一些参数,可以参考源代码。

2、
C3P0:

C3P0是一个开放源代码的JDBC连接池,C3PO
连接池是一个优秀的连接池,推荐使用。C3PO实现了JDBC3.0规范的部分功能,因而性能更加突出,包括了实现jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSources 对象。
下载地址:http://sourceforge.net/projects/c3p0

package
com.systex.utils.web;

import java.beans.PropertyVetoException;
import
java.sql.Connection;
import java.sql.SQLException;
import
javax.sql.DataSource;
import
com.mchange.v2.c3p0.ComboPooledDataSource;

public class C3PODataSource {
private static
ComboPooledDataSource dataSource = null;
private static final String driver
= "com.mysql.jdbc.Driver";
private static final String url =
"jdbc:mysql://localhost:3306/wyd";
private static final String userName =
"root";
private static final String password = "root";

public static DataSource getDataSource() {
if
(dataSource == null) {
dataSource = new ComboPooledDataSource();
try
{
dataSource.setDriverClass(driver);
} catch (PropertyVetoException
e) {
System.out.println("DataSource Load Driver
Exception!!");
e.printStackTrace();
}
dataSource.setJdbcUrl(url);
dataSource.setUser(userName);
dataSource.setPassword(password);
//
设置连接池最大连接容量
dataSource.setMaxPoolSize(20);
//
设置连接池最小连接容量
dataSource.setMinPoolSize(2);
//
设置连接池最大statements对象容量
dataSource.setMaxStatements(100);
}
return
dataSource;
}

public static Connection getConnection() throws
SQLException {
return
C3PODataSource.getDataSource().getConnection();
}
}

3、 Proxool

这是一个Java SQL
Driver驱动程序,提供了对你选择的其它类型的驱动程序的连接池封装。可以非常简单的移植到现存的代码中。完全可配置。快速,成熟,健壮。可以透明地为你现存的JDBC驱动程序增加连接池功能。

官方网站: http://proxool.sourceforge.net/

下载地址:http://proxool.sourceforge.net/download.html

Ⅹ Java数据库连接池的几种配置方法(以MySQL数

连接先建立一些连接,并且这些连接允许共享,因此这样就节省了每次连接的时间开销。Mysql数据库为例,连接池在Tomcat中的配置与使用。
1、创建数据库Student,表student
2、配置server.xml文件。Tomcat安装目录下conf中server.xml文件。
<GlobalNamingResources>
<Resource
name="jdbc/DBPool"
type="javax.sql.DataSource"
password=""
driverClassName="com.mysql.jdbc.Driver"
maxIdle="2"
maxWait="5000"
username="root"
url="jdbc:mysql://localhost:3306/student"
maxActive="3"
/>
</GlobalNamingResources>
name:指定连接池的名称
type:指定连接池的类,他负责连接池的事务处理
url:指定要连接的数据库
driverClassName:指定连接数据库使用的驱动程序
username:数据库用户名
password:数据库密码
maxWait:指定最大建立连接等待时间,如果超过此时间将接到异常
maxIdle:指定连接池中连接的最大空闲数
maxActive:指定连接池最大连接数
3、配置web.xml文件。
<web-app>
<resource-ref>
<description>mysql数据库连接池配置</description>
<res-ref-name>jdbc/DBPool</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
<res-sharing-scope>Shareable</res-sharing-scope>
</resource-ref>
</web-app>
4、配置context.xml文件
与server.xml文件所在的位置相同。
<Context>
<ResourceLink
name="jdbc/DBPool"
type="javax.sql.DataSource"
global="jdbc/DBPool"
/>
</Context>
5、测试
DataSource pool = null;
Context env = null;
Connection conn = null;
Statement st = null;
ResultSet rs = null;
try{
env = (Context)new InitialContext().lookup("java:comp/env");
//检索指定的对象,返回此上下文的一个新实例
pool = (DataSource)env.lookup("jdbc/DBPool");
//获得数据库连接池
if(pool==null){out.printl("找不到指定的连接池!");}
con = pool.getConnection();
st = con.createStatement();
rs = st.executeQuery("select * from student");
}catch(Exception ex){out.printl(ne.toString());}