-
轻量级Mysql Sharding中间件--Shark
- 网站名称:轻量级Mysql Sharding中间件--Shark
- 网站分类:技术文章
- 收录时间:2025-07-02 19:29
- 网站地址:
“轻量级Mysql Sharding中间件--Shark” 网站介绍
Shark简介
前身为Kratos,轻量级Mysql分库分表(Sharding)中间件,丰富的Sharding算法支持(2类4种分片算法),能够方便DBA实现库的水平扩容和降低数据迁移成本。Shark站在巨人的肩膀上(SpringJdbc、Druid),采用与应用集成架构,放弃通用性,只为换取更好的执行性能与降低分布式环境下外围系统的宕机风险。
Shark的优点
- 动态数据源的无缝切换;
- master/slave一主一从读写分离;
- Sql独立配置,与逻辑代码解耦;
- 单线程读重试(取决于的数据库连接池是否支持);
- 单独且友好支持Mysql数据库;
- 非Proxy架构,与应用集成,应用直连数据库,降低外围系统依赖所带来的宕机风险;
- 使用简单,侵入性低,站在巨人的肩膀上,依赖于SpringJdbc、Druid;
- 基于淘宝Druid的SqlParser完成Sql解析任务,解析性能高效、稳定;
- 分库分表路由算法支持2类4种分片模式,库内分片/一库一片;
- 提供自动生成全局唯一的sequenceId的API支持;
- 提供自动生成配置文件的支持,降低配置出错率;
- 提供内置验证页面,方便开发、测试以及运维对执行后的sql进行验证;
- 专注于Sharding领域,无需兼容通用性,因此核心代码量少、易读易维护;
Shark的分片模型
Shark支持2类4种分片算法:
Shark的使用注意事项
- 不支持强一致性的分布式事务,建议在业务层采用依赖MQ、异步操作等方式实现事物,保证事物的最终一致性;
- 不建议、不支持多表查询,所有多表查询sql,务必全部打散为单条sql逐条执行;
- sql语句的第一个参数务必是路由条件;
- 不支持sql语句中出现数据库别名;
- 路由条件必须是整数类型;
- 上一篇:一点感悟(一) 初识
- 下一篇:Gecco爬虫框架的线程和队列模型
更多相关网站
- window.onbeforeunload,浏览器关闭提示,兼容IE、FF、Chrome
- Spring整合quartz,quartz-scheduler定时任务,Spring定时任务
- Android系统应用隐藏和应用禁止卸载
- 王源三年前因为他们哭,如今和他们站在一起时,表情依旧让人心疼
- 研究人员发现 Swagger 相关漏洞
- HTC:围观我们的Eye Experience功能
- 摒弃超级像素:HTC One M8 Eye进化
- Java基础知识回顾第四篇
- Micheal Nielsen's神经网络学习之二
- Apache 服务启动不了
- jquery mobile + 百度地图 + phonegap 写的一个"校园助手"的app
- CocoaPods + XCTest进行单元测试
- leetcode: Best Time to Buy and Sell Stock II
- 备忘录模式之我见
- 多线程(3)-基于Object的线程等待与唤醒
- 基于Windows系统在VMware虚拟机上部署安装OS X El Capitan 10.11系统
- 健康债和技术债都不能欠 公众号: 我是攻城师(woshigcs)
- maven的生命周期,插件介绍(二)
- 最近发表
- 标签列表
-
- c++论坛 (14)
- mysql 时间索引 (13)
- mydisktest_v298 (35)
- sql 日期比较 (33)
- document.appendchild (35)
- 头像打包下载 (35)
- 二调符号库 (23)
- acmecadconverter_8.52绿色版 (25)
- f12019破解 (16)
- 流星蝴蝶剑修改器 (18)
- np++ (17)
- 算法第四版pdf (14)
- 梦幻诛仙表情包 (36)
- 魔兽模型 (23)
- java面试宝典2019pdf (26)
- beamoff下载 (17)
- disk++ (30)
- vncviewer破解版 (20)
- word文档批量处理大师破解版 (19)
- pk10牛牛 (20)
- 加密与解密第四版pdf (29)
- pcm文件下载 (15)
- jemeter官网 (16)
- iteye (26)
- parsevideo (22)