返回顶部
首页 > 资讯 > 数据库 >MySQL大表删除正确的姿势
  • 510
分享到

MySQL大表删除正确的姿势

2024-04-02 19:04:59 510人浏览 泡泡鱼
摘要

1、背景在生产环境有可能有删除某个不重要大表的需求,因为大表占用的大量磁盘空间,如果我们直接drop掉此表,通常需要20秒以上的时间,总会觉得会卡主Mysql,现在给大家一个正确的删除姿势。2、首先我们查看

1、背景

在生产环境有可能有删除某个不重要大表的需求,因为大表占用的大量磁盘空间,如果我们直接drop掉此表,通常需要20秒以上的时间,总会觉得会卡主Mysql,现在给大家一个正确的删除姿势。

2、首先我们查看此大表

shell>ls log_api_call_01_01* -l

-rw-r----- 1 mysql mysql   9362 Jun 22 15:35 log_api_call_01_01.frm

-rw-r----- 1 mysql mysql 293334036112 Jun 22 15:38 log_api_call_01_01.ibd

shell>ln log_api_call_01_01.ibd log_api_call_01_01ibd.bak

shell>ls log_api_call_01_01* -l

-rw-rw—- 1 MySQL mysql 9362 Apr 14 23:03 log_api_call_01_01.frm

-rw-r----- 1 mysql mysql 293334036112 Jun 22 15:38 log_api_call_01_01.ibd

-rw-r----- 1 mysql mysql 293334036112 Jun 22 15:38 log_api_call_01_01.ibd.bak

mysql>drop table log_api_call_01_01;

Query Ok, 0 rows affacted(0.92 sec)

通过这样的操作,可以减少mysql drop大表hang住的时间,然后在业务低峰期再去删除真实的那个*.b文*.bak件。


至于原理: 

就是利用OS HARD LINK的原理,

当多个文件名同时指向同一个Inode时,这个INODE的引用数N>1, 删除其中任何一个文件名都会很快.

因为其直接的物理文件块没有被删除.只是删除了一个指针而已;

当INODE的引用数N=1时, 删除文件需要去把这个文件相关的所有数据块清除,所以会比较耗时;


对于大表操作操作的其实几个Tips:

可以先用rename table替代drop table

mysql> rename table log_api_call_01_01 to log_api_call_01_01_bak;

删除物理文件

for i in `seq 100 -1 1 ` ;do sleep 2;sudo truncate -s ${i}G /data/mysql/manager/log_api_call_01_01.ibd.bak;done sudo rm -rf /data/mysql/manager/log_api_call_01_01.ibd.bak;

这个动作也很快只是相当于改一个文件名。

另外也可以考虑使用XFS文件系统,对于Drop表动作也比较快。


您可能感兴趣的文档:

--结束END--

本文标题: MySQL大表删除正确的姿势

本文链接: https://lsjlt.com/news/45686.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL大表删除正确的姿势
    1、背景在生产环境有可能有删除某个不重要大表的需求,因为大表占用的大量磁盘空间,如果我们直接drop掉此表,通常需要20秒以上的时间,总会觉得会卡主MySQL,现在给大家一个正确的删除姿势。2、首先我们查看...
    99+
    2024-04-02
  • 浅谈MySQL表空间回收的正确姿势
    目录前置说明问题重现删除数据原理数据的复用哪些操作会造成数据空洞如何收缩表空间小结不知道大家有没有遇到这样的一种情况,线上业务在MySQL表上做增删改查操作,随着时间的推移,表里面的...
    99+
    2024-04-02
  • MySQL大表清空和删除正确方法
    MySQL大表清空和删除正确方法 1 清空大表 1.1 truncate 删除表中的数据的方法有delete,truncate, 其中TRUNCATE TABLE用于删除表中的所有行,而不记录单个行删除操作...
    99+
    2024-04-02
  • python 折行的正确姿势
    在写 python 代码时,有时变量值是一个非常长的字符串,比如这样: line = 'this is a very very very very very very very very very very long string...
    99+
    2023-01-31
    姿势 正确 python
  • Python连接mysql数据库的正确姿势
    Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: GadFly mSQL MySQL PostgreSQL Microsoft SQL Server 2000...
    99+
    2022-06-04
    姿势 正确 数据库
  • 解锁redis锁的正确姿势
    解锁redis锁的正确姿势 redis是php的好朋友,在php写业务过程中,有时候会使用到锁的概念,同时只能有一个人可以操作某个行为。这个时候我们就要用到锁。锁的方式有好几种,php不能在内存中用锁,不...
    99+
    2022-06-04
    解锁 姿势 正确
  • springboot整合netty的正确姿势
    近期做一些物联网方面项目,使用到了tcp协议,之前公司做过socket短连接,网上找了一个简单的demo,很早便学习到nio方面知识,学习了《netty从入门到精通》这本书,同时也根据网上视频做了几个demo,但学习不太深入,刚好物联网项目...
    99+
    2023-10-08
    spring boot java 后端
  • MySQL使用AES_ENCRYPT()/AES_DECRYPT()加解密的正确姿势
    遇到一个需求是这样的: 需要在使用AES_ENCRYPT()函数将明文加密,存储在MySQL中,但是遇到了一些问题…… 说将加密后的密文,解密取出来是NULL。 看了一下,她发过来的表结构: 再看...
    99+
    2024-04-02
  • 调用java.lang.Runtime.exec的正确姿势分享
    目录调用java.lang.Runtime.exec的正确姿势两种方法小结一下Java Runtime.exec()注意事项1.Runtime.exec() 有四种调用方法2.得到程...
    99+
    2024-04-02
  • 浅谈java socket的正确关闭姿势
    java socket对应的是网络协议中的tcp,tcp的三次握手、四次挥手、11中状态什么的这里就不说了,不知道大家平常使用socket的时候如果不注意的情况下,会不会遇到各种异常...
    99+
    2024-04-02
  • Mybatis重置Criteria的正确姿势分享
    目录Mybatis重置Criteria发现问题原因如下我们想重置查询条件怎么办?得出一个结论Mybatis的Criteria用法总结Mybatis重置Criteria 开发中遇到My...
    99+
    2024-04-02
  • Python入门的正确姿势是什么
    Python入门的正确姿势是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Python入门的正确姿势!初级开发者学Python容易陷入茫然,面对市面上种类众...
    99+
    2023-06-02
  • SQLServer临时表的正确删除方式(sqlserver删除临时表)
    目录SQL Server临时表的正确删除方式1、错误的删除操作:2、正确的删除方式:补充:SQL临时表的使用示例删除临时表SQL Server临时表的正确删除方式 临时表与一般的表不...
    99+
    2023-02-16
    sql删除临时表 sql临时表使用
  • 浅谈Tomcat内存配置的正确姿势
    1.背景 虽然阅读了各大牛的博客或文章,但并没有找到特别全面的关于JVM内存分配方法的文章,很多都是复制黏贴 为了严谨,本文特别备注只介绍基于HotSpot VM虚拟机,并且基于JD...
    99+
    2024-04-02
  • MySQL8.0修改密码的正确姿势分享
    目录前言mysql5.7.9之后取消了password函数,authentication_string=password("123456")会报错正确更...
    99+
    2024-04-02
  • Python怎么用(Python使用的正确姿势)
    Python是一种高级编程语言,广泛用于各种应用程序的开发。以下是Python的正确使用姿势:1. 安装Python:首先需要下载和...
    99+
    2023-09-22
    python
  • 使用Java8中Optional机制的正确姿势
    前言Java8带来的函数式编程特性对于习惯命令式编程的程序员来说还是有一定的障碍的,我们只有深入了解这些机制的方方面面才能运用自如。Null的处理在JAVA编程中是出了try catch之外的另一个头疼的问题,需要大量的非空判断模板代码,程...
    99+
    2023-05-30
    java8 optional 使用
  • 开发函数计算的正确姿势——tensor
    前言 首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行...
    99+
    2023-01-31
    函数 姿势 正确
  • vue项目中使用websocket的正确姿势
    1. 在utils下新建websocket.js文件 // import { showInfoMsg, showErrorMsg } from '@/utils/popInfo' i...
    99+
    2024-04-02
  • springboot配置加密的正确姿势分享
    目录前言一、使用步骤1.引入依赖2. yml配置3. 使用总结主要介绍springboot项目中配置文件的加密 前言 为了保证服务器相关信息的保密,一般会采用加密的方式进行对配置文件...
    99+
    2022-11-16
    springboot配置加密 springboot配置详解
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作