# sharding-jdbc(ShardingSphere)读写分离的配置与使用 \> sharding-jdbc(ShardingSphere) 采用无中心化架构,是一套开源的分布式数据库解决方案组成的生态圈,它由 JDBC、Proxy 和 Sidecar(规划中)这 3 款既能够独立部署,又支持混合部署配合使用的产品组成。 它们均提供标准化的数据水平扩展、分布式事务和分布式治理等功能,可适用于如 Java 同构、异构语言、云原生、 Java 开发的高性能的轻量级 OLTP(连接事务处理)等各种多样化的应用场景。 \> #### 1.导入依赖 \`\`\`java org.apache.shardingsphere sharding-jdbc-spring-boot-starter 4.1.1 \`\`\` 2.配置yml文件 \`\`\`java spring: shardingsphere: datasource: names: master,slave # 主数据源 master: type: com.alibaba.druid.pool.DruidDataSource driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://192.168.88.131:3306/ruijiwaimai?serverTimezone=Asia/Shanghai\&useUnicode=true\&characterEncoding=utf-8\&zeroDateTimeBehavior=convertToNull\&useSSL=false\&allowPublicKeyRetrieval=true username: root password: Hgh675667% # 从数据源 slave: type: com.alibaba.druid.pool.DruidDataSource driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://192.168.88.132:3306/ruijiwaimai?serverTimezone=Asia/Shanghai\&useUnicode=true\&characterEncoding=utf-8\&zeroDateTimeBehavior=convertToNull\&useSSL=false\&allowPublicKeyRetrieval=true username: root password: Hgh675667% masterslave: # 读写分离配置 load-balance-algorithm-type: round_robin # 负载均衡算法:轮询 # 最终的数据源名称 name: dataSource # 主库数据源名称 master-data-source-name: master # 从库数据源名称列表,多个逗号分隔 slave-data-source-names: slave props: sql: show: true #开启SQL显示,默认false main: allow-bean-definition-overriding: true # 允许Bean覆盖:避免创建多个数据源导致数据源冲突 \`\`\`