Mycat2 软件架构
产品架构
计算节点(Mycat)和存储节点(MySQL)组合架构。
一般来说,Mycat2 使用数据库(接受sql的服务器)作为存储节点进行读写,当然未来也支持直接以自定义接口读写数据。特别地,暂时 Mycat2 没有实现系统表,所以查询系统表的 sql 需要转发到特殊的节点处理后返回到客户端。

参考技术栈
网络层:NIO、Netty、Vertx
数据库与其客户端:开源数据库通信协议MySQ,闭源数据库与其客户端JDBC
单机执行器与分布式执行器:火山模型、Push模型
查询优化器:Apache Calcite
查询编译器:Apace Calcite,Mycat 1.6
执行器:Lingeriej,RxJava

多实例Mycat架构
