伤心客 发表于 2025-1-5 12:38:51

Spring Boot 3 实现 MySQL 主从数据库之间的数据同步

✅ Spring Boot 3 实现 MySQL 主从数据库之间的数据同步

在现实项目中,为了提高 系统的读性能 和 数据的可用性,通常会使用 主从数据库架构。Spring Boot 提供了对 多数据源 的良好支持,可以轻松设置 主从数据库 的数据同步,实现 读写分离。
<hr> 方案介绍

我们将通过 Spring Boot 3 来实现以下目的:

[*]主库(Master):处置惩罚所有的 写操作(INSERT、UPDATE、DELETE)。
[*]从库(Slave):处置惩罚所有的 读操作(SELECT)。
通过 读写分离 的方式,我们可以有效减轻主库的压力,同时提升系统的读性能。
<hr> 步骤 1:设置 MySQL 主从同步

首先,确保你的 MySQL 主从服务器已经设置好。
假如你还没有设置主从,请参考以下步骤:

[*]在 主库 上启用 binlog 日志。
[*]在 从库 上设置 CHANGE MASTER TO 语句。
具体设置可以参考这里的指南:
MySQL 主从同步设置
<hr> 步骤 2:Spring Boot 多数据源设置

1️⃣ 添加依赖

在 pom.xml 文件中添加 MySQL 驱动 和 Spring Data JPA 依赖。
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>
<hr> 2️⃣ 设置 application.properties

设置 主库 和 从库 的数据源。
# 主库数据源
spring.datasource.master.url=jdbc:mysql://localhost:3306/master_db
spring.datasource.master.username=root
spring.datasource.master.password=master_password
spring.datasource.master.driver-class-name=com.mysql.cj.jdbc.Driver

# 从库数据源
spring.datasource.slave.url=jdbc:mysql://localhost:3306/slave_db
spring.datasource.slave.username=root
spring.datasource.slave.password=slave_password
spring.datasource.slave.driver-class-name=com.mysql.cj.jdbc.Driver
<hr> 3️⃣ 设置多数据源

创建 MasterDataSourceConfig

@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
      basePackages = "com.example.repository",
      entityManagerFactoryRef = "masterEntityManager",
      transactionManagerRef = "masterTransactionManager"
)
public class MasterDataSourceConfig {
   

    @Primary
    @Bean(name = "masterDataSource")
    @ConfigurationProperties(prefix =
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: Spring Boot 3 实现 MySQL 主从数据库之间的数据同步