比尔云BierYun--阿里云最新优惠活动
阿里云优惠码丨阿里云代金券

MySQL slow_log表不能修改成innodb引擎

MySQL slow_log表不能修改成innodb引擎

背景

从mysql.slow_log 获取慢查询日志很慢,该表是csv表,没有索引。
想添加索引来加速访问,而csv引擎不能添加索引(csv引擎存储是以逗号分割的文本来存储的),只能改存储引擎来添加索引了

mysql.slow_log表能改成myisam,不能改成innodb

3f43be2e702cc9f8b3236a68e55324a2.png

mysql> set global  slow_query_log=off;
Query OK, 0 rows affected (0.00 sec)

mysql> alter table  mysql.slow_log engine=innodb;
ERROR 1579 (HY000): This storage engine cannot be used for log tables"
mysql> alter table  mysql.slow_log engine=myisam;
Query OK, 33760 rows affected (0.37 sec)
Records: 33760  Duplicates: 0  Warnings: 0

mysql.general_log也不能改成innodb

mysql> alter table  mysql.general_log engine=myisam;
Query OK, 242956 rows affected (2.41 sec)
Records: 242956  Duplicates: 0  Warnings: 0

mysql> alter table  mysql.general_log engine=innodb;
ERROR 1579 (HY000): This storage engine cannot be used for log tables"

官方文档
7bab22c482418128cfca81646249857f.png

官方文档说明,日志表只支持csv引擎和myisam引擎。
为什么不支持innodb引擎并未说明

基于什么来考虑不支持innodb表的了?
像朋友请教了下

估计是日志表 这种引擎会耗费大量的redo, undo 资源吧

这是没有必要的。。。这些数据不重要。。

更改日志表存储引擎

SET @old_log_state = @@global.general_log;
SET GLOBAL general_log = 'OFF';
ALTER TABLE mysql.general_log ENGINE = MyISAM;
SET GLOBAL general_log = @old_log_state;

归档日志表

USE mysql;
DROP TABLE IF EXISTS general_log2;
CREATE TABLE general_log2 LIKE general_log;
RENAME TABLE general_log TO general_log_backup, general_log2 TO general_log;

参考

Selecting General Query Log and Slow Query Log Output Destinations

原文地址https://www.cnblogs.com/YangJiaXin/p/10679854.html

未经允许不得转载:阿里云代理商 » MySQL slow_log表不能修改成innodb引擎
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

强烈推荐

高性能SSD云服务器ECS抗攻击,高可用云数据库RDS