谈数据库的读写分离及springboot连接多个数据库

摘要 数据库的写速度远远慢于读的速度。读写分离设计- 主库写,从库读。主从库通过binlog复制。springboot连接多个数据库

属于 :API 标签: 发布于:2019-12-23 17:29:25

数据库的写速度远远慢于读的速度。

读写分离设计- 主库写,从库读。主从库通过binlog复制。

springboot连接多个数据库

application.properties

spring.datasource.primary.jdbc-url=jdbc:mysql://xxx1/xxx
spring.datasource.primary.username=xxx
spring.datasource.primary.password=xxx

spring.datasource.secondary.jdbc-url=jdbc:mysql://xxx.xxx.xxx.xxx:xxxx/xxx
spring.datasource.secondary.username = xxxx
spring.datasource.secondary.password = xxxx

dataSourceConfig

import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.boot.jdbc.DataSourceBuilder;

@Configuration
public class DataSourceConfig {

    @Bean(name = "primaryDataSource")
    @Qualifier("primaryDataSource")
    @ConfigurationProperties(prefix="spring.datasource.primary")
    public DataSource primaryDataSource() {
            return DataSourceBuilder.create().build();
    }

    @Bean(name = "secondaryDataSource")
    @Qualifier("secondaryDataSource")
    @Primary
    @ConfigurationProperties(prefix="spring.datasource.secondary")
    public DataSource secondaryDataSource() {
        return DataSourceBuilder.create().build();      
    }


    @Bean(name="primaryJdbcTemplate")
    public JdbcTemplate primaryJdbcTemplate (@Qualifier("primaryDataSource")  DataSource dataSource ) {
        return new JdbcTemplate(dataSource);
    }

    @Bean(name="secondaryJdbcTemplate")
    public JdbcTemplate  secondaryJdbcTemplate(@Qualifier("secondaryDataSource") DataSource dataSource) {
        return new JdbcTemplate(dataSource);
    }

}

dao层

@Autowired
@Qualifier("primaryJdbcTemplate")public JdbcTemplate jdbcTemplate;