天天看點

ShardingSphere5入門實戰(三)之sharding-jdbc垂直分片

垂直分庫:根據業務将資料庫進行拆分,比如使用者表在使用者資料庫中,訂單表在訂單資料庫中

  • 伺服器:容器名server-user,端口3301
  • 伺服器:容器名server-order,端口3302

還是通過docker容器來進行建立(建立之前一定要先開放端口然後重新開機伺服器使端口生效)

第一步:建立server-user容器

step1:建立容器:

docker run -d \
-p 3301:3306 \
-v /atguigu/server/user/conf:/etc/mysql/conf.d \
-v /atguigu/server/user/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
--name server-user \
mysql:8.0.29      

step2:登入mysql伺服器

#進入容器:
docker exec -it server-user env LANG=C.UTF-8 /bin/bash


#進入容器内的mysql指令行
mysql -uroot -p


#修改預設密碼插件
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';      

step3:建立資料庫

CREATE DATABASE db_user;
USE db_user;
CREATE TABLE t_user (
 id BIGINT AUTO_INCREMENT,
 uname VARCHAR(30),
 PRIMARY KEY (id)
);      

第二步:建立server-order容器

step1:建立容器:

docker run -d \
-p 3302:3306 \
-v /atguigu/server/order/conf:/etc/mysql/conf.d \
-v /atguigu/server/order/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
--name server-order \
mysql:8.0.29      

step2:登入mysql伺服器

#進入容器:
docker exec -it server-order env LANG=C.UTF-8 /bin/bash

#進入容器内的mysql指令行
mysql -uroot -p

#修改預設密碼插件
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';      

step3:建立資料庫

CREATE DATABASE db_order;
USE db_order;
CREATE TABLE t_order (
  id BIGINT AUTO_INCREMENT,
  order_no VARCHAR(30),
  user_id BIGINT,
  amount DECIMAL(10,2),
  PRIMARY KEY(id) 
);      

第三步:編寫程式

1、建立實體類Order(User實體類在上一篇文章已經建立)

ShardingSphere5入門實戰(三)之sharding-jdbc垂直分片

2.建立OrderMapper

ShardingSphere5入門實戰(三)之sharding-jdbc垂直分片

 3.資料分片配置,官方配置文檔:​​資料分片 :: ShardingSphere​​

# 記憶體模式--實際項目中請配置叢集模式
spring.shardingsphere.mode.type=Memory

# 配置真實資料源-名字自己起
spring.shardingsphere.datasource.names=server-order,server-user

# 配置第 1 個資料源
spring.shardingsphere.datasource.server-order.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.server-order.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.server-order.jdbc-url=jdbc:mysql://ip:3302/db_order
spring.shardingsphere.datasource.server-order.username=root
spring.shardingsphere.datasource.server-order.password=123456

# 配置第 2 個資料源
spring.shardingsphere.datasource.server-user.type=com.zaxxer.hikari.HikariDataSource
spring.shardingsphere.datasource.server-user.driver-class-name=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.server-user.jdbc-url=jdbc:mysql://ip:3301/db_user
spring.shardingsphere.datasource.server-user.username=root
spring.shardingsphere.datasource.server-user.password=123456

# 标準分片表配置
spring.shardingsphere.rules.sharding.tables.t_user.actual-data-nodes= server-user.t_user
spring.shardingsphere.rules.sharding.tables.t_order.actual-data-nodes= server-order.t_order


# 列印SQl
spring.shardingsphere.props.sql-show=true      

4.寫代碼插入t_user表和t_order表資料

ShardingSphere5入門實戰(三)之sharding-jdbc垂直分片

 然後啟動服務浏覽器通路:​​http://localhost:8080/sharding/jdbc/testInsertUserAndOrder​​