Skip to content

Latest commit

 

History

History
85 lines (76 loc) · 8.64 KB

README.md

File metadata and controls

85 lines (76 loc) · 8.64 KB

Xsql : MySQL数据库的RestAPI服务器

特性

    1. 快速生成MySQL数据库的RestAPI
    1. MySQL数据库的所有表可以全量和增量同步至本地sqlite数据库,sqlite可以根据主数据库的规模选择分片。
    1. 本地sqlite通过定时同步,或者解析MySQL—binlog数据库,保持与主数据库数据一致;同时会循环查询数据,检查不一致的数据,并将数据持久化到本地sqlite中。
    1. XSQL服务,通过Nacos注册,可以实现了微服务架构,同时可以启动多个实例,每个实例都维护一份sqlite分片,查询RestAPI如果命中本地sqlite则不需要查询主数据库,同时通过微服务架构,xsql可以同时启动N个服务,能同时承受百万级/千万级/亿级数据量,和百万级以上并发。
    1. 本地sqlite可以自定义分片规则,比如按hash,ID,日期,地域等进行分片,保证百万级以上数据量,通过分片方式开始查询到数据。
    1. 除本地sqlite,还有将每个同步至本地数据库的表的数据(需提前配置表名称,需要分词的字段),进行分词,分词数组重新排序,然后建立倒排索引。同时提供搜索引擎服务。
    1. 除本地sqlite以外,为提供ops,所有数据同步持久化为文档数据(非关系性,不提供事务),所有SQL查询,可以解析为特定参数查询函数,查询函数在文档数据中快速查询,由于没有sqlite的制约,在查询特定类型数据时,可能提供更大ops,数据同步通过类似raft协议来保持一致。
    1. MySQL数据库,可以同时同步在mysql/postgres/oracle/sqlserver,作为一款自动的数据迁移工具。
    1. MySQL数据库,在同步到sqlite时,会根据MySQL数据库表的信息,自动生成建表语句,但表必须有主键,另外如果表字段为特殊字符串,如database,则生成的DDL可能无法在sqlite中执行。
    1. 本服务的目标是:
      ①提供MySQL的RestAPI。
      ②提供MySQL的本地sqlite备份。
      ③同步完成后的sqlite可以提供快速查询功能,缓解MySQL的压力。
      ④本地sqlite提供分片功能,解决百万级至百亿级数据量查询问题。
      ⑤同步提供类mongoDB文档存储功能。
      ⑥实现微服务架构数据库,目前的Tidb是分布式的,没有注册中导致每次扩容缩容需要改动大量配置,由于本架构通过nacos注册中心,注册服务,同时启动多个实例时,自动根据配置中心的实例信息,进行动态伸缩。
      ⑦同步提供搜索引擎功能,本地服务根据配置的需要分词的表,进行分词,分词数组进行排序,然后根据分词数组建立倒排索引,如果需要搜索引擎的查询,提供搜索引擎服务。
      ⑧提供快速数据库迁移功能,其实和将数据同步至本地sqlite一样的,只是变为同步至多数据库,包括(mysql/postgres/oracle/sqlserver/sqlite/es)。 ⑨记录每份数据的历史变更,如同git一样,可以查询某数据库某表某记录的历史变更。
      ⑩最后是提供自建serverless架构,serverless架构中可以随机注册,注册后,随机或按特定规则将一部分主数据库的数据同步至serverless架构中的专员服务,专员服务维护、同步这部分数据;专员服务可以随意启动N个(1-1000000),有个任务榜服务,任务榜服务,显示有哪些数据,哪些数据本专员服务已经同步,新启动的专员服务可以根据任务榜的摘取任务的情况,动态选择需要同步的数据,如果查询请求来了,任务榜上会出现一个提问,谁(专员服务)含有此库此表的数据,专员服务检测到提问,检测是否是自己管理的数据,如果是,则返回我有(上锁),然后返回数据。这个算SQA模型,S表示是ServerLess架构,专员是服务网格中的随机一个;Q是查询任务提问;A是专员是根据自己管理的数据进行响应。(这个和分片分布式数据库很不一样的,如果为分片,数据库本身知道分片规则,也知道数据库存放在哪个分片,根据查询条件进行解析,查询相应分片,然后返回数据;SQA架构不需要分片,只需要发布数据同步任务榜,专员服务摘榜,把随机或特定同步任务完成,专员知晓自己的数据,Q:查询请求来了,管理节点只需要提出问题,谁有这个数据,A: 专员知晓自己是否含有这个数据,返回上奏汇报。这个架构可以解决百亿-万亿规模数据查询问题)

安装与启动

xmysql requires node >= 10.x

npm install 
npm run start

Example : Generate REST APIs for Magento

Features

  • Generates API for ANY MySql database 🔥🔥
  • Serves APIs irrespective of naming conventions of primary keys, foreign keys, tables etc 🔥🔥
  • REST API Usual suspects : CRUD, List, FindOne, Count, Exists, Distinct
  • 支持批量插入、批量读取、批量删除、批量修改
  • 支持分页查询
  • 支持排序查询
  • 支持字段筛选
  • 支持查询条件
  • Aggregate functions
  • Group By, Having (as query params) 🔥🔥
  • Group By, Having (as a separate API) 🔥🔥
  • Multiple group by in one API 🔥🔥🔥🔥
  • Chart API for numeric column 🔥🔥🔥🔥🔥🔥
  • Auto Chart API - (a gift for lazy while prototyping) 🔥🔥🔥🔥🔥🔥
  • XJOIN - (Supports any number of JOINS) 🔥🔥🔥🔥🔥🔥🔥🔥🔥
  1. 自动生成建表语句 xdata-xmysql-service sqlite3。 √
  2. 查询数据,使用sqlite作为缓存,先查询sqlite,如果sqlite存在,则直接返回。 ×
  3. 新增RestAPI,返回sqlite存在哪些表,表数据长度 和 主数据库表数据长度 ,一致标识。×
  4. 每张表新建一个sqlite数据库 [database].[tablename].sqlite.db,主要是为了避免并发写入时,sqlite可能锁库。√
  5. 添加分布式锁,避免并发写入问题。√
  6. Nedb作为持久化备用方案。×
  7. 建立分布式事务机制。×
  8. 使用alasql作为sql内存查询方案。×
  9. 编写定时任务,定期执行数据库同步操作。√
  10. 所有的增删改操作需要添加 表名称 + IP + 操作类型 锁。×
  11. 所有操作如果显示服务器忙(未获取到锁),则需要提示服务器忙。×
  12. 所有查询操作通过本地sqlite,或者本地Nedb,或者本地alasql返回,如果本地没有,则查询主/从数据库。×
  13. 定时检测本地sqlite 与 远程 mysql 数据库表 长度 是否一致,以及抽样调查最近一段时间数据是否一致,如果一致,则设置此表为一致,查询请求,可以先由本地一致标识的数据库返回数据。×
  14. 本地sqlite定期执行bin_log解析SQL,保证一致性,如果需要新增数据,直接新增,如果遇到修改数据,则查询主数据库数据,在将主数据库数据更新到本地,如果遇到删除,查询主数据库数据,如果主数据库数据此数据不存在,则删除本地sqlite对应数据。×
  15. 初始化同步时,应该10000条的多批次查询,按批次将数据刷入到sqlite中,如果不这样数据量大于100000级,数据时查询不出来的,而且也难以同时就数据持久化到sqlite中。×
XDATA用印数据区域名称刷新 https://api.yunwisdom.club:30443/gateway/api/v2/mysql/updata_zonename
XDATA同步考勤数据 https://api.yunwisdom.club:30443/gateway/api/v1/datasync_schedule_sign
XDATA备份MySQL数据库 https://api.yunwisdom.club:30443/gateway/api/v3/mysql/backup
XDATA同步HRMRESOURCE https://api.yunwisdom.club:30443/gateway/api/v1/datasync
XDATA刷新部门员工(创达) https://api.yunwisdom.club:30443/gateway/api/v1_cd/wework_depart_user/2/1
XDATA刷新部门(创达) https://api.yunwisdom.club:30443/gateway/api/v1_cd/wework_depart/1
XDATA刷新部门(创达) https://api.yunwisdom.club:30443/gateway/api/v1_cd/wework_depart_list/1
MySQL用印数据定时刷新 https://api.yunwisdom.club:30443/gateway/api/v2/mysql/serial/update_seal_info
XDATA刷新用户 https://api.yunwisdom.club:30443/gateway/api/v3/employee
XDATA刷新部门 https://api.yunwisdom.club:30443/gateway/api/v2/wework_depart_list/2
XDATA刷新部门 https://api.yunwisdom.club:30443/gateway/api/v2/wework_depart/2
XDATA刷新部门员工 https://api.yunwisdom.club:30443/gateway/api/v2/wework_sdepart_user/2/1
XDATA刷新部门员工 https://api.yunwisdom.club:30443/gateway/api/v2/wework_depart_user/2/1
MySQL自动序列 https://api.yunwisdom.club:30443/gateway/api/v2/mysql/serial/bs_seal_regist/serialid/id