0

0

mysql安装时选择合适的存储引擎并进行配置

P粉602998670

P粉602998670

发布时间:2026-01-25 11:05:47

|

480人浏览过

|

来源于php中文网

原创

MySQL 8.0 默认且强制使用 InnoDB,MyISAM 已被移除系统表支持;关键配置 innodb_buffer_pool_size 建议设为物理内存的 50%–75%,并需配合 innodb_file_per_table、innodb_flush_log_at_trx_commit 等参数确保稳定性与数据安全。

mysql安装时选择合适的存储引擎并进行配置

MySQL 8.0 默认用的是 InnoDB,别手动切 MyISAM

MySQL 5.5 之后就默认启用 InnoDB,8.0 更是彻底移除了 MyISAM 作为系统表的存储引擎(mysql 库下部分表仍用,但用户不应依赖)。如果你在安装时看到引擎选择界面,或想改配置文件,优先确认是否真有必要切换——绝大多数业务场景(事务、外键、崩溃恢复)都要求 InnoDB

  • MyISAM 不支持事务和行级锁,只适合极低并发、纯读、无一致性要求的场景(比如日志归档表)
  • 强行把 InnoDB 表改成 MyISAM 可能导致 ALTER TABLE ... ENGINE=MyISAM 失败,尤其当表含外键或全文索引时
  • MySQL 8.0 的数据字典完全基于 InnoDB,混合引擎会增加元数据不一致风险

innodb_buffer_pool_size 是最关键的配置项

它决定 MySQL 能用多少内存缓存数据和索引。设太小,磁盘 I/O 暴涨;设太大,可能挤占 OS 或其他进程内存,触发 OOM Killer。

  • 生产环境建议设为物理内存的 50%–75%,但不超过 80%
  • 若服务器独占 MySQL,且总内存 ≥16GB,可设为 12G(即 innodb_buffer_pool_size = 12G
  • 不要写成 12000M12288M——MySQL 会识别 G/M 单位,但整数更稳妥;避免小数(如 12.5G
  • 该参数动态生效需 MySQL 5.7+ 且开启 innodb_buffer_pool_chunk_size 配合,否则需重启

其他影响引擎行为的关键配置

仅调 ENGINE=InnoDB 不够,还需配套参数防止隐式降级或异常行为:

  • innodb_file_per_table = ON:每个表一个 .ibd 文件,便于单表迁移、空间回收;MySQL 5.6.6+ 默认开启,但旧配置可能关着
  • innodb_flush_log_at_trx_commit = 1:保证每次事务提交都刷盘,数据绝对安全;设为 20 会丢秒级数据,仅测试可用
  • innodb_log_file_size:建议设为 buffer_pool_size 的 25% 左右(如 buffer_pool=12G,则 log_file_size≈3G),过大延长崩溃恢复时间,过小频繁 checkpoint 影响性能
  • 禁用 skip-innodb ——某些一键安装包或旧脚本会加这个,会导致 InnoDB 引擎不可用,连 SHOW ENGINES 都看不到它

验证引擎是否生效及常见误判点

装完别只看安装界面勾选了什么,得进库实测:

刺鸟创客
刺鸟创客

一款专业高效稳定的AI内容创作平台

下载
SHOW ENGINES;

确认 InnoDB 行的 SUPPORT 列是 DEFAULTYES;再建个表验证:

CREATE TABLE test_engine (id INT) ENGINE=InnoDB;
SHOW CREATE TABLE test_engine;

输出里必须明确出现 ENGINE=InnoDB。容易踩的坑:

  • 配置文件写了 default-storage-engine=MyISAM,但 MySQL 8.0 忽略该选项(已废弃),实际仍走 InnoDB,造成认知偏差
  • mysqld --initialize 初始化后没加载配置文件(比如 my.cnf 路径不对),所有配置无效
  • information_schema.TABLESENGINE 字段显示 NULL?那是视图或临时表,不是真实数据表

引擎选型和配置真正复杂的地方,不在“怎么填”,而在“改了之后有没有人动过线上表的 ENGINE 属性”——这种手工修改往往藏在部署脚本里,比配置文件更难追溯。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

665

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

247

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

515

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

256

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

531

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

600

2023.08.14

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 810人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号