§ 优势特性
GreatSQL数据库是一款开源免费数据库,可在普通硬件上满足金融级应用场景,具有高可用、高性能、高兼容、高安全等特性,可作为MySQL或Percona Server for MySQL的理想可选替换。
§ 核心特性
§ 高可用
针对MGR进行了大量改进和提升工作,新增支持地理标签、仲裁节点、读写节点可绑定动态IP、快速单主模式、智能选主,并针对流控算法、事务认证队列清理算法、节点加入&退出机制、recovery机制等多项MGR底层工作机制算法进行深度优化,进一步提升优化了MGR的高可用保障及性能稳定性。
- 支持 地理标签 特性,提升多机房架构数据可靠性。
- 支持 仲裁节点 特性,用更低的服务器成本实现更高可用。
- 支持 读写节点动态VIP 特性,高可用切换更便捷。
- 支持 快速单主模式,在单主模式下更快,性能更高。
- 支持 智能选主 特性,高可用切换选主机制更合理。
- 采用 全新流控算法,使得事务更平稳,避免剧烈抖动。
- 优化了节点加入、退出时可能导致性能剧烈抖动的问题。
- 优化事务认证队列清理算法,高负载下不复存在每60秒性能抖动问题。
- 解决了个别节点上磁盘空间爆满时导致MGR集群整体被阻塞的问题。
- 解决了长事务造成无法选主的问题。
- 修复了recovery过程中长时间等待的问题。
更多信息详见文档:高可用。
§ 高性能
相对MySQL及Percona Server For MySQL的性能表现更稳定优异,支持高性能的内存查询加速 Rapid 引擎、InnoDB并行查询、并行LOAD DATA、事务无锁化、线程池等特性,在TPC-C测试中相对MySQL性能提升超过30%,在TPC-H测试中的性能表现是MySQL的十几倍甚至上百倍。
- 支持类似MySQL HeatWave的 大规模并行、高性能的内存查询加速 Rapid 引擎,可将GreatSQL的数据分析性能提升几个数量级。
- 支持 InnoDB并行查询,适用于轻量级OLAP应用场景,在TPC-H测试中平均提升15倍,最高提升40+倍。
- 优化InnoDB事务系统,实现了大锁拆分及无锁化等多种优化方案,OLTP场景整体性能提升约20%。
- 支持 并行LOAD DATA,适用于频繁导入大批量数据的应用场景,性能可提升约20+倍。
- 支持 异步删除大表,提高InnoDB引擎运行时性能的稳定性。
- 支持 线程池(Threadpool),降低了线程创建和销毁的代价,保证高并发下,性能稳定不会明显衰退。
更多信息详见文档:高性能。
§ 高兼容
支持大多数常见Oracle用法,包括 数据类型兼容、函数兼容、SQL语法、存储程序兼容 等众多兼容扩展用法。
更多信息详见文档:高兼容。
§ 高安全
支持 逻辑备份加密、CLONE备份加密、审计、表空间国密加密、数据脱敏 等多个安全提升特性,进一步保障业务数据安全,更适用于金融级应用场景。
GreatSQL 8.0.32-25 基于Percona Server for MySQL 8.0.32,它在 MySQL 8.0.32 基础上做了大量的改进和提升以及众多新特性,详情请见:Percona Server for MySQL feature comparison (opens new window),这其中包括线程池、审计、数据脱敏等MySQL企业版才有的特性,以及performance_schema提升、information_schema提升、性能和可扩展性提升、用户统计增强、PROCESSLIST增强、Slow log增强等大量改进和提升,这里不一一重复列出。
下面是 GreatSQL 和 MySQL 社区版本的特性对比表:
| 1.主要特性 | GreatSQL 8.0.32-25 | MySQL 8.0.32 |
|---|---|---|
| 开源 | ✔️ | ✔️ |
| ACID完整性 | ✔️ | ✔️ |
| MVCC特性 | ✔️ | ✔️ |
| 支持行锁 | ✔️ | ✔️ |
| Crash自动修复 | ✔️ | ✔️ |
| 表分区(Partitioning) | ✔️ | ✔️ |
| 视图(Views) | ✔️ | ✔️ |
| 子查询(Subqueries) | ✔️ | ✔️ |
| 触发器(Triggers) | ✔️ | ✔️ |
| 存储程序(Stored Programs) | ✔️ | ✔️ |
| 外键(Foreign Keys) | ✔️ | ✔️ |
| 窗口函数(Window Functions) | ✔️ | ✔️ |
| 通用表表达式CTE | ✔️ | ✔️ |
| 地理信息(GIS) | ✔️ | ✔️ |
| 基于GTID的复制 | ✔️ | ✔️ |
| 组复制(MGR) | ✔️ | ✔️ |
| MyRocks引擎 | ✔️ | |
| 2. 性能提升扩展 | GreatSQL 8.0.32-25 | MySQL 8.0.32 |
| Rapid 引擎 | ✔️ | 仅云上HeatWave |
| InnODB并行查询 | ✔️ | 仅主键扫描 |
| 并行LOAD DATA | ✔️ | ❌ |
| InnoDB事务ReadView无锁优化 | ✔️ | ❌ |
| InnoDB事务大锁拆分优化 | ✔️ | ❌ |
| InnoDB资源组 | ✔️ | ✔️ |
| 自定义InnoDB页大小 | ✔️ | ✔️ |
| Contention-Aware Transaction Scheduling | ✔️ | ✔️ |
| InnoDB Mutexes拆分优化 | ✔️ | ❌ |
| MEMORY引擎优化 | ✔️ | ❌ |
| InnoDB Flushing优化 | ✔️ | ❌ |
| 并行Doublewrite Buffer | ✔️ | ✔️ |
| InnoDB快速索引创建优化 | ✔️ | ❌ |
| VARCHAR/BLOB/JSON类型存储单列压缩 | ✔️ | ❌ |
| 数据字典中存储单列压缩信息 | ✔️ | ❌ |
| 3. 面向开发者提升改进 | GreatSQL 8.0.32-25 | MySQL 8.0.32 |
| X API | ✔️ | ✔️ |
| JSON | ✔️ | ✔️ |
| NoSQL Socket-Level接口 | ✔️ | ✔️ |
| InnoDB全文搜索改进 | ✔️ | ❌ |
| 更多Hash/Digest函数 | ✔️ | ❌ |
| Oracle兼容-数据类型 | ✔️ | ❌ |
| Oracle兼容-函数 | ✔️ | ❌ |
| Oracle兼容-SQL语法 | ✔️ | ❌ |
| Oracle兼容-存储程序 | ✔️ | ❌ |
| 4. 基础特性提升改进 | GreatSQL 8.0.32-25 | MySQL 8.0.32 |
| MGR提升-地理标签 | ✔️ | ❌ |
| MGR提升-仲裁节点 | ✔️ | ❌ |
| MGR提升-读写节点绑定VIP | ✔️ | ❌ |
| MGR提升-快速单主模式 | ✔️ | ❌ |
| MGR提升-智能选主机制 | ✔️ | ❌ |
| MGR提升-全新流控算法 | ✔️ | ❌ |
| information_schema表数量 | 95 | 65 |
| 全局性能和状态指标 | 853 | 434 |
| 优化器直方图(Histograms) | ✔️ | ✔️ |
| Per-Table性能指标 | ✔️ | ❌ |
| Per-Index性能指标 | ✔️ | ❌ |
| Per-User性能指标 | ✔️ | ❌ |
| Per-Client性能指标 | ✔️ | ❌ |
| Per-Thread性能指标 | ✔️ | ❌ |
| 全局查询相应耗时统计 | ✔️ | ❌ |
| SHOW INNODB ENGINE STATUS增强 | ✔️ | ❌ |
| 回滚段信息增强 | ✔️ | ❌ |
| 临时表信息增强 | ✔️ | ❌ |
| 用户统计信息增强 | ✔️ | ❌ |
| Slow log信息增强 | ✔️ | ❌ |
| 5.安全性提升 | GreatSQL 8.0.32-25 | MySQL 8.0.32 |
| 国密支持 | ✔️ | ❌ |
| 备份加密 | ✔️ | ❌ |
| 审计日志入库 | ✔️ | ❌ |
| SQL Roles | ✔️ | ✔️ |
| SHA-2密码Hashing | ✔️ | ✔️ |
| 密码轮换策略 | ✔️ | ✔️ |
| PAM认证插件 | ✔️ | 仅企业版 |
| 审计插件 | ✔️ | 仅企业版 |
| Keyring存储在文件中 | ✔️ | ✔️ |
| Keyring存储在Hashicorp Vault中 | ✔️ | 仅企业版 |
| InnoDB数据加密 | ✔️ | ✔️ |
| InnoDB日志加密 | ✔️ | ✔️ |
| InnoDB各种表空间文件加密 | ✔️ | ✔️ |
| 二进制日志加密 | ✔️ | ❌ |
| 临时文件加密 | ✔️ | ❌ |
| 强制加密 | ✔️ | ❌ |
| 6. 运维便利性提升 | GreatSQL 8.0.32-25 | MySQL 8.0.32 |
| DDL原子性 | ✔️ | ✔️ |
| 数据字典存储InnoDB表 | ✔️ | ✔️ |
| 快速DDL | ✔️ | ✔️ |
| SET PERSIST | ✔️ | ✔️ |
| 不可见索引 | ✔️ | ✔️ |
| 线程池(Threadpool) | ✔️ | 仅企业版 |
| 备份锁 | ✔️ | ❌ |
| SHOW GRANTS扩展 | ✔️ | ❌ |
| 表损坏动作扩展 | ✔️ | ❌ |
| 杀掉不活跃事务 | ✔️ | ❌ |
| START TRANSACTION WITH CONSISTENT SNAPSHOT扩展 | ✔️ | ❌ |
此外,GreatSQL 8.0.32-25基于Percona Server for MySQL 8.0.32版本,它在MySQL 8.0.32基础上做了大量的改进和提升以及众多新特性,详情请见:Percona Server for MySQL feature comparison (opens new window),这其中包括线程池、审计、数据脱敏等MySQL企业版才有的特性,以及performance_schema提升、information_schema提升、性能和可扩展性提升、用户统计增强、PROCESSLIST增强、Slow log增强等大量改进和提升,这里不一一重复列出。
GreatSQL同时也是gitee(码云)平台上的GVP项目,详见:https://gitee.com/gvp/database-related (opens new window) 数据库相关类目。
扫码关注微信公众号

← GreatSQL 5.7 已知问题 →