MySql 磁盘满了的处理
处理步骤:
网上查了很多资源,说要进行磁盘碎片化整理。
原因是datafree占据的空间太多啦。具体可以通过这个sql查看。
SELECT CONCAT(TRUNCATE(SUM(data_length)/1024/1024,2),'MB') AS data_size,
CONCAT(TRUNCATE(SUM(max_data_length)/1024/1024,2),'MB') AS max_data_size,
CONCAT(TRUNCATE(SUM(data_free)/1024/1024,2),'MB') AS data_free,
CONCAT(TRUNCATE(SUM(index_length)/1024/1024,2),'MB') AS index_size
FROM information_schema.tables WHERE TABLE_NAME = 'datainfo';
网上推荐的做法如下所示,对表格进行碎片化整理。
ALTER TABLE datainfo ENGINE=InnoDB;
ANALYZE TABLE datainfo;optimize table datainfo;
mysql碎片化产生的原因
(1)表的存储会出现碎片化,每当删除了一行内容,该段空间就会变为被留空,而在一段时间内的大量删除操作,会使这种留空的空间变得比存储列表内容所使用的空间更大;
(2)当执行插入操作时,MySQL会尝试使用空白空间,但如果某个空白空间一直没有被大小合适的数据占用,仍然无法将其彻底占用,就形成了碎片;
(3)当MySQL对数据进行扫描时,它扫描的对象实际是列表的容量需求上限,也就是数据被写入的区域中处于峰值位置的部分;
清除碎片的优点:
降低访问表时的IO,提高mysql性能,释放表空间降低磁盘空间使用率
注意
1.MySQL官方建议不要经常(每小时或每天)进行碎片整理,一般根据实际情况,只需要每周或者每月整理一次即可(我们现在是每月凌晨4点清理mysql所有实例下的表碎片)。
2.在OPTIMIZE TABLE运行过程中,MySQL会锁定表。因此,这个操作一定要在网站访问量较少的时间段进行。
3.清理student的105万条数据, OPTIMIZE TABLE 库.student;本地测试需要37秒。
大家可以用这条语句看看自己的系统的datafree大不大 :
- show table status from DbName \G (\G 是以行的形式进行展示结果)
- show table status like 'tableName' \G (\G 是以行的形式进行展示结果)
各字段解释:
Name: 表名称 Engine:表的存储引擎 Version:版本 Row_format:行格式。对于MyISAM引擎,这可能是Dynamic,Fixed或Compressed。动态行的行长度可变,例如Varchar或Blob类型字段。固定行是指行长度不变,例如Char和Integer类型字段 Rows:表中的行数。对于MyISAM和其他存储引擎,这个值是精确的,对于innoDB存储引擎,这个值通常是估算的 Avg_row_length:平均每行包括的字节数 Data_length:整个表的数据量(以字节为单位) Max_data_length:表可以容纳的最大数据量,该值和存储引擎相关 Index_length:索引占用磁盘的空间大小(以字节为单位) Data_free:对于MyISAM引擎,表示已经分配,但目前没有使用的空间。这部分空间包含之前被删除的行,以及后续可以被insert利用到的空间 Auto_increment:下一个Auto_increment的值 Create_time:表的创建时间 Update_time:表的最近更新时间 Check_time:使用 check table 或myisamchk工具最后一次检查表的时间 Collation:表的默认字符集和字符排序规则 Checksum:如果启用,保存的是整个表的实时校验和 Create_options:创建表时指定的其他选项 Comment:包含了其他额外信息,对于MyISAM引擎,保存的是表在创建时带的注释。如果表使用的是innodb引擎 ,保存的是InnoDB表空间的剩余空间。如果是一个视图,注释里面包含了VIEW字样。
MySql 磁盘满了的处理相关推荐
- 如果MySQL磁盘满了,会发生什么?
来源:https://testerhome.com/topics/23049 问题 使用命令发现磁盘使用率为100%了,还剩几十兆. 一系列神操作 备份数据库,删除实例.删除数据库表.重启mysql服 ...
- 数据库:如果MySQl磁盘满了,如何解决!
使用命令发现磁盘使用率为100%了,还剩几十兆. 一系列神操作 备份数据库,删除实例.删除数据库表.重启mysql服务,结果磁盘空间均没有释放. 怎么办 网上查了很多资源,说要进行磁盘碎片化整理.原因 ...
- 如果mysql磁盘满了,会发生什么?还真被我遇到了!
点击上方蓝色字体,选择"设为星标" 回复"666"获取面试宝典 使用命令发现磁盘使用率为100%了,还剩几十兆. 一系列神操作 备份数据库,删除实例.删除数据库 ...
- mysql磁盘占用太大无法删除_mysql的binlog太大太多占用大量磁盘的解决
现象:网站访问越来越慢,最后无法访问了,经过检查发现磁盘满了.仔细查询下来确认是由于mysql的binlog太多太大占用了空间. 分析过程及解决方案:通常出现这种问题都应该登录服务器检查磁盘.内存和进 ...
- 网页服务器磁盘满了怎么办,远程服务器磁盘满了怎么办
远程服务器磁盘满了怎么办 内容精选 换一换 在Linux操作系统云服务器中创建文件时提示空间不足:No space left on device磁盘分区block空间使用率达到100%.磁盘分区ino ...
- Google回应全球宕机:磁盘满了;摩拜App昨晚正式停止服务;Docker Desktop 3.0.0发布|极客头条...
整理 | 郑丽媛 头图 | CSDN 下载自东方 IC 快来收听极客头条音频版吧,智能播报由出门问问「魔音工坊」提供技术支持. 「极客头条」-- 技术人员的新闻圈! CSDN 的读者朋友们早上好哇,「 ...
- centos磁盘满了,查找大文件并清理
centos磁盘满了,查找大文件并清理 2013年07月29日 ⁄ 综合 ⁄ 共 1172字 ⁄ 字号 小 中 大 ⁄ 评论关闭 今天发现vps敲入crontab -e 居然提示 "Disk ...
- HDFS某个节点的磁盘满了
前言 昨天还是周末,公司群里就有人@,说集群有问题了,敲完Hive一直卡在那里进不去,于是我很快登上WebUi,看到了这么一幕: 这台节点的磁盘满了,其他的数据分布都比较平均 为什么会这样 这里就不得 ...
- C盘容量不足,磁盘满了怎么办
C盘容量不足,磁盘满了怎么办,下面介绍一种在windows上的骚操作: 1)将c盘中用户的目录下文件拷贝到d盘相应目录 2)cmd命令行执行如下指令 mklink /D "C:\USERS\ ...
- 磁盘满了,却找不到大文件
某天,突然接到老大电话,说公司网站打不开了,跑去一看,老毛病,磁盘满了.之前磁盘满了,都是由于项目的日志引起的,服务器上有php和java项目,去删除日志就可以了. 我负责php项目,登录php项目一 ...
最新文章
- Xcode使用正则表达式替换
- 设置tomcat远程debug
- 自梦php,PHP菜狗自学之路 云之梦php php之窗 php脚本之
- poj 2385Apple Catching(简单dp)
- linux服务器安装caffe(无root权限)
- Python Itertools
- html简单页面实验报告原理,html网页设计实验报告
- python实现密码破解
- 一加6android9玩飞车掉,解锁新速度:一加6T深度评测
- 计算机系统的基础必备软件,电脑必装软件推荐:基础篇——够用就行
- js 排序 字符串内含数字字母特殊符号排序
- C#读取系统注册表信息
- tibco常用命令记录
- Spring Cloud Eureka 全解 (1) - 总览篇
- 重启linux没有网络配置文件,Linux 网络配置 修改DNS配置文件/etc/resolv.conf后,重启网络,DNS配置丢失...
- 【opencv图像处理】--2. 颜色空间,绘制图形,绘制(中文)文本
- 如何对文本框进行功能测试
- Springboot美食分享系统716y7计算机毕业设计-课程设计-期末作业-毕设程序代做
- JAVA输出希腊union,希腊十大旅游胜地(上)
- WordPress标签云小工具详解