ShardingSphere-Proxy 数据库中间件MySql分库分表环境搭建
一. ShardingSphere-Proxy简介
1、简介
Apache ShardingSphere 是一款开源分布式数据库生态项目,旨在碎片化的异构数据库上层构建生态,在最大限度的复用数据库原生存算能力的前提下,进一步提供面向全局的扩展和叠加计算能力。其核心采用可插拔架构,对上以数据库协议及 SQL 方式提供诸多增强功能,包括数据分片、访问路由、数据安全等
ShardingSphere-Proxy是跨语言的数据库代理服务端,主要用来处理:分表、分库、读写分离 等。 【默认端口 3307 】
官网地址:https://shardingsphere.apache.org/index_zh.html
2、 什么是分表?
MySQL的InnoDB引擎采用B+ Tree的结构进行数据存储,单张表的极限为2000w,超过这个数量,性能就会下降,从而引出分表的方案。
比如原先将原先的t_order订单表可以拆分为 t_order_1 、t_order_2 等多张表。
3、什么是分库?
从并发量角度思考,如果客户端查询数据并发量比较大,超过了数据库的并发处理能力,就会导致数据库性能下降(因为数据库本身使用的系统资源还是有限的,例如内存资源,CPU资源,磁盘资源等等,都有限,所以导致数据库并发处理能力有限),从而引出分库的概念。
比如原先的商品数据库 GoodsDB,可以拆分为 GoodsDB1、GoodsDB2 等多个数据库。
4、什么是分库分表?
当分库后,但表中的数据量依旧很大,超过2000w,这个时候就需要在分库的基础上,进行分表。
通常分库分表同时使用。
即: GoodsDB1库中有:t_order_1 、t_order_2表, GoodsDB2库中也有:t_order_1 、t_order_2表,
5、常用方案
(1). 进程内方案
使用EFCore进行链接,可以实现分库分表、读写分离。 缺点:资源竞争
(2). 进程外方案
A. MyCat 缺点:配置麻烦
B. ShardingSphere 优点:配置简单
二. ShardingSphere-Proxy 环境准备
1、环境准备
(1)、数据库:MySqL 参考地址 七、阿里云 Linux CentOs7安装MySql
(2)、Java Jdk环境:参考地址 五、Linux安装Java环境
(3)、ShardingSphere-Proxy代理程序(5.5.0): (下载地址: https://shardingsphere.apache.org/document/current/cn/downloads/)

(4)、连接MySQL的驱动:mysql-connector-java-8.0.11.jar (下载地址:https://repo1.maven.org/maven2/mysql/mysql-connector-java/)

2、部署:(1)、上传shardingsphere-proxy压缩包,解压;(2)、将mysql-connector-java-8.0.11.jar拷贝到 lib 目录
tar -zxvf apache-shardingsphere-5.5.0-shardingsphere-proxy-bin.tar.gz


3、启动 ShardingSphere-Proxy(bin目录)
cd /usr/local/shardingsphere/apache-shardingsphere-5.5.0-shardingsphere-proxy-bin/bin
./start.sh #开启
./stop.sh #关闭

三. ShardingSphere-Proxy 操作
1、配置shardingsphere的访问账户和密码(文件:conf/global.yaml)
该账号用于客户端连接该代理程序使用,与数据库的账号密码没有任何关系。
vim global.yaml
authority:users:- user: root@%password: root- user: shardingpassword: shardingprivilege:type: ALL_PERMITTEDtransaction:defaultType: XAproviderType: Atomikos

2、配置分表规则(文件:conf/database-sharding.yaml)
vim database-sharding.yaml
databaseName: xinyu_proxy_dbdataSources:ds_0:url: jdbc:mysql://192.168.30.165:3306/xinyudb?serverTimezone=UTC&useSSL=falseusername: rootpassword: Cdxyks!@#Sxyd5648connectionTimeoutMilliseconds: 30000idleTimeoutMilliseconds: 60000maxLifetimeMilliseconds: 1800000maxPoolSize: 50minPoolSize: 1ds_1:url: jdbc:mysql://192.168.30.166:3306/xinyudb?serverTimezone=UTC&useSSL=falseusername: rootpassword: Cdxyks!@#Sxyd5648connectionTimeoutMilliseconds: 30000idleTimeoutMilliseconds: 60000maxLifetimeMilliseconds: 1800000maxPoolSize: 50minPoolSize: 1rules:
- !SHARDINGtables:t_order:actualDataNodes: ds_${0..1}.t_order_${0..1}tableStrategy:standard:shardingColumn: order_idshardingAlgorithmName: t_order_inlinekeyGenerateStrategy:column: order_idkeyGeneratorName: snowflakeauditStrategy:auditorNames:- sharding_key_required_auditorallowHintDisable: truet_order_item:actualDataNodes: ds_${0..1}.t_order_item_${0..1}tableStrategy:standard:shardingColumn: order_idshardingAlgorithmName: t_order_item_inlinekeyGenerateStrategy:column: order_item_idkeyGeneratorName: snowflakebindingTables:- t_order,t_order_itemdefaultDatabaseStrategy:standard:shardingColumn: user_idshardingAlgorithmName: database_inlinedefaultTableStrategy:none:defaultAuditStrategy:auditorNames:- sharding_key_required_auditorallowHintDisable: trueshardingAlgorithms:database_inline:type: INLINEprops:algorithm-expression: ds_${user_id % 2}t_order_inline:type: INLINEprops:algorithm-expression: t_order_${order_id % 2}t_order_item_inline:type: INLINEprops:algorithm-expression: t_order_item_${order_id % 2}keyGenerators:snowflake:type: SNOWFLAKEauditors:sharding_key_required_auditor:type: DML_SHARDING_CONDITIONS


3、Navicate客户端连接,创建订单,插入数据
(1)、SQL操作
create table t_order(order_id BIGINT COMMENT '订单编号', #order_id 分表order_name varchar(150) COMMENT '订单名称',user_id int COMMENT '用户ID', #user_id 分库cdt DATETIME COMMENT '订单时间',
PRIMARY KEY(order_id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;drop table t_order;
truncate table t_order;insert into t_order values('订单1-1',1,now());
insert into t_order values('订单1-2',1,now());
insert into t_order values('订单1-3',1,now());
insert into t_order values('订单1-4',1,now());
insert into t_order values('订单1-5',1,now());
insert into t_order values('订单1-6',1,now());
insert into t_order values('订单1-7',1,now());
insert into t_order values('订单1-8',1,now());
insert into t_order values('订单1-9',1,now());
insert into t_order values('订单1-10',1,now());insert into t_order values('订单2-1',2,now());
insert into t_order values('订单2-2',2,now());
insert into t_order values('订单2-3',2,now());
insert into t_order values('订单2-4',2,now());
insert into t_order values('订单2-5',2,now());
insert into t_order values('订单2-6',2,now());
insert into t_order values('订单2-7',2,now());
insert into t_order values('订单2-8',2,now());
insert into t_order values('订单2-9',2,now());
insert into t_order values('订单2-10',2,now());select * from t_order where user_id=1;select * from t_order where order_id=1053673476138729473;
select * from t_order where order_id=1053673476323278849;select * from t_order where user_id=2 order by order_id desc limit 0,10;

(2)、查看数据分布
数据库0
user_id=2%2=0,所以在“ds_0”库
表:t_order_0

表:t_order_1

数据库1
user_id=1%2=1,所以在”ds_1”库
表:t_order_0

表:t_order_1

相关文章:
ShardingSphere-Proxy 数据库中间件MySql分库分表环境搭建
一. ShardingSphere-Proxy简介 1、简介 Apache ShardingSphere 是一款开源分布式数据库生态项目,旨在碎片化的异构数据库上层构建生态,在最大限度的复用数据库原生存算能力的前提下,进一步提供面向全局的扩展和叠加计算能力。其核心采用可插…...
Pytest+selenium UI自动化测试实战实例
🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快 今天来说说pytest吧,经过几周的时间学习,有收获也有疑惑,总之最后还是搞个小项目出来证明自己的努力不没有白费 环境准备 1 …...
服务器技术研究分析:存储从HBM到CXL
服务器变革:存储从HBM到CXL 在《从云到端,AI产业的新范式(2024)》中揭示,传统服务器价格低至1万美金,而配备8张H100算力卡的DGX H100AI服务器价值高达40万美金(约300万人民币)。 从供…...
下载并安装 WordPress 中文版
下载并安装 WordPress 中文版 1. 安装 LAMP 环境(Linux, Apache, MySQL, PHP)1. 安装 Apache2. 安装 MySQL3. 安装 PHP1. 下载并安装 WordPress 中文版1. 下载 WordPress2. 配置文件权限3 . 创建 MySQL 数据库4 . 配置 WordPress1. 安装 LAMP 环境(Linux, Apache, MySQL, PH…...
从零开始的LeetCode刷题日记:515.在每个树行中找最大值
一.相关链接 题目链接:515.在每个树行中找最大值 二.心得体会 这道题也是层序遍历,只需要记录每一层的最大值即可,反复比较记录最大值。 三.代码 class Solution { public:vector<int> largestValues(TreeNode* root) {vector<…...
C语言 | Leetcode C语言题解之第492题构造矩形
题目: 题解: class Solution { public:vector<int> constructRectangle(int area) {int w sqrt(1.0 * area);while (area % w) {--w;}return {area / w, w};} };...
在FastAPI网站学python:虚拟环境创建和使用
Python虚拟环境(virtual environment)是一个非常重要的工具,它允许开发者为每个项目创建独立的Python环境,隔离您为每个项目安装的软件包,从而避免不同项目之间的依赖冲突。 学习参考FastAPI官网文档:Virt…...
安全风险评估(Security Risk Assessment, SRA)
安全风险评估(Security Risk Assessment, SRA)是识别、分析和评价信息安全风险的过程。它帮助组织了解其信息资产面临的潜在威胁,以及这些威胁可能带来的影响。通过风险评估,组织可以制定有效的风险管理策略,以减少或控…...
SQL Injection | SQL 注入 —— 布尔盲注
关注这个漏洞的其他相关笔记:SQL 注入漏洞 - 学习手册-CSDN博客 0x01:布尔盲注 —— 理论篇 布尔盲注(Boolean-Based Blind Injection)是一种常见的 SQL 注入技术,它适用于那些 SQL 注入时,查询结果不会直…...
stm32 bootloader写法
bootloader写法: 假设app的起始地址:0x08020000,则bootloader的范围是0x0800,0000~0x0801,FFFF。 #define APP_ADDR 0x08020000 // 应用程序首地址定义 typedef void (*APP_FUNC)(void); // 函数指针类型定义 /*main函数中调用rum_app&#x…...
Unity3D 物体表面水滴效果详解
在游戏开发中,逼真的水滴效果能够显著提升游戏场景的真实感和沉浸感。Unity3D作为一款强大的游戏开发引擎,提供了丰富的工具和技术来实现这种效果。本文将详细介绍如何在Unity3D中实现物体表面的水滴效果,包括技术详解和代码实现。 对惹&…...
若依框架中spring security的完整认证流程,及其如何使用自定义用户表进行登录认证,学会轻松实现二开,嘎嘎赚块乾
1)熟悉之前的SysUser登录流程 过滤器链验证配置 这里security过滤器链增加了前置过滤器链jwtFilter 该过滤器为我们自定义的,每次请求都会经过jwt验证 ok我们按ctrl alt B跳转过去来看下 首先会获取登录用户LoginUser 内部通过header键,获…...
selenium:操作滚动条的方法(8)
selenium支持几种操作滚动条的方法,主要介绍如下: 使用ActionChains 类模拟鼠标滚轮操作 使用函数ActionChains.send_keys发送按键Keys.PAGE_DOWN往下滑动页面,发送按键Keys.PAGE_UP往上滑动页面。 from selenium import webdriver from se…...
Discuz | 起尔开发 传奇开服表游戏公益服发布论坛网站插件
Discuz | 起尔开发 传奇开服表游戏公益服发布论坛网站插件 插件下载:源码 - 起尔开发的插件下载 演示地址:discuz.72jz.com 标黄和非标黄自动分开 在标黄时间内显示在上面置顶,标黄过期后自动显示在下面白色区域。 后台可以设置非标黄默认…...
问:JAVA对象的数据结构长啥样?
Java 对象在内存中的结构是一个复杂且精细的设计,它不仅关乎对象如何存储,还直接影响到垃圾回收(GC)、并发控制等运行时行为。一个典型的 Java 对象主要由三部分组成:对象头(Object Header)、实…...
STGCN解读(论文+代码)
一、引言 引言部分不是论文的重点,主要讲述了交通预测的重要性以及一些传统方法的不足之处。进而推出了自己的模型——STGCN。 二、交通预测与图卷积 第二部分讲述了交通预测中路图和图卷积的概念。 首先理解道路图,交通预测被定义为典型的时间序列预测…...
perl读取目录,写入文件
perl读取目录,写入文件 此脚本有两个输入参数,第一个参数为需要打印的文件目录,第二个参数为打印后的文件名; 该脚本名称为out_file_full_path #!/bin/perluse 5.010; my $dir $ARGV[0]; # 此为第一个参数; opendi…...
JDK-23与JavaFX配置在IDEA中
一、安装 1.IDEA安装,可以查看CSDN 2.JDK,JavaFX安装,可以查看CSDN 二、配置JDK 打开IDEA,选择个项目,点击图中的设置按钮: 点击项目设置: 点击“”添加JDK,寻找相应的JDK目录就行 三、配置…...
VSCode运行QT界面
VSCode用久了,感觉Qt Creator的写起代码来还是不如VSCode得心应手,虽然目前还是存在一些问题,先把目前实现的状况做个记录,后续有机会再进一步优化。 当前方式 通过QtCreator创建一个CMake项目,然后使用CMake的方式在VSCode中进行编译。 claude给出的建议 左上角的名字会…...
npm-run-all 使用实践
参考: npm-run-all 背景 在前端开发中,你是否存在以下烦恼: 写 package.json 的 scripts 命令时,命令太过冗长,例如编译命令 build 需要执行清理 clean, 编译css build:css, 编译js build:js, 编译html build:html 命令,则 bui…...
禾赛科技Linux BSP工程师面试技术要点解析
1. 禾赛科技高级Linux BSP工程师面试全解析最近参加了禾赛科技高级Linux BSP软件工程师的社招面试,整体感觉技术考察非常全面深入。作为一家专注激光雷达研发的科技公司,他们对底层系统开发能力的要求极高。下面我就把两轮技术面试中遇到的真实问题及技术…...
Qt键盘控制按钮实战:用WASD键玩转UI交互(附完整代码)
Qt键盘控制按钮实战:用WASD键玩转UI交互(附完整代码) 想象一下,当你正在开发一款自助点餐系统时,突然发现触摸屏失灵了——这种场景下,键盘控制的UI交互能力就成了救命稻草。Qt框架提供的键盘事件处理机制&…...
C语言字符串与指针操作技巧解析
1. 字符串的本质与指针操作在嵌入式开发中,字符串处理是最基础也是最重要的技能之一。很多人虽然每天都在使用字符串,但对它的本质理解却不够深入。实际上,C语言中的字符串本质上就是一个字符指针,它指向内存中连续存储的字符序列…...
AI Agent在物流与运输中的应用:路径优化与调度自动化
AI Agent在物流与运输中的应用:路径优化与调度自动化 引言 在当今快速发展的商业环境中,物流与运输行业正面临着前所未有的挑战。随着电子商务的爆发式增长,消费者对配送速度、成本和可靠性的要求越来越高。同时,全球化供应链的复杂性、燃油价格的波动以及环保法规的日益…...
eNSP启动AR报错码40终极排查指南:从Hyper-V冲突到虚拟网卡修复
1. 遇到eNSP启动AR报错码40怎么办? 最近在折腾eNSP的时候,遇到了AR设备启动报错码40的问题,按照官方帮助手册排查了一圈都没解决。这种系统级的虚拟化冲突确实让人头疼,特别是当你急着做实验的时候。经过反复测试和查阅资料&#…...
超越系统默认:ImageGlass如何重新定义图像浏览体验
超越系统默认:ImageGlass如何重新定义图像浏览体验 【免费下载链接】ImageGlass 🏞 A lightweight, versatile image viewer 项目地址: https://gitcode.com/gh_mirrors/im/ImageGlass 当你下载了一张HEIC格式的照片却无法打开,或是处…...
NifSkope终极指南:为什么这款免费开源3D模型编辑器能彻底改变你的游戏模组制作体验
NifSkope终极指南:为什么这款免费开源3D模型编辑器能彻底改变你的游戏模组制作体验 【免费下载链接】nifskope A git repository for nifskope. 项目地址: https://gitcode.com/gh_mirrors/ni/nifskope 你是否曾为《上古卷轴》或《辐射》系列的模型文件格式头…...
Linux内核中的实时调度器详解
Linux内核中的实时调度器详解 引言 实时调度器是Linux内核中负责调度实时任务的重要组件,它确保实时任务能够在规定的时间内完成,满足实时系统的时间约束。Linux内核支持多种实时调度策略,包括SCHED_FIFO、SCHED_RR和SCHED_DEADLINEÿ…...
RAG核心技术实战指南:从切片策略到召回优化的全流程解析
1. RAG技术全景解析:从原理到价值 第一次接触RAG技术时,我被它巧妙的设计思路惊艳到了。想象一下,你正在参加一场开卷考试,允许带一本参考书进场——这就是RAG给大语言模型带来的改变。传统的大模型就像闭卷考试的学生,…...
Bootstrap Switch 终极指南:如何快速创建现代化切换开关
Bootstrap Switch 终极指南:如何快速创建现代化切换开关 【免费下载链接】bootstrap-switch Turn checkboxes and radio buttons in toggle switches. 项目地址: https://gitcode.com/gh_mirrors/bo/bootstrap-switch Bootstrap Switch 是一款强大的开源工具…...
