13518219792

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

频繁插入(insert)的业务,用什么存储引擎更合适?|数据库系列

继续回答星球水友提问:

创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都做网站、网站制作、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的芦溪网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

沈老师,MyISAM只支持表锁,但网上文章却说,在并发插入量比较大的时候,比较适合使用MyISAM,这矛盾吗?

这个问题,涉及MySQL表锁的一些细节,借着这个问题,系统性说下表锁的“所以然”。

画外音:网上不少文章只说结论,不说为什么,容易让人蒙圈。

MySQL表锁知识系统性梳理。

哪些存储引擎使用表锁?

MySQL,除InnoDB支持行锁外,MySQL的其他存储引擎均只使用表锁,例如:MyISAM, MEMORY, MERGE等。

表锁有什么好处?

画外音:这样的一些场景,使用MyISAM比InnoDB更优。

表锁是怎么运作的?

和其他临界资源的读写锁类似。

写时,要加写锁:

读时,要加读锁:

表锁释放时:

如果写锁队列和读锁队列里都有锁,写有更高的优先级,即写锁队列先出列。这么做的原因是,如果有“大查询”,可能会导致写锁被批量“饿死”,而写锁往往释放很快。

画外音:潜台词是,如果有大量并发update请求,select会等所有update请求执行完才执行。

如何查看表锁情况?

如果要分析表锁冲突情况,可查看:T

这两个变量。

使用以下命令查看:

 
 
 
 
  1. show status like 'Table%'; 

如果等待表锁的次数占比较大,说明表锁可能是潜在瓶颈。 说了半天,还是没有讲到点子上,为什么在并发插入量比较大的时候,比较适合使用MyISAM呢?不会因为表锁频繁冲突而导致吞吐量降低吗?

画外音:知识的系统性,比问题答案更重要。

知识点一:

MyISAM的索引与记录存储分离,有单独的区域存储行记录,PK是非聚集索引。

 知识点二:

MyISAM表,如果数据文件(data file)紧密存储,中间没有空闲块(free blocks),数据总是插入到数据文件的尾部(end),就如同追加日志一样,性能很高,此时的并发insert与select是不加锁的(lock free)。

如上图所示:

知识点三:

MyISAM表,如果数据文件(data file)中间有空洞(hole),上述机制会失效,直到空洞被新数据填满,又会启用不加锁机制。

空洞是怎么导致的?

删除或者修改数据,都可能导致空洞。

如上图所示:

再如上图所示:

结论

虽然MyISAM只支持表锁,但高并发select与insert的业务场景,上述机制使得MyISAM的表锁依然有非常强劲的性能。

画外音:本文基于MySQL5.6。

希望解答了这位水友的疑问。

【本文为专栏作者“58沈剑”原创稿件,转载请联系原作者】


分享题目:频繁插入(insert)的业务,用什么存储引擎更合适?|数据库系列
文章位置:http://cdbrznjsb.com/article/cdoohhh.html

其他资讯

让你的专属顾问为你服务