垂直分庫:根據業務将資料庫進行拆分,比如使用者表在使用者資料庫中,訂單表在訂單資料庫中
- 伺服器:容器名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實體類在上一篇文章已經建立)
2.建立OrderMapper
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表資料
然後啟動服務浏覽器通路:http://localhost:8080/sharding/jdbc/testInsertUserAndOrder