Spring Boot+Mybatis+Annotation+Druid(五)

本文介绍Druid作为Java中优秀的数据库连接池工具,不仅提供了强大的监控功能还支持扩展。文中详细展示了如何使用Druid配置多数据源,并通过具体示例介绍了配置过程及实践应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. Druid是什么?

   Druid是Java语言中最好的数据库连接池。Druid能够提供强大的监控和扩展功能。

  Druid 核心主要包括三部分:
1. DruidDriver 代理 Driver,能够提供基于 Filter-Chain 模式的插件体系。
2. DruidDataSource 高效可管理的数据库连接池
3. SQLParser

2. 在哪里下载druid

正式版本下载:

3.
多数据源的应用

     当业务数据量达到了一定程度,DBA 需要合理配置数据库资源。即配置主库的机器高配置,把核心高频的数据放在主库上;把次要的数据放在从库,低配置,开源节流。把数据放在不同的数据库里,就需要通过不同的数据源进行操作数据。


    那么user 用户表在主库 master 上,城市表 city 在从库 cluster 上。

User表

/*
Navicat MySQL Data Transfer

Source Server         : aaaa
Source Server Version : 50512
Source Host           : localhost:3306
Source Database       : springbootdb_custer

Target Server Type    : MYSQL
Target Server Version : 50512
File Encoding         : 65001

Date: 2018-04-04 17:05:30
*/

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for user
-- ----------------------------
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '用户编号',
  `user_name` varchar(25) DEFAULT NULL COMMENT '用户名称',
  `description` varchar(25) DEFAULT NULL COMMENT '描述',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of user
-- ----------------------------
INSERT INTO `user` VALUES ('1', '李福', '这是个测试网站哦!');

City表

/*
Navicat MySQL Data Transfer

Source Server         : aaaa
Source Server Version : 50512
Source Host           : localhost:3306
Source Database       : springbootdb

Target Server Type    : MYSQL
Target Server Version : 50512
File Encoding         : 65001

Date: 2018-04-02 10:45:36
*/

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for city
-- ----------------------------
DROP TABLE IF EXISTS `city`;
CREATE TABLE `city` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '城市编号',
  `province_id` int(10) unsigned NOT NULL COMMENT '省份编号',
  `city_name` varchar(25) DEFAULT NULL COMMENT '城市名称',
  `description` varchar(25) DEFAULT NULL COMMENT '描述',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of city
-- ----------------------------
INSERT INTO `city` VALUES ('1', '1', '杭州市', '刘飞的家在杭州市');
INSERT INTO `city` VALUES ('2', '1', '海宁市', '张三的家在海宁市')

工程架构图:

(1)使用Maven加入Druid.jar

	<!-- Druid 数据连接池依赖 -->
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>druid</artifactId>
			<version>1.1.6</version>
		</dependency>

(2)application.properties 配置两个数据源配置

## user
master.datasource.url=jdbc:mysql://localhost:3306/springbootdb_custer?useUnicode=true&characterEncoding=utf8
master.datasource.username=root
master.datasource.password=root
master.datasource.driver-class-name=com.mysql.jdbc.Driver

## city
cluster.datasource.url=jdbc:mysql://localhost:3306/springbootdb?useUnicode=true&characterEncoding=utf8
cluster.datasource.username=root
cluster.datasource.password=root
cluster.datasource.driver-class-name=com.mysql.jdbc.Driver

(3) 多数据源配置的时候注意,必须要有一个主数据源,即 MasterDataSourceConfig 配置:

import javax.sql.DataSource;

import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;

import org.springframework.jdbc.datasource.DataSourceTransactionManager;

import com.alibaba.druid.pool.DruidDataSource;

@Configuration
// 扫描 Mapper 接口并容器管理
//sqlSessionFactoryRef表示定义了 key ,表示一个唯一 SqlSessionFactory 实例
@MapperScan(basePackages = MasterDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "masterSqlSessionFactory")
public class MasterDataSourceConfig {
	// 精确到 master 目录,以便跟其他数据源隔离
	static final String PACKAGE = "com.hlx.springboot.dao.master";
	// static final String MAPPER_LOCATION = "classpath:mapper/master/*.xml";

	// 获取全局配置文件 application.properties 的 key=value 配置,并自动装配
	@Value("${master.datasource.url}")
	private String url;

	@Value("${master.datasource.username}")
	private String user;

	@Value("${master.datasource.password}")
	private String password;

	@Value("${master.datasource.driver-class-name}")
	private String driverClass;

	/**
	 * 数据源
	 * 
	 * @return
	 */
	@Bean(name = "masterDataSource")
	@Primary
	// 多数据源配置的时候注意,必须要有一个主数据源
	public DataSource masterDataSource() {
		// 数据源对象
		DruidDataSource dataSource = new DruidDataSource();
		// 将值设置中
		dataSource.setDriverClassName(driverClass);
		dataSource.setUrl(url);
		dataSource.setUsername(user);
		dataSource.setPassword(password);
		return dataSource;
	}

	/**
	 * 事务管理
	 * 
	 * @return
	 */
	@Bean(name = "masterTransactionManager")
	@Primary
	// 多数据源配置的时候注意,必须要有一个主数据源
	public DataSourceTransactionManager masterTransactionManager() {
		// spring事务管理
		return new DataSourceTransactionManager(masterDataSource());
	}

	/**
	 * 会话工厂
	 * 
	 * @param masterDataSource
	 * @return
	 * @throws Exception
	 */

	@Bean(name = "masterSqlSessionFactory")
	@Primary
	// 多数据源配置的时候注意,必须要有一个主数据源
	public SqlSessionFactory masterSqlSessionFactory(
			@Qualifier("masterDataSource") DataSource masterDataSource)
			throws Exception {
		// 会话工厂对象
		final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
		// 设置数据源
		sessionFactory.setDataSource(masterDataSource);
		// 设置xml路径
		// sessionFactory
		// .setMapperLocations(new PathMatchingResourcePatternResolver()
		// .getResources(MasterDataSourceConfig.MAPPER_LOCATION));
		return sessionFactory.getObject();
	}
}
ClusterDataSourceConfig 配置:(忽略)注意这个不能再配置@Primary就OK了!

(4)数据层

@Mapper
public interface UserDao {

	/**
     * 根据用户名获取用户信息
     *
     * @param userName
     * @return
     */
	@Select("select * from user where user_name=#{userName}")
	@Results({
		@Result(column="id",property="id"),
		@Result(column="user_name",property="userName"),
		@Result(column="description",property="description")
	})
	public User findUser(@Param("userName") String userName);
}

(5)业务层

@Service
public class CityServiceImpl implements UserService {

	// 注入dao
	@Autowired
	private CityDao cityDao;

	@Autowired
	private UserDao userDao;

	@Override
	public User findUserName(String userName) {

		User user = userDao.findUser(userName);
		City city = cityDao.findCity("杭州市");
		user.setCity(city);
		return user;
	}

}

(6)控制层

@RestController
public class UserRestController {

	// 注入业务
	@Autowired
	private UserService userService;

	/**
	 * 返回JSON
	 * 
	 * @param cityName
	 * @return
	 */
	@RequestMapping(value = "/my/user", method = RequestMethod.GET)
	public User findUser(
			@RequestParam(value = "userName", required = true) String userName) {
		return userService.findUserName(userName);
	}

}

效果:







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值