当前位置: 首页 > 数据库 > 数据库综合 >正文

你对MySQL BlackHole引擎有多少了解?

来源:互联网时间:2021-09-11 17:00:43编辑:网友分享
像MyISAM、InnoDB,BlackHole是另一种MySQL引擎,从字面意思来看,其表现就像一个黑洞,只进不出,进来就消失。

概念

像MyISAM、InnoDB,BlackHole是另一种MySQL引擎,从字面意思来看,
其表现就像一个黑洞,只进不出,进来就消失。换句话说,任何往其中写的数据都将丢失,有点像Linux的/dev/null
比如一个表test的引擎是BlackHole,任何对这个表的insert都将丢失,
对它的select永远返回空集,对应的数据目录下只有一个test.frm文件,且没有其他文件与之关联。

使用场景

一个并不保存任何数据的引擎,到底有什么意义?
关键在于,虽然其不保存数据,但对数据库的操作仍旧记录在binlog日志中。
这就带来一个好处,可以将其作为主从复制的中介,将原来从主库中同步的操作变为从作为中介的BlackHole引擎数据库中同步。

1.作为伪主库分担主库负担

众所周知,当从库比较多的时候,所有从库都从主库load数据将加重主库的负担。但如果是从BlackHole的伪主库中同步就可以减轻主库的负担。原有主从架构大概就像下面这样:

你对MySQL BlackHole引擎有多少了解?特别要配置:log-slave-update = 1,只有这样,主库中的操作才会同步到BlackHole的binlog中,否则,只有直接针对BlackHole的操作才会记录到binlog。
忽略InnoDB:skip-innodb,当建表语句带有engine=innodb时,将使用默认的BlackHole引擎。
需要提醒的是,当采用这种架构时,数据同步多了中间一层,需要进一步考虑延迟问题。

推荐学习:《mysql视频教程》

以上就是你对MySQL BlackHole引擎有多少了解?的详细内容,更多请关注web开发者其它相关文章!

上一篇: 深入了解MySQL中的事务和锁

下一篇:一起聊聊redis的scan操作

您可能感兴趣的文章

相关阅读