Sharding-Jdbc如何配置主從讀寫分離模式
Sharding-Jdbc 配置主從模式
我們項(xiàng)目的讀寫分離的主從模式項(xiàng)目中一般可以分為多種方式來實(shí)現(xiàn),可以手動(dòng)在代碼 Java 中配置多種數(shù)據(jù)源來實(shí)現(xiàn)讀寫分離的模式,我們也可以通過第三方的框架來實(shí)現(xiàn)讀寫分離例如我們的 Sharding-jdbc,也可以是我們的MyCat的來實(shí)現(xiàn)讀寫分離。
- Java 代碼的方式配置多種數(shù)據(jù)源
- Sharding-Jdbc
- MyCat
今天我們就來講解一下如何使用 Sharding-jdbc 來實(shí)現(xiàn)讀寫分離。
使用 YMAL 方式來實(shí)現(xiàn)配置。
配置 master 數(shù)據(jù)源和 slave 數(shù)據(jù)源。我們這次是的方案是一主多從的方式來實(shí)現(xiàn)讀寫分離,mysql 的主從搭建我們這次就不說了。
我們這次就是主要來實(shí)現(xiàn) sharding-jdbc 的方式來實(shí)現(xiàn)讀寫分離
Sharding-jdbc 讀寫分離配置
我們首先要引入 MAVEN 依賴
<dependency>
<groupId>org.apache.shardingsphere</groupId>
<artifactId>shardingsphere-jdbc-core-spring-boot-starter</artifactId>
<version>5.1.1</version>
</dependency>我們這次使用的版本是比較新的版本。
配置數(shù)據(jù)源以及數(shù)據(jù)源的名字
spring:
shardingsphere:
# 內(nèi)存模式
mode:
type: Memory
# 數(shù)據(jù)源配置
datasource:
names: master,slave
# 主數(shù)據(jù)源
master:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.jc.mysql.Driver
jdbc-url: jdbc:mysql://localhost:3306/shardingjdbc?allowPublicKeyRetrieval=true
username: root
password: 123456
# 從機(jī)數(shù)據(jù)源
slave:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.jc.mysql.Driver
jdbc-url: jdbc:mysql://localhost:3306/shardingjdbc?allowPublicKeyRetrieval=true
username: root
password: 123456主要是配置數(shù)據(jù)源的鏈接地址和賬戶以及密碼。
讀寫分離的策略
spring:
shardingsphere:
rules:
readwrite-splitting:
data-sources:
mydatasource:
# 類型是靜態(tài)還是動(dòng)態(tài)
type: Static
props:
# 寫入數(shù)據(jù)
write-data-source-name: master
# 讀數(shù)據(jù)
read-data-source-names: slave
# 使用的邏輯策略
load-balancer-name: round-alg
# 負(fù)載均衡策略
load-balancers:
# 輪詢
round-alg:
type: ROUND_ROBIN這里的是配置寫數(shù)據(jù)和讀數(shù)據(jù)使用的數(shù)據(jù)源
完整配置
spring:
shardingsphere:
mode:
type: Memory
# 數(shù)據(jù)源配置
datasource:
names: master,slave
# 主數(shù)據(jù)源
master:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.jc.mysql.Driver
jdbc-url: jdbc:mysql://localhost:3306/shardingjdbc?allowPublicKeyRetrieval=true
username: root
password: 123456
# 從機(jī)數(shù)據(jù)源
slave:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.jc.mysql.Driver
jdbc-url: jdbc:mysql://localhost:3306/shardingjdbc?allowPublicKeyRetrieval=true
username: root
password: 123456
rules:
readwrite-splitting:
data-sources:
mydatasource:
# 類型是靜態(tài)還是動(dòng)態(tài)
type: Static
props:
write-data-source-name: master
read-data-source-names: slave
# 使用的邏輯策略
load-balancer-name: round-alg
# 負(fù)載均衡策略
load-balancers:
# 輪詢
round-alg:
type: ROUND_ROBIN
# 隨機(jī)
random-alg:
type: RANDOM
# 權(quán)重,我們?cè)谂渲脵?quán)重的時(shí)候必須配置各個(gè) slave 的權(quán)重值,值的數(shù)據(jù)類型為 double
weight-alg:
type: WEIGHT
props:
slave: 1.0
props:
show-sql: true
結(jié)束!
中間我在啟動(dòng)的時(shí)候遇到一個(gè) mysql 的連接異常
Public Key Retrieval is not allowed
這種情況可以配置參數(shù)的時(shí)候設(shè)置連接參數(shù) ?allowPublicKeyRetrieval=true
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
解析如何用兩個(gè)棧來實(shí)現(xiàn)隊(duì)列的方法
本篇文章是對(duì)如何用兩個(gè)棧實(shí)現(xiàn)隊(duì)列的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
JAXB命名空間及前綴_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要給大家介紹了關(guān)于JAXB命名空間及前綴的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08
Java可變個(gè)數(shù)形參的方法實(shí)例代碼
這篇文章主要給大家介紹了關(guān)于Java可變個(gè)數(shù)形參的相關(guān)資料,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-02-02
JavaApi實(shí)現(xiàn)更新刪除及讀取節(jié)點(diǎn)
這篇文章主要介紹了JavaApi實(shí)現(xiàn)更新刪除及讀取節(jié)點(diǎn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
Java8新特性之Base64詳解_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了Java8新特性之Base64的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
SpringMVC深入講解文件的上傳下載實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了springMVC實(shí)現(xiàn)文件上傳和下載的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
java向上轉(zhuǎn)型發(fā)生的時(shí)機(jī)知識(shí)點(diǎn)詳解
在本篇文章里小編給大家整理分享的是關(guān)于java向上轉(zhuǎn)型發(fā)生的時(shí)機(jī)知識(shí)點(diǎn)內(nèi)容,有興趣的讀者們可以參考下。2021-05-05
使用mybatis-plus的insert方法遇到的問題及解決方法(添加時(shí)id值不存在異常)
這篇文章主要介紹了使用mybatis-plus的insert方法遇到的問題及解決方法(添加時(shí)id值不存在異常),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08

