1.  现象

巡检时发现服务器磁盘空间不足,通过查看大文件进行筛选是发现有几个#sql开头的文件,且存在超过100G及10G以上的文件。

2. 原因

如果MySQL在一个 ALTER TABLE操作(ALGORITHM=INPLACE)的中间退出,那么可能会留下一个占用系统空间的临时表。例如,在对一张表(大表)添加索引时中途中断、磁盘不足导致异常或正在添加索引时实例被kill等等情况所致。

注意: 此类表空间文件不能直接rm -f的方式物理删除,因为该信息记录在ibdata的共享表空间里,直接删除后,后续实例重启时会出现错误。

3. 处理方法

3.1   同时存在.frm 和.ibd名称相同的文件

如果 #sql-*.ibd 和 #sql-*.frm两个文件都存在数据目录里的话,可以直接drop table。但注意删除时候表名的变化。

/* 直接删除,表名前加#mysql50  */root@testdb 01:42:57> DROP TABLE `#mysql50##sql-ib87-856498050`;

注:#mysql50#前缀是MySQL 5.1中引入的文件名安全编码。另外,表名因不符合命名规范,想要执行该脚本需要将表名用反引号括起来。

3.2  创建新表方式删除

因为本例中没有存在.frm 和.ibd名称相同的文件的情况,因此采用创建一张与ibd表空间对应的结构(字段名及索引)一致的表,然后将frm文件拷贝为和ibd一致的文件,再进行删除。

下面处理截图中#sql-ib1516-2335726735.ibd文件,步骤如下:

a) 创建一张与#sql-ib1516-2335726735相同的表

root@testdb 08:47:35>create table company20191216 like  company;Query OK, 0 rows affected (0.05 sec)root@testdb 08:48:59>exitBye

b) 拷贝为#sql-ib1516-2335726735.frm的定义文件

[root@db4 testdb]# cp -p  company20191216.frm  \#sql-ib1516-2335726735.frm

c)  删除表

因为上一步拷贝时使用-p的方式,即权限和原文件权限一致,属主及group均为mysql,因此可以直接在数据库里读取删除,如果权限不对,必须先修改文件权限。

root@testdb 08:49:54>drop table `#mysql50##sql-ib1516-2335726735`;Query OK, 0 rows affected (6.65 sec)

此时,135G的文件就已经删掉了(其实另一个文件#sql-821_2.frm文件也一并删了)

注:删除这种100G的表不建议直接删除,而是通过创建硬链接的方式处理。

3.3  修改frm文件名与ibd文件名一致

上一步中删除ibd文件时,其中一个frm也自动删除了。为此,尝试通过修改frm文件名和ibd文件名一致的方式处理。但要注意,由于不确定是否结构一致,修改后可能异常,但如果没有暴力处理,通常均可以成功。如下:

a)  修改frm文件名与ibd文件名一致

[root@db4 testdb]# mv \#sql-a846_2.frm  \#sql-ib1570-121877015.frm

b) 删除表

root@testdb 01:41:06>DROP TABLE `#mysql50##sql-ib1570-121877015`;Query OK, 0 rows affected (1.70 sec)

done!

其实还有其他的方式处理,大家可以自行测试。

c 没有mysql名称空间_MySQL如何删除#sql开头的临时表相关推荐

  1. mysql 释放空间_Mysql InnoDB删除数据后释放磁盘空间的步骤详解

    Mysql InnoDB删除数据后释放磁盘空间的方法 Innodb数据库对于已经删除的数据只是标记为删除,并不真正释放所占用的磁盘空间,这就导致InnoDB数据库文件不断增长. 如果在创建数据库的时候 ...

  2. mysql 回收空间_MySQL表的碎片整理和空间回收小结

    MySQL表碎片化(Table Fragmentation)的原因 关于MySQL中表碎片化(Table Fragmentation)产生的原因,简单总结一下,MySQL Engine不同,碎片化的原 ...

  3. mysql 表空间_mysql 表空间

    什么是表空间 默认情况下,InnoDB只包含一个称为系统表空间的表空间,其标识符为0.可以使用innodb_file_per_table配置参数间接创建更多表空间.表空间由一系列文件组成.文件的大小不 ...

  4. mysql平滑关闭_MySQL平滑删除数据的小技巧

    这是学习笔记的第 1852篇文章 今天接到一位开发同学的数据操作需求,需求看似很简单,需要执行下面的SQL语句:delete from test_track_log where log_time &l ...

  5. mysql 交换空间_MySQL优化纪录

    优化纪录 20200304第一次 新的ECS型号如下 2 vCPU 4 GiB (I/O优化) ecs.n4.large 3Mbps 弄这个ECS纯属是个人的爱好,折腾一下代码,网站的访问量也不大,所 ...

  6. mysql批量删除多条记录的sql语句_mysql批量删除sql语句

    30种mysql优化sql语句查询的方法_计算机软件及应用_IT/计算机_专业资... 简要介绍基础语句: 1.说明:创建数据库 CREATE DATABASE database-name 2.说明: ...

  7. mysql count 排序_MySQL什么时候会使用内部临时表?

    1.union执行过程 首先我们创建一个表t1 create table t1(id int primary key, a int, b int, index(a));delimiter ;;crea ...

  8. mysql语句表_mysql表级sql语句

    create table table_name ( id int unsigned primary key AUTO_INCREMENT, username varchar(32) not null, ...

  9. mybatis与mysql调优_MySQL + mybatis的SQL优化方案

    sql优化方案: 1.添加索引,在条件参数,关联参数上建立参数, 2.字段优化,需要什么字段查什么字段 3.模糊查询尽量使用: select * from tableName a where a.na ...

最新文章

  1. linux platform匹配机制,Linux驱动中的platform总线详解
  2. 演示如何使用application.yml文件
  3. 汉恩互联「绘动画室」,触摸背景墙
  4. httpclient 小例子编写
  5. mysql 重置密码模式_mysql--重置密码
  6. RavenDB:基于Windows/.NET平台的NoSQL数据库
  7. jq ajax异步上传文件,jQuery插件ajaxFileUpload异步上传文件
  8. 登录界面拦截java_java拦截通过url访问页面,必须通过登录页面访问目标页面
  9. php elements,wd elements se和wd elements的区别是什么
  10. (实用篇)浅谈PHP拦截器之__set()与__get()的理解与使用方法
  11. cuda Synchronization
  12. MySQL怎么卸载干净重装?
  13. 【渝粤教育】国家开放大学2018年春季 0557-22T广告设计 参考试题
  14. Hadoop中Yarnrunner里面submit Job以及AM生成 至Job处理过程源码解析
  15. ajax点击事件click触发两次,jQuery点击click触发两次事件解决办法
  16. 浅析机器学习算法的应用场景!
  17. Word中插入参考文献 自动管理
  18. 【源码】食肉植物算法Carnivorous Plant Algorithm (CPA)
  19. iOS- 利用UIImageView自己整了个不会说话的汤姆猫
  20. Screen Wonders for Mac (3D动态视频壁纸) v1.9.1

热门文章

  1. Python 一行代码搞定炫酷可视化,你需要了解一下 Cufflinks
  2. python中yield函数的作用?
  3. python opencv cv2.VideoCapture(),read(),waitKey()的使用 ret,frame参数
  4. k中心点聚类算法伪代码_聚类算法之——K-Means、Canopy、Mini Batch K-Means
  5. python怎么显示分数_在Python中使用分数
  6. weblogic 故障转移
  7. git commit 提交的时候报错husky > pre-commit hook failed 或者‘lint-staged‘ 不是内部或外部命令,也不是可运行的程序(解决办法)
  8. 什么是线程池,连接池,线程池和连接池之间的区别
  9. SpringCloud--Eureka服务注册与发现 Eureka 集群搭建 详细案例!!!
  10. springboot项目集成docker