释放innodb空间
记一次MySQL运维
[root@b2btest ~]# free -h
total used free shared buffers cached
Mem: 125G 124G 780M 13M 28K 238M
-/+ buffers/cache: 124G 1.0G
Swap: 30G .5G 22G
分析现象;
首先,可以看到,free部分已经严重不足,swap被大量启用。
而另一方面,cached部分的数据量非常低,而几乎所有的内存资源都被-/+ buffers/cache部分used,
初步分析:
buffer pool的设置过高,所有的数据都默认存储进了buffer pool中。在我的另一篇文章中,介绍了上面各个参数的含义,第一行的buffer指的是未被使用的量。
这导致了两个问题;
一个是内存资源被大量占用,free部分严重不足。
另一个是缓存区没有得到使用,因为所有数据都优先导入了buffer pool中。
因为缓存区没有被使用,所以即使内存的free部分已经不够用了,系统缓存也无法自动释放空间。
当这个矛盾产生后,系统就开始启用swap分区。
解决思路:
将数据,从buffer pool与swap里,全部挤压出来到cached中。再将 cached中的数据释放到磁盘内。使得内存中的空间得到释放。
先找到占用的具体进程
top - :: up days, :, users, load average: 2.67, 2.04, 1.97
Tasks: total, running, sleeping, stopped, zombie
%Cpu(s): 10.2 us, 0.6 sy, 0.0 ni, 89.2 id, 0.0 wa, 0.0 hi, 0.1 si, 0.0 st
KiB Mem: +total, +used, free, buffers
KiB Swap: total, used, free. cached Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
mysql .130t .117t S 129.1 95.3 : mysqld
这是台mysql专用服务器,系统资源全部被MySQL占用,要释放内存,就业从MySQL内部解决;
mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine | Support | Comment | Transactions | XA | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES
默认存储引擎为innodb,
mysql> show engine innodb status;
截取以下段落
----------------------
BUFFER POOL AND MEMORY
----------------------
Total large memory allocated
Dictionary memory allocated
Buffer pool size
Free buffers
Database pages
Old database pages 2657374
找到原因。开始处理
mysql> show variables like "%innodb_buffer_pool%"; 截取以下参数
+-------------------------------------+----------------+
| Variable_name | Value |
+-------------------------------------+----------------+
| innodb_buffer_pool_chunk_size | |
| innodb_buffer_pool_instances | |
| innodb_buffer_pool_size | |
+-------------------------------------+----------------+
rows in set (0.00 sec) mysql> select -**;
计划释放50倍的数据块
+-----------------------------+
| -** |
+-----------------------------+
| |
+-----------------------------+
row in set (0.00 sec) mysql> SET GLOBAL innodb_buffer_pool_size=;
Query OK, rows affected (0.00 sec)
将112G的内存降低至60G
之后查看下系统内存。free -h。确认下修改是否生效
[root@b2btest ~]# free -h
total used free shared buffers cached
Mem: 125G 124G 839M 15M 40K 47G
-/+ buffers/cache: 77G 48G
Swap: 30G .4G 22G
从这里已经可以看到,可用缓存空间已经增加了50G左右,接下来释放SWAP文件
[root@b2btest ~]# swapoff -a
7.5G的swap文件,释放需要5个小时!!,从这里也可以明显体会到swap文件系统运行的缓慢。
[root@b2btest ~]# free -h
total used free shared buffers cached
Mem: 125G 124G 742M 459M 60K 41G
-/+ buffers/cache: 83G 41G
Swap: 0B 0B 0B
现在所有的数据,都已经被转移到cached中,接下来,释放缓存。
[root@b2btest ~]# sync
[root@b2btest ~]# echo > /proc/sys/vm/drop_caches
[root@b2btest ~]# free -h
total used free shared buffers cached
Mem: 125G 83G 42G 459M 0B 42M
-/+ buffers/cache: 83G 42G
Swap: 0B 0B 0B
从缓存区释放40G数据,用时10秒左右。
[root@b2btest ~]# swapon -a
[root@b2btest ~]# swapon -s
文件名 类型 大小 已用 权限
/dev/sda3 partition -
重启swap分区。
在数据库保持正常运行的情况下,系统资源释放结束。
释放innodb空间的更多相关文章
- Mysql InnoDB彻底释放磁盘空间
Innodb数据库对于已经删除的数据只是标记为删除,并不真正释放所占用的磁盘空间,这就导致InnoDB数据库文件不断增长. 如果需要彻底释放磁盘空间,则需要先导出数据,然后删除数据文件,最后导入数据. ...
- [记录]一则清理MySQL大表以释放磁盘空间的案例
一则清理MySQL大表以释放磁盘空间的案例 一.基本情况: 1.dbtest库554G,先清理st_online_time_away_ds(37G)表的数据,保留半年的数据: 1)删除的数据:sele ...
- MySQL删除数据几种情况以及是否释放磁盘空间【转】
MySQL删除数据几种情况以及是否释放磁盘空间: 1.drop table table_name 立刻释放磁盘空间 ,不管是 Innodb和MyISAM ; 2.truncate table tabl ...
- 【转】利用optimize、存储过程和系统表对mysql数据库表进行批量碎片清理释放表空间
本文收集于本人的笔记本,由于找不到原文出处.在此省略,如哪位知道可以联系我加上. 核心是利用mysql系统表和“optimize table 表名”命令,对mysql数据表进行空间的释放.由于dele ...
- oracle 删除表、表空间、用户时,如何释放磁盘空间
truncate table tablename DROP STORAGE; drop 执行drop table xx 语句drop后的表被放在回收站(user_recyclebin)里,而不是直接删 ...
- Oracle中关于清除数据和释放表空间
一.表的重命名 flashback table test2 to before drop rename to test3;--[to test3]将表重命名 drop table test3 purg ...
- [转]oracle在删除表\表空间\用户时,如何释放磁盘空间
一.drop表 执行drop table xx 语句 drop后的表被放在回收站(user_recyclebin)里,而不是直接删除掉.这样,回收站里的表信息就可以被恢复,或彻底清除. 通过查询回收站 ...
- Mac - 苹果电脑mac系统释放硬盘空间方法汇总
硬盘空间是大家最头痛的一个问题,大家在硬盘空间变小的时候怎么腾空间的呢?下面为大家分享7个mac系统释放空间的高级方法,大家赶紧来收了! mac系统释放硬盘空间方法: 方法一:删除Emacs--可以节 ...
- mongodb拷贝数据库copyDatabase()。实现释放磁盘空间的方法。
下面我们一起来看看关于mongodb拷贝数据库copyDatabase().实现释放磁盘空间的方法,希望文章对各位同学会有所帮助. db.copyDatabase("from",& ...
随机推荐
- Docker Swarm Mode简介与核心概念
什么是Docker Swarm Docker Swarm是Docker官方的一种容器编排方案,用于管理跨主机的Docker容器,可以快速对指定服务进行水平扩展.部署.删除 一个Docker Swarm ...
- xshell连接不上ubuntu---could not connect to 'ip' (port 22): Connection failed.
可能是没有开启ssh server,接下来就是开启服务就好.命令如下: sudo apt-get install openssh-server 这样就OK啦
- C# async await 死锁问题总结
可能发生死锁的程序类型 1.WPF/WinForm程序 2.asp.net (不包括asp.net mvc)程序 死锁的产生原理 对异步方法返回的Task调用Wait()或访问Result属性时,可能 ...
- 「USACO08JAN」电话线Telephone Lines 解题报告
题面 大意:在加权无向图上求出一条从 \(1\) 号结点到 \(N\) 号结点的路径,使路径上第 \(K + 1\) 大的边权尽量小. 思路: 由于我们只能直接求最短路,不能记录过程中的具体的边--那 ...
- Educational Codeforces Round 53 (Rated for Div. 2) (前五题题解)
这场比赛没有打,后来补了一下,第五题数位dp好不容易才搞出来(我太菜啊). 比赛传送门:http://codeforces.com/contest/1073 A. Diverse Substring ...
- yum回滚至Kubernetes1.15.7版本
背景:升级Kubernetes版本从1.14.1-->1.17.0,官方说明不能跨版本升级,所以只好一个版本一个版本升级.最终升到1.17.0后发现API的格式有改动,之前的中间件版本很多不支持 ...
- 16.用pycharm导入自己写的模块时,import无法识别的解决办法
我们用pycharm打开自己写的代码,当多个文件之间有相互依赖的关系的时候,import无法识别自己写的文件,但是我们写的文件又确实在同一个文件夹中, 这种问题可以用下面的方法解决: 1)打开File ...
- linux常用命令,最基础
rmdir keda1/ 6 touch test.java 创建空文件 7 拷贝文件 cp 源文件 目标文件 cp test.java test1.java 8 删除文件rm -r 递归删除 -rf ...
- 【官方文档翻译】SpringBootActuator生产特性
翻译自 spring-boot 官方文档(版本:2.2.2.RELEASE) Spring Boot包含了许多附加功能,可以帮助您在将应用程序推送到生产环境时监视和管理它.您可以选择使用HTTP端点或 ...
- Ubuntu 19.10 安装 jupyter
安装pip3 ubuntu 19.10 已经没有python了,取代的是python3. 执行sudo apt install python3-pip安装pip3 安装jupyter 执行sudo p ...