SpringBoot入门学习(八) ~~ 热部署集成DataSource

目录

 

SpringBoot集成DataSource

一、Spring-boot-starter-parent依赖介绍

二、基成DataSource


SpringBoot集成DataSource

  • 一、Spring-boot-starter-parent依赖介绍

SpringBoot依赖格式介绍

 

  • 二、基成DataSource

【准备工作:】这里使用Druid的数据源,在github上搜索“druid”出现:

选择右边的 alibaba/druid

拉倒最下面,选在SpringBootstart文档:

点击到这个页面:

这样就大概知道druid是如何使用了。

 

 

1、引入依赖文件

<dependency>
   <groupId>com.alibaba</groupId>
   <artifactId>druid-spring-boot-starter</artifactId>
   <version>1.1.4</version>
</dependency>

<dependency>
   <groupId>mysql</groupId>
   <artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

2、编写一个简单控制类

@Controller

  public class DataSourceController {

   @Autowired

   private DataSource dataSource;

   @RequestMapping("/druidDataSource")

   @ResponseBody

   public String dataSourcePage() throws  Exception{

      System.out.println(0.123);

      System.out.println(dataSource.getConnection());

      System.out.println(dataSource);

      return "hello druidDataSource";

  

   }

}

3、在核心配置类,创建一个Bean,指定它的配置参数

@SpringBootApplication

  public class DataSourceApplication {

  

   @Bean

   @ConfigurationProperties("db")

   public DataSource dataSource(){

      return new DruidDataSource();

   }

  

   public static void main(String[] args) {

      SpringApplication.run(DataSourceApplication.class,args);

   }

}

4、启动SpringBoot项目,尝试去访问druidDataSource

如果说没有报错,能够正常访问表示ok的。但是这种方式呢!是我们手动创建的方式而不是利用SpringBoot自动创建的方式。

 

改造为:

       删除Application中的@Bean

@SpringBootApplication

  public class DataSourceApplication {

  

   public static void main(String[] args) {

      SpringApplication.run(DataSourceApplication.class,args);

   }

}

 

       直接在配置文件中配置:

spring.datasource.druid.url=jdbc:mysql://192.168.9.102:3306/paycenter

  spring.datasource.druid.username=root

  spring.datasource.druid.password=123456

  spring.datasource.druid.driver-class-name=com.mysql.jdbc.Driver

  spring.datasource.druid.initial-size=5

//配置初始连接数为5

尝试去访问,表示ok

这种方式呢!它是利用SpringBoot自动注入的原因,稍后会详细分析自动注入原理。因为引入了Druid,它检查到存在该druiDataSource类,它会检测我们是否手动创建了该@Bean,如果没有的话,它就会自动帮我们创建,在创建的时候,它依赖于一些连接参数,这些参数的属性值是固定的,它会去读取配置文件,完成自动配置的效果。

在Spring Boot中集成dynamic-datasource可以帮助我们实现动态数据源切换的功能。面是一些基本步骤: 1. 添加依赖:在pom.xml文件中添加dynamic-datasource的依赖。 ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>dynamic-datasource-spring-boot-starter</artifactId> <version>latest-version</version> </dependency> ``` 2. 配置数据源:在application.properties或application.yml文件中配置数据源信息。 ```properties # 数据源1 spring.datasource.dynamic.datasource.master.url=jdbc:mysql://localhost:3306/db1 spring.datasource.dynamic.datasource.master.username=root spring.datasource.dynamic.datasource.master.password=123456 spring.datasource.dynamic.datasource.master.driver-class-name=com.mysql.jdbc.Driver # 数据源2 spring.datasource.dynamic.datasource.slave.url=jdbc:mysql://localhost:3306/db2 spring.datasource.dynamic.datasource.slave.username=root spring.datasource.dynamic.datasource.slave.password=123456 spring.datasource.dynamic.datasource.slave.driver-class-name=com.mysql.jdbc.Driver ``` 3. 配置动态数据源:创建一个配置类,用于配置动态数据源。 ```java @Configuration public class DynamicDataSourceConfig { @Primary @Bean("dynamicDataSource") @ConfigurationProperties(prefix = "spring.datasource.dynamic") public DataSource dynamicDataSource() { return new DruidDataSource(); } @Bean public DataSourceTransactionManager transactionManager(@Qualifier("dynamicDataSource") DataSource dataSource) { return new DataSourceTransactionManager(dataSource); } @Bean public SqlSessionFactory sqlSessionFactory(@Qualifier("dynamicDataSource") DataSource dataSource) throws Exception { MybatisSqlSessionFactoryBean sessionFactory = new MybatisSqlSessionFactoryBean(); sessionFactory.setDataSource(dataSource); return sessionFactory.getObject(); } } ``` 4. 使用动态数据源:在需要使用数据源的地方,通过注解`@DS`指定数据源。 ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override @DS("master") // 使用master数据源 public List<User> getMasterUsers() { return userMapper.getUsers();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值