『叶问』#42,可以禁用MyISAM引擎吗

Posted 老叶茶馆_

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了『叶问』#42,可以禁用MyISAM引擎吗相关的知识,希望对你有一定的参考价值。

MyISAM的适用场景越来越少了。

随着mysql 8.0的推出,系统表已经全面采用InnoDB引擎,不再需要MyISAM引擎。另外,MGR中也不支持MyISAM引擎。

因此,基本上可以考虑全面禁止使用MyISAM引擎了,问题是,这可行吗?

答案是肯定的,可以做到。

从MySSQL 5.7.8开始,新增一个选项 disabled_storage_engines,只需要设置下即可:

disabled_storage_engines = MyISAM

这就完美地实现禁用MyISAM的目的了。

另外,这么设置的话,是不会影响MySQL实例初始化的。即便是在MySQL 5.7版本中,系统表要使用MyISAM引擎,也不会影响生成MyISAM引擎的系统表。

disabled_storage_engines is disabled and has no effect if the server is started with any of these options: --bootstrap, --initialize, --initialize-insecure, --skip-grant-tables.

不过,设置该选项后可能会影响 mysql_upgrade 升级:

Setting disabled_storage_engines might cause an issue with mysql_upgrade. For details, see Section 4.4.7, “mysql_upgrade — Check and Upgrade MySQL Tables”.

执行 mysql_upgrade 进行升级时可能会报错:

mysql_upgrade: [ERROR] 3161: Storage engine MyISAM is disabled
(Table creation is disallowed).

这时候需要临时关闭该选项,等待升级完成后再重新启用即可。


《实战MGR》视频课程

戳此小程序即可直达B站

或复制链接在浏览器中打开

  • https://space.bilibili.com/1363850082


文章推荐:


点击文末“阅读原文”直达「叶问」专栏

以上是关于『叶问』#42,可以禁用MyISAM引擎吗的主要内容,如果未能解决你的问题,请参考以下文章

(转)InnoDB与MyISAM引擎区别

MYSQL 5.6中禁用INNODB引擎

自己对MyISAM存储引擎的理解

MYSQL: INNODB 还是 MYISAM?

《叶问》36期,MySQL最多只能用到128个逻辑CPU,是真的吗

『叶问』#41,三节点的MGR集群,有两个节点宕机后还能正常工作吗