您现在的位置是:亿华云 > IT科技类资讯
数据库MySQL一般查询日志或者慢查询日志历史数据的清理
亿华云2025-10-02 18:42:09【IT科技类资讯】2人已围观
简介general log&slow query log对于MySQL的一般查询日志和慢查询日志,开启比较简单,其中公用的一个参数是log_output,log_output控制着慢查询和一般查询
general log&slow query log
对于MySQL的数据数据一般查询日志和慢查询日志,开启比较简单,般查其中公用的询日一个参数是log_output,log_output控制着慢查询和一般查询日志的志或者慢输出方向可以是表(mysql.general_log,mysql.slow_log)或者文件(有参数general_log_file和slow_query_log_file配置决定)或者同时输出到表和文件(想不明白,什么时候需要同时输出到表和文件)。查询
但是日志两者受log_output参数影响,输出的历史理目标总是一致的,也就是数据数据要么都写入表,或者要么都写入文件,般查不会一个输出到表,询日一个输出到文件。志或者慢
--slow log 相关参数 select * from performance_schema.global_variables where variable_name in (slow_query_log,查询log_output,slow_query_log_file,long_query_time) --general log 相关参数 select * from performance_schema.global_variables where variable_name in (general_log,log_output,general_log_file)对于上述两种日志,系统默认不会清理,日志因此在开启了相关日志之后,历史理需要人为清理。数据数据
如何清理历史general log&slow query log
1,当输出目标为表的时候
无法直接删除,如果直接删除的话,会出现“ERROR 1556 (HY000): You can’t use locks with log tables.”的错误提示
以general log为例,需要先关闭general_log,然后重命名general_log这个表,服务器托管
在对重命名之后的表执行删除,最后在重命名回来,最后开启general_log(如果有必要的话)
SET GLOBAL general_log = OFF; RENAME TABLE general_log TO general_log_temp; DELETE FROM general_log_temp WHERE event_time < DATE(NOW()); RENAME TABLE general_log_temp TO general_log; SET GLOBAL general_log = ON; --slow log 同理 SET GLOBAL slow_query_log = OFF; RENAME TABLE slow_log TO slow_log_temp; DELETE FROM slow_log_temp WHERE start_time < DATE(NOW()); RENAME TABLE slow_log_temp TO slow_log; SET GLOBAL slow_query_log = ON;如果对重命名之后的表(general_log或者是slow_log)没有再次重命名回来,会发生什么?
参加如下截图,如果没有找到对应的表(general_log或者是slow_log),在输出目标为表的情况下,会提示无法找到对应的表,将无法开启对应的日志
2,当输出目标为文件的时候
当输出目标为文件的时候,在linux下,直接使用rm命名删除即可,如果在开启了一般查询日志或者是慢查询日志,删除对应的日志文件,并不影响数据库的正常使用。网上有说需要停止MySQL服务然后重命名文件然后在创建新的文件啥的,在Linux下并不是必须的亿华云,不知道在windows下是什么情况,没兴趣试。
当然也不是说就建议始终这种暴力的方式清理日志文件,在Linux下,删除了默认的日志文件(或者重命名了原日志文件),要想再次生成日志文件
可以使用mysqladmin flush-logs 是SQL命令flush slow logs;flush general logs; 重启MySQL服务均可重新生成对应的日志文件。
注意:当对应的文件是存在的时候,上述命名执行之后是没有影响的(也不会清理对应的日志文件)
以下偏离主题
当输出目标为表的时候的解析
不管是general_log或者是slow_log,对应的SQL语句都是二进制格式的,需要使用convert(sql_text using UTF8)做一个转换,才变得具有可读性。
当输出目标为表的时候对性能的云南idc服务商影响
据个人测试,在请求量不大的数据库上,开启general_log或者是slow_log,对性能影响并没有非常明显。理论家们一方面强调说MySQL的处理并发上多强悍,一方面又说开启general_log对性能影响很大,会不会自相矛盾呢?关于general_log,在zabbix监控下,测试环境TPS不过百的情况下(每秒写入general log不超过100条数据),开启general_log之后并CPU负载几乎没有变化,CPU高点是在做其他压力测试。尤其是slow_log这种写入不是太频繁的日志,直接写入到表中,对性能的影响有限,比后面再去花时间解析文件……
当然不排除TPS在上千或者上万甚至更高之后,开启general_log会产生较大的影响,当然没事也不会闲的蛋疼去开general_log。
很赞哦!(99)
相关文章
- 会让国人沸腾的国产5G芯片,还要过多少重山?
- 付款完成后,您只需耐心等待,如果您注册成功,系统会提示您。这里需要注意的是,域名是一个即时产品,只有在最终付款成功时才能预订,注册成功后不能更改。
- 域名资源有限,好域名更是有限,但机会随时都有,这取决于我们能否抓住机会。一般观点认为,国内域名注册太深,建议优先考虑外国注册人。外国注册人相对诚实,但价格差别很大,从几美元到几十美元不等。域名投资者应抓住机遇,尽早注册国外域名。
- 为什么喜欢国外注册域名?国外注册域名注意什么?
- 新华三携手宁夏移动 拓宽数据西游路
- 5、使用企业名称的英文名称作为域名也是国内许多企业选择域名的一种方式,特别适合一些与计算机、网络和通信相关的行业。
- 只要我们做的是从目前的市场情况选择域名,从简单易记,从个性特征上,我们就可以找到一个好域名进行注册。域名注册进行域名记录和解析以及绑定网站后,客户可以通过URL登录您的网站。
- 3、考虑出售域名
- 新华三HPE Alletra 5000新一代混闪存储系统重磅发布
- 3、商标域名一经注册,就可以作为域名裁决过程中的主要信息之一。这可以大大增加公司被抢注的相关域名胜诉的机会。
热门文章
站长推荐
占地16000方,迪拜开通运营全球最大太阳能供电数据中心
a、变更前的公司证件扫描件(代码证或者营业执照)及联系人身份证复印件、变更后的公司证件扫描件(代码证或者营业执照)及新的联系人身份证复印件;身份证复印件需本人签名,公司证件复印件需加盖公章。
.com域名是国际最广泛流行的通用域名,目前全球注册量第一的域名,公司企业注册域名的首选。国际化公司通常会注册该类域名。
为什么起域名意义非凡?起域名有什么名堂?
2022年第十七届中国企业年终评选榜单揭晓:联想ST650 V2服务器荣获2022年度中国IT行业人工智能优秀产品奖
前面这两个步骤都是在本机完成的。到这里还没有涉及真正的域名解析服务器,如果在本机中仍然无法完成域名的解析,就会真正请求域名服务器来解析这个域名了。
tk域名是什么域名?新手对tk域名有什么看法?
旧域名的外链是否会对新建站点产生影响?