1. 最常见的还是分表,但是分表有一个弊端 就是有些查询受限制,对于每一个查询条件都需要把分表 依赖列 传进来。
2.写事务的并发度 依赖于索引设计和文件的io的刷盘速度,如果依赖于索引的锁设计没有问题的话,锁的占用就是行级锁,可以大大提高性能。
3. 由于mysql事务是基于 redo和undo日志来实现的,那么如果数据不是强一致性 并且允许丢失的情况下,可以考虑设置redo和undo 日志的刷新级别,交给操作系统来定时刷盘,这样就没有了io的性能瓶颈。
4.可以考虑在7层或者四层接入的时候 将写流量导入到 主mysql节点所在的机房,将锁占用时间卡在局域网访问,减少锁的占用时间
5.如果真的 并发瓶颈 依赖于网络io,那么可以考虑分库的设计,使用多主多从 来解决单台主mysql节点的性能问题