GitXplorerGitXplorer
X

Gaea

public
2605 stars
418 forks
68 issues

Commits

List of commits on branch master.
Verified
de11b227581b49f409313914650cee7fb7e02935

Merge pull request #260 from XiaoMi/admin-add-issue-template

ggongna-au committed 2 months ago
Verified
e6c1c97730732a0c5cd816859f459e3df96b643d

Update issue templates

xxiyangxixian committed 2 months ago
Verified
9e16060c4afcabe8ca910313e2abde4113e9af79

Merge pull request #214 from XiaoMi/dev

xxiyangxixian committed 2 years ago
Unverified
bd4f77a454464ed450de828e0c72f8417b205eb5

修复 delete update 语句状态码返回错误

xxiyangxixian committed 2 years ago
Verified
27bb343e08afe054683a4d96d3f4f0784dc37db8

Merge pull request #213 from XiaoMi/dev

xxiyangxixian committed 2 years ago
Unverified
1e1c0fbad3563e74bb29472b8a1fa21fb1eb9c31

修复分库分表情况下,状态码错误问题

xxiyangxixian committed 2 years ago

README

The README file for this repository.

LICENSE Build Status Go Report Card

简介

Gaea是小米中国区电商研发部研发的基于mysql协议的数据库中间件,目前在小米商城大陆和海外得到广泛使用,包括订单、社区、活动等多个业务。Gaea支持分库分表、sql路由、读写分离等基本特性,更多详细功能可以参照下面的功能列表。其中分库分表方案兼容了mycat和kingshard两个项目的路由方式。Gaea在设计、实现阶段参照了mycat、kingshard和vitess,并使用tidb parser作为内置的sql parser,在此表达诚挚感谢。为了方便使用和学习Gaea,我们也提供了详细的使用和设计文档,也欢迎大家多多参与。

功能列表

基础功能

  • 多集群
  • 多租户
  • SQL透明转发
  • 慢SQL指纹
  • 错误SQL指纹
  • 注解路由
  • 慢日志
  • 读写分离,从库负载均衡
  • 自定义SQL拦截与过滤
  • 连接池
  • 配置热加载
  • IP/IP段白名单
  • 全局序列号

分库、分表功能

  • 分库: 支持mycat分库方式
  • 分表: 支持kingshard分表方式
  • 聚合函数: 支持max、min、sum、count、group by、order by等
  • join: 支持分片表和全局表的join、支持多个分片表但是路由规则相同的join

架构图

gaea架构图

集群部署图

gaea集群部署图

如上图所示, 部署一套gaea-cc和etcd可用来管理多套gaea集群, 负责集群内namespace配置的增删改查. gaea-cc的HTTP接口文档

安装使用

设计与实现

Roadmap

  • [x] 支持配置加密存储,开关
  • [ ] 支持执行计划缓存
  • [ ] 支持事务追踪
  • [ ] 支持二级索引
  • [ ] 支持分布式事务
  • [ ] 支持平滑的扩容、缩容
  • [ ] 后端连接池优化 (按照请求时间排队)

自有开发模块

  • backend
  • cmd
  • log
  • models
  • proxy/plan
  • proxy/router(kingshard路由方式源自kingshard项目本身)
  • proxy/sequence
  • server

外部模块

  • mysql(google vitess、tidb、kingshard都有引入)
  • parser(tidb)
  • stats(google vitess,打点统计)
  • util(混合)

社区

gitter

Gitter

钉钉

钉钉