数据源DataSource 配置

本文介绍如何在Tomcat中配置全局数据源DataSource,并解释其优点及连接池的工作原理。通过<Resource>和<resource-ref>元素实现数据库连接配置。

DataSource:
代表数据源实体
可以代表大型数据库,也可以代表存放数据的文本文件
可以位于服务器端,也可以位于客户端
在开发方面,直观的理解就是:提供Connection的对象


DataSource的优点:
与DriverManager对比
不需要象使用DriverManager一样对加载的数据库驱动程序信息进行硬编码,而是在程序中使用一个逻辑名称来引用数据源
对连接池和分布式事务的支持

 

连接池:
连接池产生并管理一系列与数据库的连接
原理:在DataSource中事先建立了多个数据库连接,这些数据库连接保存在连接池(Connect Pool)中。Java程序访问数据库时,只需要从连接池中取出空闲状态的数据库连接;当程序访问数据库结束,再将数据库连接放回连接池。
在访问量大的时候,与应用程序自己维护数据库连接相比,优势非常明显

 

在Tomcat中配置全局数据源
1、在server.xml中加入<Resource>元素<Resource>元素用来定义JNDI Resource
<Resource name="jdbc/TaskDB" auth="Container"
      type="javax.sql.DataSource"
      maxActive="100" maxIdle="30"    maxWait="10000"
      username="root" password="neddy"
     driverClassName="com.mysql.jdbc.Driver"
 url="jdbc:mysql://localhost:3306/task?autoReconnect=true"/>


<Resource>元素属性说明
name    指定Resource的JNDI名字
auth    指定管理Resource的Manager,它有两个可选值:Container、Application
type    指定Resource所属的Java类名
maxActive    指定数据库连接池中处于活动状态的最大连接数目,0表示不受限制
maxIdle    指定数据库连接池中处于空闲状态的最大连接数目,0表示不受限制
maxWait   获取数据库连接的最长等待时间,-1表示无限期等待
username    指定连接数据库的用户名
password    指定连接数据库的口令
driverClassName    指定连接数据库的JDBC驱动程序
url             指定连接数据库的URL

 

2、在web.xml中加入<resource-ref>元素<resource-ref>元素表示在Web应用中引用JNDI资源
<resource-ref>
<description>DB Connection</description>
<res-ref-name>jdbc/TaskDB</res-ref-name>
 <res-type>javax.sql.DataSource</res-type>
 <res-auth>Container</res-auth>
</resource-ref>

 

<resource-ref>元素属性说明
description    对所引用的资源的说明
res-ref-name    指定所引用资源的JNDI名字,与<Resource>元素中的name属性对应
res-type             指定所引用资源的类名字,与<Resource>元素中的type属性对应
res-auth             指定所引用资源的Manager,与<Resource>元素中的auth属性对应

 

3、在tomcat_home/conf/Context.xml加入以下格式的信息做资源映射
<ResourceLink name="jdbc/TaskDB" global="jdbc/TaskDB" type="javax.sql.DataSource"/>
或者在tomcat_home\webapps\应用名\META-INF\context.xml中加入此信息
或者在tomcat_home/conf/localhost/下建立一个xml文件,文件名是“应用名.xml”,里面填加同样的内容

注意:

由于数据源由Servlet容器创建并维护,所以必须把JDBC驱动程序拷贝到Tomcat安装目录下的common/lib目录下,确保Servlet容器能够访问驱动程序

 

使用DataSource
获得对数据源的引用:
 Context ctx = new InitalContext();
 DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/TaskDb");
获得数据库连接对象:
 Connection con = ds.getConnection();
返回数据库连接到连接池:
      con.close();

<think>首先,用户的问题是关于查找Spring Boot多数据源DataSource配置方法。查询是:"请问Spring Boot多数据源DataSource配置"。 参考系统指令: - 所有行内数学表达式必须使用$...$格式。 - 独立公式必须使用$$...$$格式。 - LaTeX语法正确。 - 使用中文回答。 - 生成相关问题。 - 回答中引用的段落末尾自然地添加引用标识。 另外,用户提供了站内引用: - 引用[1]:讨论Spring Boot多数据源配置的概述。 - 引用[2]:提供具体的代码示例,配置多个数据源的Bean。 - 引用[3]:简要提到单个数据源配置。 - 引用[4]:另一个配置示例,涉及MapperScan。 从这些引用中,重点是配置多个数据源的具体方法。我需要从中提取相关信息来回答用户的问题。 关键点从引用中: - 引用[2] 提供了核心代码:使用@Configuration类,定义多个DataSource Bean,每个用@Bean注解,并指定配置前缀。 - 引用[4] 补充了MyBatis的配置,如SqlSessionFactory和事务管理器。 用户的问题是具体的:"Spring Boot多数据源DataSource配置",所以我需要专注于如何配置DataSource本身。引用[2] 直接提供了这个。 回答结构应该清晰,逐步解决问题: 1. 概述多数据源配置的基本步骤。 2. 提供代码示例。 3. 解释关键部分。 4. 生成相关问题。 使用中文回答。 在回答末尾自然地添加引用标识。例如,如果引用代码来自[2],就在那段代码后加[^2]。 最后,生成相关问题。 组织回答: - 先简要介绍。 - 然后分步骤解释配置方法,包括代码。 - 确保代码格式正确(使用代码块)。 - 结尾添加相关问题。 代码示例:从引用[2]中提取并呈现。 独立公式:问题中没有数学相关内容,所以可能不需要。但如果用户提到方程等,我会处理。这里看起来纯技术问题,跳过LaTeX。 生成相关问题: - 基于主题,如优化、常见问题、事务管理等。 完整回答框架: 1. **简介**:解释多数据源配置的好处和基本概念。 2. **配置步骤**: - 添加依赖。 - 创建配置类。 - 定义多个DataSource Bean。 - 配置属性文件。 - 事务管理(如果需要)。 3. **代码示例**:展示核心代码。 4. **总结**。 5. **相关问题**。 引用标识:在解释引用内容时添加。 </think>### Spring Boot多数据源DataSource配置方法 在Spring Boot项目中,配置数据源DataSource可以帮助支持复杂的业务场景,如读写分离、分库分表或多租户系统。核心方法是定义一个或多个DataSource Bean,并通过属性文件指定连接参数。下面我将基于引用内容,逐步说明配置步骤,确保回答可靠且实用。 #### 1. **添加依赖** 首先,确保项目中包含必要的依赖。Spring Boot Starter Data JDBC或Spring Boot Starter Data JPA是基础: ```xml <!-- pom.xml 示例 --> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <!-- 如果使用MyBatis,添加 --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>3.0.3</version> </dependency> </dependencies> ``` #### 2. **创建配置类定义DataSource Bean** 核心是通过一个@Configuration类定义多个DataSource Bean,每个Bean对应一个数据源。使用@Primary注解标记主数据源。代码示例基于引用[2]和[^4]: ```java import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.boot.jdbc.DataSourceBuilder; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import javax.sql.DataSource; @Configuration public class DataSourceConfig { // 主数据源配置 @Bean(name = "primaryDataSource") @Primary // 标记为主数据源 @ConfigurationProperties(prefix = "spring.datasource.primary") // 绑定属性前缀 public DataSource primaryDataSource() { return DataSourceBuilder.create().build(); // 自动构建DataSource } // 次数据源配置 @Bean(name = "secondaryDataSource") @ConfigurationProperties(prefix = "spring.datasource.secondary") // 绑定属性前缀 public DataSource secondaryDataSource() { return DataSourceBuilder.create().build(); } } ``` - **解释**:每个@Bean方法定义一个DataSource,@ConfigurationProperties读取属性文件中以指定前缀开头的配置(如数据库URL、用户名)。@Primary确保事务管理器默认使用主数据源[^2][^4]。 #### 3. **配置属性文件** 在`application.properties`或`application.yml`中定义数据源详细信息: ```properties # 主数据源配置 spring.datasource.primary.url=jdbc:mysql://localhost:3306/db_primary spring.datasource.primary.username=root spring.datasource.primary.password=password spring.datasource.primary.driver-class-name=com.mysql.cj.jdbc.Driver # 次数据源配置 spring.datasource.secondary.url=jdbc:mysql://localhost:3306/db_secondary spring.datasource.secondary.username=root spring.datasource.secondary.password=password spring.datasource.secondary.driver-class-name=com.mysql.cj.jdbc.Driver ``` - **注意事项**:属性前缀必须匹配代码中的@ConfigurationProperties前缀。如果使用其他数据库(如PostgreSQL),调整URL和驱动类[^1][^3]。 #### 4. **配置事务和MyBatis(可选)** 如果使用MyBatis或JPA,需要额外配置SqlSessionFactory和事务管理器,以避免冲突。基于引用[2]和[^4]: ```java import org.apache.ibatis.session.SqlSessionFactory; import org.mybatis.spring.SqlSessionFactoryBean; import org.springframework.context.annotation.Bean; import org.springframework.jdbc.datasource.DataSourceTransactionManager; import org.springframework.transaction.PlatformTransactionManager; import javax.sql.DataSource; @Configuration public class MyBatisConfig { // 主数据源SqlSessionFactory @Bean(name = "mainSessionFactory") public SqlSessionFactory mainSqlSessionFactory(DataSource primaryDataSource) throws Exception { SqlSessionFactoryBean sessionFactoryBean = new SqlSessionFactoryBean(); sessionFactoryBean.setDataSource(primaryDataSource); return sessionFactoryBean.getObject(); } // 主数据源的事务管理器 @Bean public PlatformTransactionManager primaryTransactionManager(DataSource primaryDataSource) { return new DataSourceTransactionManager(primaryDataSource); } // 次数据源的事务管理器(如果需要) @Bean public PlatformTransactionManager secondaryTransactionManager(DataSource secondaryDataSource) { return new DataSourceTransactionManager(secondaryDataSource); } } ``` - **解释**:每个SqlSessionFactory绑定到特定的DataSource。事务管理器确保操作的一致性。在MapperScan中指定对应的SqlSessionFactoryRef,如引用[4]所示[^2][^4]。 #### 5. **使用和验证** - 在Service或DAO层,通过@Qualifier注入特定数据源: ```java @Service public class MyService { @Autowired @Qualifier("primaryDataSource") private DataSource primaryDataSource; @Autowired @Qualifier("secondaryDataSource") private DataSource secondaryDataSource; } ``` - 启动应用检查日志:确保没有数据源冲突错误。Spring Boot会自动加载Bean[^1][^3]。 #### 总结 配置数据源DataSource的核心是定义多个@Bean并使用属性文件绑定参数。这种方法灵活扩展性强,适合高并发系统。实践中,确保事务管理正确以避免脏读或死锁[^1][^2]。更多细节可参考[Spring Boot官方文档](https://docs.spring.io/spring-boot/docs/current/reference/html/data.html)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值