key_buffer_size仅影响MyISAM索引缓存,对InnoDB无效;应通过information_schema查MyISAM索引实际占用并设为1.2--1.5倍,避免过大导致锁竞争或内存浪费。key_buffer_size 是给 MyISAM 表用的,InnoDB 完全不认它很多人调大 key_buffer_size 是想加速查询,结果发现没效果------因为你的表大概率是 InnoDB 引擎。MySQL 5.5 之后默认引擎就是 InnoDB,而 key_buffer_size 只影响 MyISAM 的索引缓存,对 InnoDB 的 innodb_buffer_pool_size 零作用。确认方法很简单:SHOW TABLE STATUS LIKE 'your_table_name'; 看 Engine 字段;或者批量查:SELECT table_name, engine FROM information_schema.tables WHERE table_schema = 'your_db';如果全是 InnoDB,key_buffer_size 设成 8M 或 16M 就够了,再大纯属浪费内存如果还有 MyISAM 表(比如老系统里的 mysql 系统库部分表),才需要按实际索引大小谨慎调高设得过大可能挤占其他关键内存(比如 innodb_buffer_pool_size 或连接缓冲),反而拖慢整体性能怎么查 MyISAM 索引真实占用,避免拍脑袋设值不能看磁盘上 .MYI 文件大小,因为里面含空闲空间和碎片;得查 MySQL 内部统计的"已用索引长度"。执行这条 SQL:SELECT SUM(index_length) FROM information_schema.tables WHERE engine = 'MyISAM' AND table_schema NOT IN ('information_schema', 'performance_schema', 'sys');结果单位是字节,除以 1024÷1024 得到 MBkey_buffer_size 建议设为该值的 1.2--1.5 倍(留点增长余量,但别超过 2 倍)如果总和不到 32MB,保持默认 8M 或设成 16M 即可,没必要动注意:这个值会随数据变更缓慢增长,不用天天重算,三个月左右看一次足够my.cnf 里改完不生效?检查这三处硬伤改了 key_buffer_size 重启 mysqld 还是没变,常见卡点就这几个: 知网AI智能写作 知网AI智能写作,写文档、写报告如此简单
相关推荐
金銀銅鐵26 分钟前
[Python] 扩展欧几里得算法Duckdblab41 分钟前
DuckDB 性能调优终极指南:打造闪电般的分析体验带派擂总1 小时前
Python全栈开发精华版最全合集(包含各种面试题) Day24_异常和错误笃行3503 小时前
金仓数据库数据安全双防线:静态存储加密与传输加密实战笃行3503 小时前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救笃行3503 小时前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环金銀銅鐵4 小时前
n^5 和 n 的个位数是否总相等?aqi008 小时前
15天学会AI应用开发(九)利用Chroma持久化向量数据