java tomcat 连接池配置_Tomcat中数据连接池的配置和相应的javabean

数据源(Data Source)为了减少数据库的连接信息和一些逻辑名称写在JSP的源代码中,JDBC2.0提供的一个接口叫做DataSource。

连接池(Connection Pool)对于应用程序来说为了防止应用程序多次连接和断开数据库所耗费的时间和资源,可采用数据连接池的方式减少资源的消耗。即一次向数据库请求很多的connection。存储在一个Pool中,让需要的人从吃重取得Connection,等到用完了后在放回到数据池中。这样提供了一个缓冲区,让JSP和数据库之间得到最大的执行效率。

JNDI(Java Naming and Directory Interface)提供一个接口是用户可在不知道资源所在位置的情形之下获得服务。

5.2.3 Tomcat5.X数据连接池配置:

在Tomcat 5.X的conf目录下面找一个server.xml文件在里面配置数据连接池。在文件里面加入如下编码:

unpackWARs="true" autoDeploy="true"

xmlValidation="false" xmlNamespaceAware="false">

reloadable="true" crossContext="true">

type="javax.sql.DataSource"

driverClassName="org.gjt.mm.mysql.Driver"

maxIdle="30"

maxWait="1000"

username="root"

password="hacker"

url="jdbc:mysql://localhost:3306/toll_system"

maxActive="4"

autoReconnect="true"/>

说明:TollSystemModel是你的war包名称或者是你在webapps/创建的目录名称

jdbc/TollSystemModel中的TollSystemModel是连接数据源名称

toll_system是数据库名称

5.2.4 开发数据源的JavaBean。

下面是用来开发数据源的JavaBean。即ConnectionBean.java。利用JNDI获取数据源,等待用户使用。

package ConnectDatabaseBean;

import java.sql.Connection;

import java.sql.SQLException;

import javax.naming.InitialContext;

import javax.naming.NamingException;

import javax.sql.DataSource;

public class ConnectionBean {

private DataSource ds=null;

public ConnectionBean()

{

//通过JNDI获得数据源

try {

InitialContext ctx=null;

ctx = new InitialContext();

ds=(DataSource)ctx.lookup("java:comp/env/jdbc/TollSystemModel");

} catch (NamingException e) {

e.printStackTrace();

}

}

public Connection getConnection()

{

//获取连接

try{

return ds.getConnection();

}

catch(SQLException sqle)

{

System.err.println("cant‘t get Connection from data source");

sqle.printStackTrace();

return null;

}

}

}

5.2.4 封装的SQL方法的JavaBean

下面是封装的数据库操作的一些方法。即ConnectionHold.java,自行定义了一些transaction和执行的SQL程序代码,便于管理。

package ConnectDatabaseBean;

import java.sql.*;

import javax.servlet.http.HttpSessionBindingEvent;

import javax.servlet.http.HttpSessionBindingListener;

public class ConnectionHolder implements HttpSessionBindingListener{

private Connection connection=null;

private Statement stmt=null;

public ConnectionHolder(){

}

public void commit() throws SQLException{

connection.commit();

}

public ResultSet executeQuery(String sql) throws ClassNotFoundException, SQLException, Exception

{

return stmt.executeQuery(sql);

}

public int executeUpdate(String sql) throws ClassNotFoundException, SQLException, Exception

{

return stmt.executeUpdate(sql);

}

public void rollBack() throws ClassNotFoundException, SQLException, Exception

{

connection.rollback();

}

public void setAutoCommit(boolean ifAuto) throws SQLException

{

//可以设置是否自动提交

connection.setAutoCommit(ifAuto);

}

public void setConnection(Connection holdone)

{

connection=holdone;

try

{

stmt=connection.createStatement();

}

catch(SQLException sqle)

{

stmt=null;

}

}

public void valueBound(HttpSessionBindingEvent arg0) {

if(connection==null)

System.err.println("Didn‘t get Connection from Data Source!");

// 加入session的时候自动产生

}

public void valueUnbound(HttpSessionBindingEvent arg0) {

// TODO Auto-generated method stub

try {

connection.close();

} catch (SQLException e) {

// session注销时候调用,把连接放入池中

e.printStackTrace();

}

finally{

connection=null;

}

}

}

5.2.5 Jsp中如何运用数据源

由于数据连接池的生命周期是整个应用程序,所以他们的范围(scope)应该是application

下面是Jsp中如何引入连接池。

‘/>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
mysql +连接池+JavaBean 实现用户注册登陆系统其实这是jsp宝典上第14章的例子,只是书上错误百出,我反复修改终于调试成功。调试环境: xp2mysql5.018jdk1.5.0_04Tomcat5.028数据库设计: 数据库名: mydb, 登录名:root 密码:123 users表: * 表示该字段是主键=================================================== 字段 数据类型 名称=================================================== USER_ID VARCHAR(50) * 用户名PASSWORD VARCHAR(50) 密码NAME VARCHAR(50) 姓名SEX CHAR(2) 性别BRITH LONG 生日DESCRIPTION VARCHAR(200) 个人描述products表: * 表示该字段是主键=================================================== 字段 数据类型 名称=================================================== PRODUCT_ID BIGINT(20) * 编号 PRODUCT_NAME VARCHAR(50) 名称PRICE FLOAT 价格DESCRIPTION VARCHAR(200) 描述我的Tomcat 安装目录是:D:\Tomcat5连接池配置: 请查看文件:WebRoot.xml 和 web.xml 注 WebRoot.xml 必须存放在D:\Tomcat5\conf\Catalina\localhost\处运行:http://localhost:80/WebRoot/index.jsp //我的 Tomcat 断口是80我的文件目录:D:\web\WebRoot\chek_login.jspD:\web\WebRoot\createMa.jspD:\web\WebRoot\do_register.jspD:\web\WebRoot\index.jspD:\web\WebRoot\login.jspD:\web\WebRoot\logout.jspD:\web\WebRoot\mydb.jspD:\web\WebRoot\register.cssD:\web\WebRoot\register.jspD:\web\WebRoot\WebRoot.xml 必须存放在D:\Tomcat5\conf\Catalina\localhost\下 [我的Tomcat 安装目录是:D:\Tomcat5]D:\web\WebRoot\说明.TxtD:\web\WebRoot\imags\bg.gifD:\web\WebRoot\imags\buy_reg.jpgD:\web\WebRoot\imags\buy_reset.jpgD:\web\WebRoot\imags\index_top32.gifD:\web\WebRoot\imags\liuchen.gifD:\web\WebRoot\imags\log_button.gifD:\web\WebRoot\imags\reg_button.gifD:\web\WebRoot\imags\userlogin.gifD:\web\WebRoot\imags\userlogin2.gifD:\web\WebRoot\imags\username.gifD:\web\WebRoot\imags\username2.gifD:\web\WebRoot\imags\userps.gifD:\web\WebRoot\imags\userps2.gifD:\web\WebRoot\imags\userym.gifD:\web\WebRoot\imags\userym2.gifD:\web\WebRoot\WEB-INF\web.xmlD:\web\WebRoot\WEB-INF\classes\AbstractProduct.javaD:\web\WebRoot\WEB-INF\classes\AbstractUser.javaD:\web\WebRoot\WEB-INF\classes\DateFormat.javaD:\web\WebRoot\WEB-INF\classes\DBConnect.javaD:\web\WebRoot\WEB-INF\classes\Factory.javaD:\web\WebRoot\WEB-INF\classes\MD5.javaD:\web\WebRoot\WEB-INF\classes\Product.javaD:\web\WebRoot\WEB-INF\classes\SqlFactory.javaD:\web\WebRoot\WEB-INF\classes\SqlProduct.javaD:\web\WebRoot\WEB-INF\classes\SqlUser.javaD:\web\WebRoot\WEB-INF\classes\User.javaD:\web\WebRoot\WEB-INF\classes\cn\registerD:\web\WebRoot\WEB-INF\classes\cn\register\DateFormat.classD:\web\WebRoot\WEB-INF\classes\cn\register\Factory.classD:\web\WebRoot\WEB-INF\classes\cn\register\MD5.classD:\web\WebRoot\WEB-INF\classes\cn\register\productD:\web\WebRoot\WEB-INF\classes\cn\register\SqlFactory.classD:\web\WebRoot\WEB-INF\classes\cn\register\db\DBConnect.classD:\web\WebRoot\WEB-INF\classes\cn\register\user\AbstractUser.classD:\web\WebRoot\WEB-INF\classes\cn\register\user\SqlUser.classD:\web\WebRoot\WEB-INF\classes\cn\register\user\Test.classD:\web\WebRoot\WEB-INF\classes\cn\register\user\User.classD:\web\WebRoot\WEB-INF\classes\cn\register\product\AbstractProduct.classD:\web\WebRoot\WEB-INF\classes\cn\register\product\Product.classD:\web\WebRoot\WEB-INF\classes\cn\register\product\SqlProduct.class

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值