前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL slow_log表不能修改成innodb引擎

MySQL slow_log表不能修改成innodb引擎

作者头像
星哥玩云
发布2022-08-18 14:12:38
4930
发布2022-08-18 14:12:38
举报
文章被收录于专栏:开源部署

背景

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

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

MySQL slow_log表不能修改成innodb引擎
MySQL slow_log表不能修改成innodb引擎
代码语言:javascript
复制
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

代码语言:javascript
复制
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"

官方文档

MySQL slow_log表不能修改成innodb引擎
MySQL slow_log表不能修改成innodb引擎

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

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

估计是日志表 这种引擎会耗费大量的redo, undo 资源吧 这是没有必要的。。。这些数据不重要。。

更改日志表存储引擎并添加索引 mysql.general_log表

代码语言:javascript
复制
set sql_log_bin=0;
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;

mysql.slow_log表

代码语言:javascript
复制
set sql_log_bin=0;
set @old_slow_log_state=@@global.slow_query_log;
set global slow_query_log='OFF';
ALTER TABLE mysql.slow_log ENGINE = MyISAM;
alter table mysql.slow_log add index idx_query_time(query_time);
set global slow_query_log=@old_slow_log_state;

注意问题

更改日志表的存储引擎需要先关闭日志表,还需要不记录会话的binlog日志 不然,主从复制中,从库会出现sql线程错误

代码语言:javascript
复制
LAST_ERROR_MESSAGE: Worker 1 failed executing transaction '5a459629-1e13-11e9-a99d-74eacb7427c5:377210591' at master log mysql-bin.001278, end_log_pos 40623782; Error 'You cannot 'ALTER' a log table if logging is enabled' on query. Default database: ''. Query: 'ALTER TABLE mysql.slow_log ENGINE = MyISAM'

归档日志表 归档mysql.general_log表

代码语言:javascript
复制
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;

归档mysql.slow_log表

代码语言:javascript
复制
USE mysql;
DROP TABLE IF EXISTS slow_log2;
CREATE TABLE slow_log2 LIKE slow_log;
RENAME TABLE slow_log TO slow_log_backup, slow_log2 TO slow_log;

参考

代码语言:javascript
复制
Selecting General Query Log and Slow Query Log Output Destinations
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
文件存储
文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档