MySQL大表删除导致服务器变慢的分析
2017-07-28 10:30
411 查看
---注意,在生产环境中MySQL删除表的时候 如果表过大,几十G 甚至上百G ,删除的时候要小心,要不然会导致MySQLhang住,从而影响业务;
1、MySQL在删除表的时候,一共分为2步:
①:buffer pool页面清除的过程
在删除表的时候,innodb会将文件在buffer pool中对应的页面清除,对于删除表的页面清除,只需要将页面从flush队列中删除即可,而不需要去做flush操作,这样就可以减少对系统的冲击;
②:删除ibd磁盘文件的过程(这个过程是很耗资源的也比较慢会影响数据库的性能)
2、正确的删除大表的姿势:
①:对表的系统文件做个硬链接,加速删除
如:ln /mysql/data/test/emp.ibd /mysql/data/test/emp.ibd.hdlk
[mysql@db2 test]$ ln /mysql/data/test/emp.ibd /mysql/data/test/emp.ibd.hdlk
[mysql@db2 test]$ ls -l
total 208
-rw-r--r-- 1 mysql mysql 65 Mar 3 10:35 db.opt
-rw-rw---- 1 mysql mysql 8556 May 12 04:40 emp.frm
-rw-rw---- 2 mysql mysql 98304 May 12 04:40 emp.ibd
-rw-rw---- 2 mysql mysql 98304 May 12 04:40 emp.ibd.hdlk
[mysql@db2 test]$
然后在数据库中执行:drop table emp; ---即可,
②:第二种方法就是分批删除数据,设定一个条件有序的删除,如:可以按照每天的数据删除或按照一个范围进行分批删除,
---注意,在生产数据库删除表的时候,如果表数据量过大要么分批删除 要么做硬链接的方式删除;
1、MySQL在删除表的时候,一共分为2步:
①:buffer pool页面清除的过程
在删除表的时候,innodb会将文件在buffer pool中对应的页面清除,对于删除表的页面清除,只需要将页面从flush队列中删除即可,而不需要去做flush操作,这样就可以减少对系统的冲击;
②:删除ibd磁盘文件的过程(这个过程是很耗资源的也比较慢会影响数据库的性能)
2、正确的删除大表的姿势:
①:对表的系统文件做个硬链接,加速删除
如:ln /mysql/data/test/emp.ibd /mysql/data/test/emp.ibd.hdlk
[mysql@db2 test]$ ln /mysql/data/test/emp.ibd /mysql/data/test/emp.ibd.hdlk
[mysql@db2 test]$ ls -l
total 208
-rw-r--r-- 1 mysql mysql 65 Mar 3 10:35 db.opt
-rw-rw---- 1 mysql mysql 8556 May 12 04:40 emp.frm
-rw-rw---- 2 mysql mysql 98304 May 12 04:40 emp.ibd
-rw-rw---- 2 mysql mysql 98304 May 12 04:40 emp.ibd.hdlk
[mysql@db2 test]$
然后在数据库中执行:drop table emp; ---即可,
②:第二种方法就是分批删除数据,设定一个条件有序的删除,如:可以按照每天的数据删除或按照一个范围进行分批删除,
---注意,在生产数据库删除表的时候,如果表数据量过大要么分批删除 要么做硬链接的方式删除;
相关文章推荐
- NUMA导致的MySQL服务器SWAP问题分析与解决方案
- NUMA导致的MySQL服务器SWAP问题分析与解决方案
- MySQL删除表时I/O错误的原因分析与解决
- 黄聪:MYSQL使服务器内存CPU占用过高问题的分析及解决方法
- Innodb中MySQL如何快速删除2T的大表
- 5种MySql 服务器集群方案的分析和比较
- SQLyog客户端无法连接MySQL服务器案例分析
- mysql安全删除大表
- 安装MYSQL遇到的问题后来无意发现是卸载的时候没有卸载完全导致,下面给出完整的卸载MySQL 5.1的卸载方法: 1、控制面板里的增加删除程序内进行删除 2、删除MySQL文件夹下的
- mysql 分析5语句的优化--索引添加删除
- mysql删除大表更快的drop table办法
- mysql服务器io等待高定位与分析
- MySQL Sending data导致查询很慢的问题详细分析
- [乐意黎原创]因误删除导致Mysql启动时出现system error 1067 has occurred及Plugin FEDERATED is disabled 错误提示的解决方法
- Mysql查询语句使用select.. for update导致的数据库死锁分析
- 服务器重启导致mysql同步出错
- mysql服务器查询慢原因分析与解决方法小结
- mysql服务器查询慢原因分析方法
- MySQL Insert语句单个批次数量过多导致的CPU性能问题分析
- MYSQL 服务器查询速度慢原因分析与解决办法