多数据源的用途

1、什么是多数据源,多数据源的用途?
多数据源指的是如果一个web项目用到了多个数据库,那么就需要连接多个数据库操作,这就是多数据源,举个例子:比如:我要用到A数据库(mysql)中 的某些数据进行数据验证,并且要将数据插入B数据库中(sql server2000)。这样做的好处是,不需要改变A中数据库的结构,就算是连接更多数据库的话,都不需要考虑其中结构问题,但是这就需要一个web项 目跟多个数据库进行连接操作的技术,而这个技术正是我今天介绍的多数据源配置。
2、性能问题
通过我以上的介绍,你肯定有以下想法想法,这样的话,那不就是每一次Web请求都要建立一次数据库连接,建立连接是一个费时的活动,每次都得花费 0.05s~1s的时间,而且如果我是从A数据库的连接到B数据库的连接,那花费的时间将更长,而且系统还要分配内存资源。这个时间对于一次或几次数据库 操作,或许感觉不出系统有多大的开销。可是对于现在的Web应用,尤其是大型电子商务网站,同时有几百人甚至几千人在线是很正常的事。在这种情况下,频繁 的进行数据库连接操作势必占用很多的系统资源,系统的响应速度必定下降,严重的甚至会造成服务器的崩溃。
当然有这种想法不是危言耸听,正是因为这个问题,数据库连接池技术也就产生了。
数据库连接池(connection pool)的工作原理:
由上面的分析可以看出,问题的根源就在于对数据库连接资源的低效管理。
对于共享资源,有一个很著名的设计模式:资源池(Resource Pool)。该模式正是为了解决资源的频繁分配、释放所造成的问题。为解决上述问题,可以采用数据库连接池技术。数据库连接池的基本思想就是为数据库连接 建立一个“缓冲池”。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去。我们可以通过设定 连接池最大连接数来防止系统无尽的与数据库连接。更为重要的是我们可以通过连接池的管理机制监视数据库的连接的数量、使用情况,为系统开发、测试及性能调 整提供依据。
二、 实施步骤
网上存在很多tomcat5.5多数据源配置的资料和教程,但是大多都是在tomcat服务器中配置全局的数据源,因此我觉得这种方式不安全,而 且在真实的项目中不可能存在让你轻易更改web服务器的配置的,并且如果你更改相关的配置信息会影响他人的使用,所以我不介绍这种方案,而介绍的是一种局 部多数据源配置方案。
1、 在你的web项目中的META-INF/下新建一个context.xml文件,并且在其中配置好所需要连接的数据库(数据源)(以下是一个demo,注意其中黑体字的解释)
Context.xml文件中的内容是:
<?xml version="1.0" encoding="UTF-8"?>
//context标签里面的path表示你的web项目的所在相对路径(相对于%tomcat_Home%/webapps/的相对路径),而docBase代表你项目的名称。
<Context path="/pro_bw" docBase="pro_bw" reloadable="true">
//resource标签代表的是一个数据源配置。
Name表示数据源名称。DriverClassName表示驱动类名称。(数据库)
url:是指连接数据库的地址。
<Resource name="jdbc/sql" auth="Container"
type="javax.sql.DataSource" maxActive="100"
maxIdle="50" maxWait="10000"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://192.168.0.196:1433;databaseName=db_bw;user=sa;password=123"
/>
//resource标签代表的是另一个数据源配置。
Name表示数据源名称。DriverClassName表示驱动类名称。(数据库)
url:是指连接数据库的地址。
    <Resource name="jdbc/t_sql" auth="Container"
type="javax.sql.DataSource" maxActive="100"
maxIdle="50" maxWait="10000"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://192.168.0.196:1433;databaseName=db_test;user=sa;password=123"
    />
</Context>
2、 编写连接数据库的类(这里是通过JNDI技术来连接数据库的)。获得数据库的连接的代码示例:
public static synchronized Connection getConnection()
throws NamingException, SQLException {
Context initCtx = new InitialContext();
Context envCtx = (Context) initCtx.lookup("java:comp/env");
DataSource ds = (DataSource) envCtx.lookup("jdbc/sql");
return ds.getConnection();
}

public static synchronized Connection gett_sqlConnection()
throws NamingException, SQLException {
Context initCtx = new InitialContext();
Context envCtx = (Context) initCtx.lookup("java:comp/env");
DataSource ds = (DataSource) envCtx.lookup("jdbc/t_sql");
return ds.getConnection();

}
jdbc/sql和jdbc/t_sql代表上面配置的两个数据源,也就是resource下的name标签,通过这个来进行标识不同的数据源。
3、 后面业务中调用相应的连接就行了,现在展示一下,我写的一个demo示例,通过分别向A数据库中插入一条student的记录,并且B数据库中插入另一条记录。
那么根本得不到正确的验证信息。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值