## 背景
上一期月报[MariaDB on Power8](http://mysql.taobao.org/monthly/2015/12/09/)我介绍了下 MariaDB 为 Power 处理器所做的一些优化,但是并没有给出实际测试的效果,这次月报我们借到了一台Power8的机器,有机会亲自试一把 MariaDB 在 Power 上的表现。
## 环境
一切不交代测试场景的Benchmark都是Benchmarketing。
因为Power和Intel之间对标的CPU型号我无法得知,因此这个测试仅仅用来观察MariaDB/MySQL在Power和Intel之间一些特质的差异,而非性能的直接对比。
Power 这边我们拿到的是 PowerVM 虚拟化的32核Power8机器,Intel这边用的是我们日常测试的E5-2630机型,虚拟机 vs 物理机,两者的价格我也没有数据,所以不要直接对比性能,不要直接对比性能,不要直接对比性能!
### Power战队
处理器规格:
~~~
processor : 0
cpu : POWER8 (architected), altivec supported
clock : 3425.000000MHz
revision : 2.1 (pvr 004b 0201)
~~~
处理器核数:
~~~
[root@plx sysbench]# cat /proc/cpuinfo | grep processor | wc -l
32
~~~
内存:
~~~
[root@plx sysbench]# free -g
total used free shared buff/cache available
Mem: 30 7 3 0 19 22
Swap: 15 0 15
~~~
### Intel战队
处理器规格:
~~~
processor : 0
vendor_id : GenuineIntel
cpu family : 6
model : 45
model name : Intel(R) Xeon(R) CPU E5-2630 0 @ 2.30GHz
stepping : 7
cpu MHz : 2294.709
cache size : 15360 KB
physical id : 0
siblings : 12
core id : 0
cpu cores : 6
apicid : 0
initial apicid : 0
fpu : yes
fpu_exception : yes
cpuid level : 13
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc arch_perfmon pebs bts rep_good xtopology nonstop_tsc aperfmperf pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 cx16 xtpr pdcm dca sse4_1 sse4_2 x2apic popcnt aes xsave avx lahf_lm arat epb xsaveopt pln pts dts tpr_shadow vnmi flexpriority ept vpid
bogomips : 4589.41
clflush size : 64
cache_alignment : 64
address sizes : 46 bits physical, 48 bits virtual
power management:
~~~
处理器核数:
~~~
$cat /proc/cpuinfo | grep processor | wc -l
24
~~~
内存:
~~~
$free -g
total used free shared buffers cached
Mem: 189 53 135 0 0 2
-/+ buffers/cache: 50 138
Swap: 1 0 1
~~~
## CPU理论性能测试
首先我们用sysbench简单测试下CPU的计算能力。
测试命令:
~~~
sysbench --test=cpu --cpu-max-prime=20000 --num-threads=$num run
~~~
我在每个平台上至少执行了3次测试,只有连续三次测试结果差异极小的时候,才认为最后一次测试结果有效。因为Power8是一台虚拟机,并不能保证宿主机任何时候都只有我在用。
下面是原始测试数据的表格:
### Power CPU理论测试
| 线程 | 总耗时(s) | 平均延时(ms) | 95%延时(ms) |
|---|---|---|
| 1 | 201.67 | 20.17 | 20.19 |
| 4 | 66.61 | 26.64 | 33.18 |
| 8 | 59.90 | 47.90 | 106.78 |
| 16 | 49.18 | 78.62 | 119.75 |
| 32 | 37.37 | 119.36 | 119.86 |
| 64 | 37.37 | 237.32 | 349.90 |
| 128 | 37.38 | 469.16 | 619.61 |
| 512 | 37.38 | 1671.31 | 2179.63 |
### Intel CPU理论测试
| 线程 | 总耗时(s) | 平均延时(ms) | 95%延时(ms) |
|---|---|---|
| 1 | 827.08 | 82.71 | 83.02 |
| 4 | 206.97 | 82.77 | 83.24 |
| 8 | 103.45 | 82.72 | 83.14 |
| 16 | 60.02 | 95.96 | 114.39 |
| 32 | 47.52 | 151.89 | 230.74 |
| 64 | 47.53 | 303.26 | 350.64 |
| 128 | 47.53 | 604.46 | 695.92 |
| 512 | 47.53 | 2360.40 | 2759.46 |
### CPU理论性能对比
(注:比值指的是相同线程数下,Intel耗时是Power的多少倍)
| 线程 | Power总耗时(s) | Intel总耗时(s) | 比值 |
|---|---|---|
| 1 | 201.67 | 827.08 | 4.10 |
| 4 | 66.61 | 206.97 | 3.11 |
| 8 | 59.90 | 103.45 | 1.73 |
| 16 | 49.18 | 60.02 | 1.22 |
| 32 | 37.37 | 47.52 | 1.27 |
| 64 | 37.37 | 47.53 | 1.27 |
| 128 | 37.38 | 47.53 | 1.27 |
| 512 | 37.38 | 47.53 | 1.27 |
从上面三个图我们可以总结一些硬件上的特性:
* 单核心效率Power要高于Intel。3.425GHz 的 Power8 耗时是 2.6GHZ 的 E5-2630 的 1/4,CPU频率只有1.3倍的差异;
* 并发足够高时,性能差异并没有那么大,耗时稳定在1.27倍左右。而核心数Power也是Intel的1.33倍。
## 场景
本次测试共有三种场景:
* MariaDB 10.1.10 on Power
* MariaDB 10.1.10 on Intel
* RDS MySQL 5.6.16 on Intel
为何没有 MySQL on Power 呢,因为编译不过。。。
Buffer Pool全部为16G,数据文件大小为8G上下,保证数据可以全部载入内存。
测试命令:
~~~
./sysbench --db-dirver=mysql --mysql-host=127.0.0.1 --mysql-port=3001 --mysql-user=root --test=tests/db/select.lua --mysql-table-engine=innodb --oltp-table-size=500000 --oltp-tables-count=64 --max-time=1800 --max-requests=2000000000 --num-threads=$num run
~~~
为什么只测读?因为Power主机和Intel主机上使用的硬盘不一样,HDD vs. SDD,测写就完全没有意义了,HDD会被SSD吊打。
因为做过PREPARE之后就直接开测,没有关过MySQL,因此测试时数据都是在内存中的,不会产生物理IO。
下面是测试结果原始数据的表格:
(注:TPS变动比例指当前线程数下的TPS相对于上一轮测试的TPS的比值)
### MariaDB on Power
| 线程 | TPS | 平均耗时(ms) | 95%耗时(ms) | TPS变动比例 |
|---|---|---|
| 1 | 14279.19 | 0.07 | 0.08 | |
| 4 | 41563.43 | 0.09 | 0.12 | 291.08% |
| 8 | 63601.75 | 0.12 | 0.18 | 153.02% |
| 16 | 94346.29 | 0.17 | 0.23 | 148.34% |
| 32 | 119444.32 | 0.26 | 0.45 | 126.60% |
| 64 | 129451.95 | 0.49 | 0.82 | 108.38% |
| 128 | 123414.89 | 1.03 | 1.75 | 95.34% |
| 256 | 112408.11 | 2.27 | 4.00 | 91.08% |
| 512 | 113163.74 | 4.52 | 8.59 | 100.67% |
| 768 | 105875.56 | 7.24 | 15.53 | 93.56% |
### RDS MySQL on Intel
| 线程 | TPS | 平均耗时(ms) | 95%耗时(ms) | TPS变动比例 |
|---|---|---|
| 1 | 10742.70 | 0.09 | 0.11 | |
| 4 | 40061.40 | 0.10 | 0.12 | 372.92% |
| 8 | 68544.88 | 0.12 | 0.14 | 171.10% |
| 16 | 109659.96 | 0.14 | 0.16 | 159.98% |
| 32 | 149450.12 | 0.21 | 0.39 | 136.29% |
| 64 | 145596.26 | 0.44 | 0.75 | 97.42% |
| 128 | 139679.85 | 0.91 | 4.96 | 95.94% |
| 256 | 141907.18 | 1.80 | 11.73 | 101.59% |
| 512 | 61794.87 | 8.28 | 25.79 | 43.55% |
### MariaDB on Intel
| 线程 | TPS | 平均耗时(ms) | 95%耗时(ms) | TPS变动比例 |
|---|---|---|
| 1 | 9673.51 | 0.10 | 0.12 | |
| 4 | 37394.20 | 0.11 | 0.13 | 386.56% |
| 8 | 47347.03 | 0.17 | 0.19 | 126.62% |
| 16 | 107496.94 | 0.15 | 0.18 | 227.04% |
| 32 | 140805.33 | 0.22 | 0.35 | 130.99% |
| 64 | 137045.70 | 0.46 | 0.66 | 97.33% |
| 128 | 138472.96 | 0.92 | 0.36 | 101.04% |
| 256 | 134908.32 | 1.90 | 7.23 | 97.43% |
| 512 | 131814.55 | 3.88 | 19.04 | 97.71% |
下面是对比的表格:
### MySQL vs MariaDB on Intel
(注:变化率是指MariaDB的数值相对于MySQL的数值的比值的百分比)
| 线程 | MySQL TPS | 平均耗时(ms) | 95%耗时(ms) | MariaDB TPS | 平均耗时(ms) | 95%耗时(ms) | TPS变化率 | 平均延时变化率 | 95%延时变化率 |
|---|---|---|
| 1 | 10742.70 | 0.09 | 0.11 | 9673.51 | 0.10 | 0.12 | 90.05% | 111.11% | 109.09% |
| 4 | 40061.40 | 0.10 | 0.12 | 37394.20 | 0.11 | 0.13 | 93.34% | 110.00% | 108.33% |
| 8 | 68544.88 | 0.12 | 0.14 | 47347.03 | 0.17 | 0.19 | 69.07% | 141.67% | 135.71% |
| 16 | 109659.96 | 0.14 | 0.16 | 107496.94 | 0.15 | 0.18 | 98.03% | 107.14% | 112.50% |
| 32 | 149450.12 | 0.21 | 0.39 | 140805.33 | 0.22 | 0.35 | 94.22% | 104.76% | 89.74% |
| 64 | 145596.26 | 0.44 | 0.75 | 137045.70 | 0.46 | 0.66 | 94.13% | 104.55% | 88.00% |
| 128 | 139679.85 | 0.91 | 4.96 | 138472.96 | 0.92 | 0.36 | 99.14% | 101.10% | 7.26% |
| 256 | 141907.18 | 1.80 | 11.73 | 134908.32 | 1.90 | 7.23 | 95.07% | 105.56% | 61.64% |
| 512 | 61794.87 | 8.28 | 25.79 | 131814.55 | 3.88 | 19.04 | 213.31% | 46.86% | 73.83% |
### MariaDB on Intel vs Power
(注:变化率是指Power平台的数值相对于Intel平台的数值的比值的百分比)
| 线程 | Intel TPS | 平均耗时(ms) | 95%耗时(ms) | Power TPS | 平均耗时(ms) | 95%耗时(ms) | TPS变化率 | 平均延时变化率 | 95%延时变化率 |
|---|---|---|
| 1 | 9673.51 | 0.10 | 0.12 | 14279.19 | 0.07 | 0.08 | 147.61% | 70.00% | 66.67% |
| 4 | 37394.20 | 0.11 | 0.13 | 41563.43 | 0.09 | 0.12 | 111.15% | 81.82% | 92.31% |
| 8 | 47347.03 | 0.17 | 0.19 | 63601.75 | 0.12 | 0.18 | 134.33% | 70.59% | 94.74% |
| 16 | 107496.94 | 0.15 | 0.18 | 94346.29 | 0.17 | 0.23 | 87.77% | 113.33% | 127.78% |
| 32 | 140805.33 | 0.22 | 0.35 | 119444.32 | 0.26 | 0.45 | 84.83% | 118.18% | 128.57% |
| 64 | 137045.70 | 0.46 | 0.66 | 129451.95 | 0.49 | 0.82 | 94.46% | 106.52% | 124.24% |
| 128 | 138472.96 | 0.92 | 0.36 | 123414.89 | 1.03 | 1.75 | 89.13% | 111.96% | 486.11% |
| 256 | 134908.32 | 1.90 | 7.23 | 112408.11 | 2.27 | 4.00 | 83.32% | 119.47% | 55.33% |
| 512 | 131814.55 | 3.88 | 19.04 | 113163.74 | 4.52 | 8.59 | 85.85% | 116.49% | 45.12% |
这个测试结果跟上一篇月报中IBM给出的官方测试对比有很大差异。
我们就来看看这些测试结果反映了些什么问题:
* 如果只看 MariaDB on Power 和 MySQL on Intel 的结果,我会以为 Power 在高并发时性能更稳定,但看了 MariaDB on Intel 的测试结果之后,意识到这是 MariaDB Thread Pool 的功劳,并不是Power平台的优势;
* 对比 MySQL on Intel 和 MariaDB on Intel 可以明显的看到,16并发和256并发是明显的分水岭,16并发之前MySQL优势明显,16并发到256并发之间两者差距不大,256并发之后,MariaDB完爆MySQL;
* 看 MariaDB 在 Power 和 Intel 平台下的表现,16并发之前 Power 优势会明显一点,16并发之后 Intel 就追上来了并且超越了 Power。这跟我们上面做的 CPU 理论测试结果差不多,大家可以上去翻表格,16线程之前 Power 效率要高于 Intel,但是之后基本就稳定了;
* 所以,官方的Benchmark永远不可靠,自己动手才是硬道理。
- 数据库内核月报目录
- 数据库内核月报 - 2016/09
- MySQL · 社区贡献 · AliSQL那些事儿
- PetaData · 架构体系 · PetaData第二代低成本存储体系
- MySQL · 社区动态 · MariaDB 10.2 前瞻
- MySQL · 特性分析 · 执行计划缓存设计与实现
- PgSQL · 最佳实践 · pg_rman源码浅析与使用
- MySQL · 捉虫状态 · bug分析两例
- PgSQL · 源码分析 · PG优化器浅析
- MongoDB · 特性分析· Sharding原理与应用
- PgSQL · 源码分析 · PG中的无锁算法和原子操作应用一则
- SQLServer · 最佳实践 · TEMPDB的设计
- 数据库内核月报 - 2016/08
- MySQL · 特性分析 ·MySQL 5.7新特性系列四
- PgSQL · PostgreSQL 逻辑流复制技术的秘密
- MySQL · 特性分析 · MyRocks简介
- GPDB · 特性分析· Greenplum 备份架构
- SQLServer · 最佳实践 · RDS for SQLServer 2012权限限制提升与改善
- TokuDB · 引擎特性 · REPLACE 语句优化
- MySQL · 专家投稿 · InnoDB物理行中null值的存储的推断与验证
- PgSQL · 实战经验 · 旋转门压缩算法在PostgreSQL中的实现
- MySQL · 源码分析 · Query Cache并发处理
- PgSQL · 源码分析· pg_dump分析
- 数据库内核月报 - 2016/07
- MySQL · 特性分析 ·MySQL 5.7新特性系列三
- MySQL · 特性分析 · 5.7 代价模型浅析
- PgSQL · 实战经验 · 分组TOP性能提升44倍
- MySQL · 源码分析 · 网络通信模块浅析
- MongoDB · 特性分析 · 索引原理
- SQLServer · 特性分析 · XML与JSON应用比较
- MySQL · 最佳实战 · 审计日志实用案例分析
- MySQL · 性能优化 · 条件下推到物化表
- MySQL · 源码分析 · Query Cache内部剖析
- MySQL · 捉虫动态 · 备库1206错误问题说明
- 数据库内核月报 - 2016/06
- MySQL · 特性分析 · innodb 锁分裂继承与迁移
- MySQL · 特性分析 ·MySQL 5.7新特性系列二
- PgSQL · 实战经验 · 如何预测Freeze IO风暴
- GPDB · 特性分析· Filespace和Tablespace
- MariaDB · 新特性 · 窗口函数
- MySQL · TokuDB · checkpoint过程
- MySQL · 特性分析 · 内部临时表
- MySQL · 最佳实践 · 空间优化
- SQLServer · 最佳实践 · 数据库实现大容量插入的几种方式
- 数据库内核月报 - 2016/05
- MySQL · 引擎特性 · 基于InnoDB的物理复制实现
- MySQL · 特性分析 · MySQL 5.7新特性系列一
- PostgreSQL · 特性分析 · 逻辑结构和权限体系
- MySQL · 特性分析 · innodb buffer pool相关特性
- PG&GP · 特性分析 · 外部数据导入接口实现分析
- SQLServer · 最佳实践 · 透明数据加密在SQLServer的应用
- MySQL · TokuDB · 日志子系统和崩溃恢复过程
- MongoDB · 特性分析 · Sharded cluster架构原理
- PostgreSQL · 特性分析 · 统计信息计算方法
- MySQL · 捉虫动态 · left-join多表导致crash
- 数据库内核月报 - 2016/04
- MySQL · 参数故事 · innodb_additional_mem_pool_size
- GPDB · 特性分析 · Segment事务一致性与异常处理
- GPDB · 特性分析 · Segment 修复指南
- MySQL · 捉虫动态 · 并行复制外键约束问题二
- PgSQL · 性能优化 · 如何潇洒的处理每天上百TB的数据增量
- Memcached · 最佳实践 · 热点 Key 问题解决方案
- MongoDB · 最佳实践 · 短连接Auth性能优化
- MySQL · 最佳实践 · RDS 只读实例延迟分析
- MySQL · TokuDB · TokuDB索引结构--Fractal Tree
- MySQL · TokuDB · Savepoint漫谈
- 数据库内核月报 - 2016/03
- MySQL · TokuDB · 事务子系统和 MVCC 实现
- MongoDB · 特性分析 · MMAPv1 存储引擎原理
- PgSQL · 源码分析 · 优化器逻辑推理
- SQLServer · BUG分析 · Agent 链接泄露分析
- Redis · 特性分析 · AOF Rewrite 分析
- MySQL · BUG分析 · Rename table 死锁分析
- MySQL · 物理备份 · Percona XtraBackup 备份原理
- GPDB · 特性分析· GreenPlum FTS 机制
- MySQL · 答疑解惑 · 备库Seconds_Behind_Master计算
- MySQL · 答疑解惑 · MySQL 锁问题最佳实践
- 数据库内核月报 - 2016/02
- MySQL · 引擎特性 · InnoDB 文件系统之文件物理结构
- MySQL · 引擎特性 · InnoDB 文件系统之IO系统和内存管理
- MySQL · 特性分析 · InnoDB transaction history
- PgSQL · 会议见闻 · PgConf.Russia 2016 大会总结
- PgSQL · 答疑解惑 · PostgreSQL 9.6 并行查询实现分析
- MySQL · TokuDB · TokuDB之黑科技工具
- PgSQL · 性能优化 · PostgreSQL TPC-C极限优化玩法
- MariaDB · 版本特性 · MariaDB 的 GTID 介绍
- MySQL · 特性分析 · 线程池
- MySQL · 答疑解惑 · mysqldump tips 两则
- 数据库内核月报 - 2016/01
- MySQL · 引擎特性 · InnoDB 事务锁系统简介
- GPDB · 特性分析· GreenPlum Primary/Mirror 同步机制
- MySQL · 专家投稿 · MySQL5.7 的 JSON 实现
- MySQL · 特性分析 · 优化器 MRR & BKA
- MySQL · 答疑解惑 · 物理备份死锁分析
- MySQL · TokuDB · Cachetable 的工作线程和线程池
- MySQL · 特性分析 · drop table的优化
- MySQL · 答疑解惑 · GTID不一致分析
- PgSQL · 特性分析 · Plan Hint
- MariaDB · 社区动态 · MariaDB on Power8 (下)
- 数据库内核月报 - 2015/12
- MySQL · 引擎特性 · InnoDB 事务子系统介绍
- PgSQL · 特性介绍 · 全文搜索介绍
- MongoDB · 捉虫动态 · Kill Hang问题排查记录
- MySQL · 参数优化 ·RDS MySQL参数调优最佳实践
- PgSQL · 特性分析 · 备库激活过程分析
- MySQL · TokuDB · 让Hot Backup更完美
- PgSQL · 答疑解惑 · 表膨胀
- MySQL · 特性分析 · Index Condition Pushdown (ICP)
- MariaDB · 社区动态 · MariaDB on Power8
- MySQL · 特性分析 · 企业版特性一览
- 数据库内核月报 - 2015/11
- MySQL · 社区见闻 · OOW 2015 总结 MySQL 篇
- MySQL · 特性分析 · Statement Digest
- PgSQL · 答疑解惑 · PostgreSQL 用户组权限管理
- MySQL · 特性分析 · MDL 实现分析
- PgSQL · 特性分析 · full page write 机制
- MySQL · 捉虫动态 · MySQL 外键异常分析
- MySQL · 答疑解惑 · MySQL 优化器 range 的代价计算
- MySQL · 捉虫动态 · ORDER/GROUP BY 导致 mysqld crash
- MySQL · TokuDB · TokuDB 中的行锁
- MySQL · 捉虫动态 · order by limit 造成优化器选择索引错误
- 数据库内核月报 - 2015/10
- MySQL · 引擎特性 · InnoDB 全文索引简介
- MySQL · 特性分析 · 跟踪Metadata lock
- MySQL · 答疑解惑 · 索引过滤性太差引起CPU飙高分析
- PgSQL · 特性分析 · PG主备流复制机制
- MySQL · 捉虫动态 · start slave crash 诊断分析
- MySQL · 捉虫动态 · 删除索引导致表无法打开
- PgSQL · 特性分析 · PostgreSQL Aurora方案与DEMO
- TokuDB · 捉虫动态 · CREATE DATABASE 导致crash问题
- PgSQL · 特性分析 · pg_receivexlog工具解析
- MySQL · 特性分析 · MySQL权限存储与管理
- 数据库内核月报 - 2015/09
- MySQL · 引擎特性 · InnoDB Adaptive hash index介绍
- PgSQL · 特性分析 · clog异步提交一致性、原子操作与fsync
- MySQL · 捉虫动态 · BUG 几例
- PgSQL · 答疑解惑 · 诡异的函数返回值
- MySQL · 捉虫动态 · 建表过程中crash造成重建表失败
- PgSQL · 特性分析 · 谈谈checkpoint的调度
- MySQL · 特性分析 · 5.6 并行复制恢复实现
- MySQL · 备库优化 · relay fetch 备库优化
- MySQL · 特性分析 · 5.6并行复制事件分发机制
- MySQL · TokuDB · 文件目录谈
- 数据库内核月报 - 2015/08
- MySQL · 社区动态 · InnoDB Page Compression
- PgSQL · 答疑解惑 · RDS中的PostgreSQL备库延迟原因分析
- MySQL · 社区动态 · MySQL5.6.26 Release Note解读
- PgSQL · 捉虫动态 · 执行大SQL语句提示无效的内存申请大小
- MySQL · 社区动态 · MariaDB InnoDB表空间碎片整理
- PgSQL · 答疑解惑 · 归档进程cp命令的core文件追查
- MySQL · 答疑解惑 · open file limits
- MySQL · TokuDB · 疯狂的 filenum++
- MySQL · 功能分析 · 5.6 并行复制实现分析
- MySQL · 功能分析 · MySQL表定义缓存
- 数据库内核月报 - 2015/07
- MySQL · 引擎特性 · Innodb change buffer介绍
- MySQL · TokuDB · TokuDB Checkpoint机制
- PgSQL · 特性分析 · 时间线解析
- PgSQL · 功能分析 · PostGIS 在 O2O应用中的优势
- MySQL · 引擎特性 · InnoDB index lock前世今生
- MySQL · 社区动态 · MySQL内存分配支持NUMA
- MySQL · 答疑解惑 · 外键删除bug分析
- MySQL · 引擎特性 · MySQL logical read-ahead
- MySQL · 功能介绍 · binlog拉取速度的控制
- MySQL · 答疑解惑 · 浮点型的显示问题
- 数据库内核月报 - 2015/06
- MySQL · 引擎特性 · InnoDB 崩溃恢复过程
- MySQL · 捉虫动态 · 唯一键约束失效
- MySQL · 捉虫动态 · ALTER IGNORE TABLE导致主备不一致
- MySQL · 答疑解惑 · MySQL Sort 分页
- MySQL · 答疑解惑 · binlog event 中的 error code
- PgSQL · 功能分析 · Listen/Notify 功能
- MySQL · 捉虫动态 · 任性的 normal shutdown
- PgSQL · 追根究底 · WAL日志空间的意外增长
- MySQL · 社区动态 · MariaDB Role 体系
- MySQL · TokuDB · TokuDB数据文件大小计算
- 数据库内核月报 - 2015/05
- MySQL · 引擎特性 · InnoDB redo log漫游
- MySQL · 专家投稿 · MySQL数据库SYS CPU高的可能性分析
- MySQL · 捉虫动态 · 5.6 与 5.5 InnoDB 不兼容导致 crash
- MySQL · 答疑解惑 · InnoDB 预读 VS Oracle 多块读
- PgSQL · 社区动态 · 9.5 新功能BRIN索引
- MySQL · 捉虫动态 · MySQL DDL BUG
- MySQL · 答疑解惑 · set names 都做了什么
- MySQL · 捉虫动态 · 临时表操作导致主备不一致
- TokuDB · 引擎特性 · zstd压缩算法
- MySQL · 答疑解惑 · binlog 位点刷新策略
- 数据库内核月报 - 2015/04
- MySQL · 引擎特性 · InnoDB undo log 漫游
- TokuDB · 产品新闻 · RDS TokuDB小手册
- PgSQL · 社区动态 · 说一说PgSQL 9.4.1中的那些安全补丁
- MySQL · 捉虫动态 · 连接断开导致XA事务丢失
- MySQL · 捉虫动态 · GTID下slave_net_timeout值太小问题
- MySQL · 捉虫动态 · Relay log 中 GTID group 完整性检测
- MySQL · 答疑释惑 · UPDATE交换列单表和多表的区别
- MySQL · 捉虫动态 · 删被引用索引导致crash
- MySQL · 答疑释惑 · GTID下auto_position=0时数据不一致
- 数据库内核月报 - 2015/03
- MySQL · 答疑释惑· 并发Replace into导致的死锁分析
- MySQL · 性能优化· 5.7.6 InnoDB page flush 优化
- MySQL · 捉虫动态· pid file丢失问题分析
- MySQL · 答疑释惑· using filesort VS using temporary
- MySQL · 优化限制· MySQL index_condition_pushdown
- MySQL · 捉虫动态·DROP DATABASE外键约束的GTID BUG
- MySQL · 答疑释惑· lower_case_table_names 使用问题
- PgSQL · 特性分析· Logical Decoding探索
- PgSQL · 特性分析· jsonb类型解析
- TokuDB ·引擎机制· TokuDB线程池
- 数据库内核月报 - 2015/02
- MySQL · 性能优化· InnoDB buffer pool flush策略漫谈
- MySQL · 社区动态· 5.6.23 InnoDB相关Bugfix
- PgSQL · 特性分析· Replication Slot
- PgSQL · 特性分析· pg_prewarm
- MySQL · 答疑释惑· InnoDB丢失自增值
- MySQL · 答疑释惑· 5.5 和 5.6 时间类型兼容问题
- MySQL · 捉虫动态· 变量修改导致binlog错误
- MariaDB · 特性分析· 表/表空间加密
- MariaDB · 特性分析· Per-query variables
- TokuDB · 特性分析· 日志详解
- 数据库内核月报 - 2015/01
- MySQL · 性能优化· Group Commit优化
- MySQL · 新增特性· DDL fast fail
- MySQL · 性能优化· 启用GTID场景的性能问题及优化
- MySQL · 捉虫动态· InnoDB自增列重复值问题
- MySQL · 优化改进· 复制性能改进过程
- MySQL · 谈古论今· key分区算法演变分析
- MySQL · 捉虫动态· mysql client crash一例
- MySQL · 捉虫动态· 设置 gtid_purged 破坏AUTO_POSITION复制协议
- MySQL · 捉虫动态· replicate filter 和 GTID 一起使用的问题
- TokuDB·特性分析· Optimize Table
- 数据库内核月报 - 2014/12
- MySQL· 性能优化·5.7 Innodb事务系统
- MySQL· 踩过的坑·5.6 GTID 和存储引擎那会事
- MySQL· 性能优化·thread pool 原理分析
- MySQL· 性能优化·并行复制外建约束问题
- MySQL· 答疑释惑·binlog event有序性
- MySQL· 答疑释惑·server_id为0的Rotate
- MySQL· 性能优化·Bulk Load for CREATE INDEX
- MySQL· 捉虫动态·Opened tables block read only
- MySQL· 优化改进· GTID启动优化
- TokuDB· Binary Log Group Commit with TokuDB
- 数据库内核月报 - 2014/11
- MySQL· 捉虫动态·OPTIMIZE 不存在的表
- MySQL· 捉虫动态·SIGHUP 导致 binlog 写错
- MySQL· 5.7改进·Recovery改进
- MySQL· 5.7特性·高可用支持
- MySQL· 5.7优化·Metadata Lock子系统的优化
- MySQL· 5.7特性·在线Truncate undo log 表空间
- MySQL· 性能优化·hash_scan 算法的实现解析
- TokuDB· 版本优化· 7.5.0
- TokuDB· 引擎特性· FAST UPDATES
- MariaDB· 性能优化·filesort with small LIMIT optimization
- 数据库内核月报 - 2014/10
- MySQL· 5.7重构·Optimizer Cost Model
- MySQL· 系统限制·text字段数
- MySQL· 捉虫动态·binlog重放失败
- MySQL· 捉虫动态·从库OOM
- MySQL· 捉虫动态·崩溃恢复失败
- MySQL· 功能改进·InnoDB Warmup特性
- MySQL· 文件结构·告别frm文件
- MariaDB· 新鲜特性·ANALYZE statement 语法
- TokuDB· 主备复制·Read Free Replication
- TokuDB· 引擎特性·压缩
- 数据库内核月报 - 2014/09
- MySQL· 捉虫动态·GTID 和 DELAYED
- MySQL· 限制改进·GTID和升级
- MySQL· 捉虫动态·GTID 和 binlog_checksum
- MySQL· 引擎差异·create_time in status
- MySQL· 参数故事·thread_concurrency
- MySQL· 捉虫动态·auto_increment
- MariaDB· 性能优化·Extended Keys
- MariaDB·主备复制·CREATE OR REPLACE
- TokuDB· 参数故事·数据安全和性能
- TokuDB· HA方案·TokuDB热备
- 数据库内核月报 - 2014/08
- MySQL· 参数故事·timed_mutexes
- MySQL· 参数故事·innodb_flush_log_at_trx_commit
- MySQL· 捉虫动态·Count(Distinct) ERROR
- MySQL· 捉虫动态·mysqldump BUFFER OVERFLOW
- MySQL· 捉虫动态·long semaphore waits
- MariaDB·分支特性·支持大于16K的InnoDB Page Size
- MariaDB·分支特性·FusionIO特性支持
- TokuDB· 性能优化·Bulk Fetch
- TokuDB· 数据结构·Fractal-Trees与LSM-Trees对比
- TokuDB·社区八卦·TokuDB团队