官宣!Apache ShardingSphere 5.0.0 正式发布
11 月 10 日,是 Apache ShardingSphere 进入 Apache 基金会的三周年纪念日。在这特殊的一天,我们很高兴的宣布 Apache ShardingSphere 迎来了 5.0.0 GA 版本的正式发布。经过近两年的优化和打磨,ShardingSphere 5.0.0 GA 版正式开启了以可插拔架构为核心的全新阶段,实现了由过去数据分片单一应用场景到现在复杂应用环境下综合数据治理的身份转变与能力提升。
5.0.0 具体版本发布信息如下:
1 新特性
-
支持注释解析
-
弹性伸缩:初步支持 openGauss
-
弹性伸缩:增加增量同步是否已完成检测算法 SPI 接口
-
弹性伸缩:增加数据校验算法 SPI 接口
-
弹性伸缩:迁移前自动建表基本支持 MySQL 和 openGauss
-
弹性伸缩:与 proxy 整合更完善,支持迁移完成自动切换配置
-
弹性伸缩:提供更多的 DistSQL 支持,数据校验、切换配置等
-
弹性伸缩:支持 DistSQL 自动触发迁移
-
新增 DistSQL 语法:Shadow 规则管理
-
新增 DistSQL 语法:弹性伸缩任务管理
-
新增 DistSQL 语法:Proxy 实例熔断
-
新增 DistSQL 语法:读写分离读库禁用
-
新增 DistSQL 语法:ALTER RESOURCE
-
新增 DistSQL 语法:DROP SHARDING ALGORITHM
-
新增 DistSQL 语法:CREATE SHARDING ALGORITHM
-
新增 DistSQL 语法:CREATE DEFAULT SHARDING [TABLE | DATABASE] STRATEGY
-
新增 DistSQL 语法:SHOW ALL VARIABLES
-
新增 DistSQL 语法:SHOW VARIABLE variableName;
-
Proxy 支持 openGauss
2 API 变更
-
ShardingSphere-JDBC 增加 schema name 配置
-
增加默认分片键配置
-
默认 authority provider 由 NATIVE 调整为 ALL_PRIVILEGES_PERMITTED
-
SCTL 语法调整,与 DistSQL RAL 语法合并
-
SHOW RESOURCES DistSQL 调整为 SHOW SCHEMA RESOURCES
-
影子库压测:移除 shadow 逻辑字段,支持 shadow 算法
3 增强
-
元数据重构以及性能提升
-
支持 MySQL union/union all 语句解析
-
支持 PostgreSQL ABORT 语句
-
支持 PostgreSQL CREATE INDEX 语句未指定索引时,自动生成索引
-
支持带逻辑 schema 的 SQL 语句执行
-
支持绑定表配置不同分片键
-
ShardingSphere 内核性能优化
-
Proxy 支持对部分 information_schema 表的查询,优化客户端连接体验
-
DistSQL 支持用引号的的方式将关键字作为参数名
-
ADD RESOURCE语句中 password 支持特殊字符
-
ADD RESOURCE 支持自定义 JDBC 参数和连接池属性
-
DROP RESOURCE 支持可选参数 ignore single tables,用于忽略单表规则限制
-
支持在读写分离规则的基础上,使用 DistSQL 创建 sharding table rule
-
SHOW DATABASES 语句支持 like 语法
-
CREATE SHARDING TABLE RULE 支持使用 inline 表达式指定资源
-
CREATE SHARDING TABLE RULE 支持使用 dataNodes 的方式配置分片
-
CREATE SHARDING TABLE RULE 支持复用已有算法
-
SET VARIABLE,支持修改 Proxy 配置
-
PostgreSQL 协议完善(支持 Portal、未指定类型的数据等)
-
Proxy 支持切换 Netty 线程池在部分场景提高性能
-
Proxy 与数据库交互的 fetch size 可配置
-
弹性伸缩:完善对 PostgreSQL 的支持
-
弹性伸缩:数据校验支持源端和目标端并行计算
4 重构
-
重构 SingleTable 功能以支持 Encrypt 多数据源
-
重构 examples,调整模块结构
-
调整注册中心节点持久化数据结构
-
弹性伸缩:重构增量同步是否已完成检测算法默认实现
-
弹性伸缩:重构数据校验算法默认实现
-
弹性伸缩:移除 HTTP API 和独立打包
-
影子库压测:去除 DML 重写流程
-
影子库压测:支持 DDL 路由
5 漏洞修复
-
修复 INTERVAL 分片算法问题
-
修复 SHOW INDEX FROM TABLE FROM TABLE 语句改写异常
-
修复 Encrypt 多表关联改写异常
-
修复子查询 index out of range 异常
-
修复 Oracle 分页异常
-
修复 Sharding 场景下未配置 KeyGenerateStrategy 时改写异常
-
修复 Oracle 方言大小写导致 Federation 执行引擎异常
-
修复 Sharding/Encrypt 整合使用时改写异常
-
修复 Oracle 元数据加载异常的问题
-
修复 SHOW RESOURCES 语句无法展示自定义属性的问题
-
修复 SQL 执行异常不抛出的问题
-
修复 Etcd 无法发送节点新增事件
-
修复 PostgreSQL Proxy 查询结果可能丢失包含 null 值的数据行的问题
-
修复 PostgreSQL 元数据列顺序可能错乱的问题
-
修复 Proxy 字符编码可能不正确的问题
6 社区建设
Apache ShardingSphere 5.0.0 版本的发布离不开社区用户的支持和贡献,期间共有 168 位 Contributor 提交了 4468 个 PR,助力 ShardingSphere 5.0.0 版本的全力发布,感谢社区伙伴们的大力支持。
