SpringBoot2(2),原创Kafka学习笔记

二、配置&初始化数据源

==========================================================================

接下来,在 application.properties 中配置数据源,不同于上篇文章,这里的数据源需要配置两个,如下:

spring.datasource.master.jdbc-url = jdbc:mysql://139.196.20.xxx:3306/spring_boot1?useUnicode=true&characterEncoding=utf-8

spring.datasource.master.username = root

spring.datasource.master.password = 123456

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

spring.datasource.slave.jdbc-url = jdbc:mysql://139.196.20.xxx:3306/spring_boot2?useUnicode=true&characterEncoding=utf-8

spring.datasource.slave.username = root

spring.datasource.slave.password = 123456

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

这里通过 master 和 slave 对数据源进行了区分,但是加了 master 和 slave 之后,这里的配置就没法被 SpringBoot 自动加载了 (因为前面的 key 变了),需要我们自己去加载 DataSource 了,此时,需要自己配置一个 DataSourceConfig,用来提供两个 DataSource Bean,如下:

@Configuration

public class DataSourceConfiguration {

@Primary

@Bean

@ConfigurationProperties(prefix = “spring.datasource.master”)

public DataSource masterDataSource() {

return DataSo 需要zi料+ 绿色徽【vip1024b】

urceBuilder.create().build();

}

@Bean

@ConfigurationProperties(prefix = “spring.datasource.slave”)

public DataSource slaveDataSource() {

return DataSourceBuilder.create().build();

}

@Bean

public JdbcTemplate masterJdbcTemplate(@Qualifier(“masterDataSource”) DataSource masterDataSource) {

return new JdbcTemplate(masterDataSource);

}

@Bean

public JdbcTemplate slaveJdbcTemplate(@Qualifier(“slaveDataSource”) DataSource slaveDataSource) {

return new JdbcTemplate(slaveDataSource);

}

}

这里提供了两个 Bean, @ConfigurationProperties(prefix = “spring.datasource.master”) 表示使用 spring.datasource.master 前缀的数据库配置去创建一个 DataSource,这样配置之后,我们就有了两个不同的 DataSource,然后再用这两个不同的 DataSource 去创建两个不同的 JdbcTemplate。

每一个 JdbcTemplate 的创建都需要一个 DataSource,由于 Spring 容器中现在存在两个 DataSource,默认使用类型查找,会报错,因此加上 @Qualifier 注解,表示按照名称查找。这里创建了两个 JdbcTemplate 实例,分别对应了两个 DataSource。

三、准备测试数据

=======================================================================

创建spring_boot1、spring_boot2两个数据库

spring_boot1

CREATE TABLE spring_boot1.article (

id int(11) NOT NULL AUTO_INCREMENT,

title varchar(255) NULL COMMENT ‘文章标题’,

author varchar(255) NULL COMMENT ‘作者’,

PRIMARY KEY (id)

) COMMENT = ‘文章表’;

INSERT INTO spring_boot1.article(id, title, author) VALUES (1, ‘master’, ‘Java程序鱼’);

spring_boot2

CREATE TABLE spring_boot2.article (

id int(11) NOT NULL AUTO_INCREMENT,

title varchar(255) NULL COMMENT ‘文章标题’,

author varchar(255) NULL COMMENT ‘作者’,

PRIMARY KEY (id)

) COMMENT = ‘文章表’;

INSERT INTO spring_boot2.article(id, title, author) VALUES (1, ‘slave’, ‘Java程序鱼’);

四、核心代码

=====================================================================

@RestController

难道这样就够了吗?不,远远不够!

提前多熟悉阿里往年的面试题肯定是对面试有很大的帮助的,但是作为技术性职业,手里有实打实的技术才是你面对面试官最有用的利器,这是从内在散发出来的自信。

备战阿里时我花的最多的时间就是在学习技术上,占了我所有学习计划中的百分之70,这是一些我学习期间觉得还是很不错的一些学习笔记

我为什么要写这篇文章呢,其实我觉得学习是不能停下脚步的,在网络上和大家一起分享,一起讨论,不单单可以遇到更多一样的人,还可以扩大自己的眼界,学习到更多的技术,我还会在csdn、博客、掘金等网站上分享技术,这也是一种学习的方法。

今天就分享到这里了,谢谢大家的关注,以后会分享更多的干货给大家!

阿里一面就落马,恶补完这份“阿里面试宝典”后,上岸蚂蚁金服

阿里一面就落马,恶补完这份“阿里面试宝典”后,上岸蚂蚁金服

image.png

学习到更多的技术,我还会在csdn、博客、掘金等网站上分享技术,这也是一种学习的方法。

今天就分享到这里了,谢谢大家的关注,以后会分享更多的干货给大家!

[外链图片转存中…(img-R94fiqWc-1710369115484)]

[外链图片转存中…(img-wXBrwPQB-1710369115484)]

[外链图片转存中…(img-coxztJgl-1710369115485)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值