记一次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空间的更多相关文章

  1. Mysql InnoDB彻底释放磁盘空间

    Innodb数据库对于已经删除的数据只是标记为删除,并不真正释放所占用的磁盘空间,这就导致InnoDB数据库文件不断增长. 如果需要彻底释放磁盘空间,则需要先导出数据,然后删除数据文件,最后导入数据. ...

  2. [记录]一则清理MySQL大表以释放磁盘空间的案例

    一则清理MySQL大表以释放磁盘空间的案例 一.基本情况: 1.dbtest库554G,先清理st_online_time_away_ds(37G)表的数据,保留半年的数据: 1)删除的数据:sele ...

  3. MySQL删除数据几种情况以及是否释放磁盘空间【转】

    MySQL删除数据几种情况以及是否释放磁盘空间: 1.drop table table_name 立刻释放磁盘空间 ,不管是 Innodb和MyISAM ; 2.truncate table tabl ...

  4. 【转】利用optimize、存储过程和系统表对mysql数据库表进行批量碎片清理释放表空间

    本文收集于本人的笔记本,由于找不到原文出处.在此省略,如哪位知道可以联系我加上. 核心是利用mysql系统表和“optimize table 表名”命令,对mysql数据表进行空间的释放.由于dele ...

  5. oracle 删除表、表空间、用户时,如何释放磁盘空间

    truncate table tablename DROP STORAGE; drop 执行drop table xx 语句drop后的表被放在回收站(user_recyclebin)里,而不是直接删 ...

  6. Oracle中关于清除数据和释放表空间

    一.表的重命名 flashback table test2 to before drop rename to test3;--[to test3]将表重命名 drop table test3 purg ...

  7. [转]oracle在删除表\表空间\用户时,如何释放磁盘空间

    一.drop表 执行drop table xx 语句 drop后的表被放在回收站(user_recyclebin)里,而不是直接删除掉.这样,回收站里的表信息就可以被恢复,或彻底清除. 通过查询回收站 ...

  8. Mac - 苹果电脑mac系统释放硬盘空间方法汇总

    硬盘空间是大家最头痛的一个问题,大家在硬盘空间变小的时候怎么腾空间的呢?下面为大家分享7个mac系统释放空间的高级方法,大家赶紧来收了! mac系统释放硬盘空间方法: 方法一:删除Emacs--可以节 ...

  9. mongodb拷贝数据库copyDatabase()。实现释放磁盘空间的方法。

    下面我们一起来看看关于mongodb拷贝数据库copyDatabase().实现释放磁盘空间的方法,希望文章对各位同学会有所帮助. db.copyDatabase("from",& ...

随机推荐

  1. JVM 体系结构与工作方式

    .katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > ...

  2. 开源项目SMSS开发指南

    SMSS是一个由我个人发起的开源项目,目的是建立一套轻量化,高可用,高安全和方便扩展的业务支撑框架.SMSS面向TCP/IP层开发,适合扩展上层业务接口.数据结构传输序列化通过Protobuf实现.传 ...

  3. 洛谷P2602 [ZJOI2010]数字计数 题解 数位DP

    题目链接:https://www.luogu.com.cn/problem/P2602 题目大意: 计算区间 \([L,R]\) 范围内 \(0 \sim 9\) 各出现了多少次? 解题思路: 使用 ...

  4. Date、Time类型拼接成字符串

    Date.Time类型拼接成字符串 语言用的是kotlin,和Java类似 var time = "" val sdf1 = SimpleDateFormat("yyyy ...

  5. 客户端访问windows server2016 服务器共享 速度慢

    客户端(windows10)敲完地址后,要过很久才会谈出窗口.  所有的客户端都出现过此现象. 解决:关闭server的 Smb1.0

  6. RabbitMQ入门之Hello World

    RabbitMQ简介   在介绍RabbitMQ之前,我们需要了解一些最基础的概念,相信使用过或者听说过RabbitMQ的人都不会陌生,但笔者还是不厌其烦地在这里讲述,因为笔者的理念是self con ...

  7. HTTPS中的TLS

    1. SSL 与 TLS SSL:(Secure Socket Layer) 安全套接层,于 1994 年由网景公司设计,并于 1995 年发布了 3.0 版本TLS:(Transport Layer ...

  8. 【Java并发基础】并发编程bug源头:可见性、原子性和有序性

    前言 CPU .内存.I/O设备之间的速度差距十分大,为了提高CPU的利用率并且平衡它们的速度差异.计算机体系结构.操作系统和编译程序都做出了改进: CPU增加了缓存,用于平衡和内存之间的速度差异. ...

  9. 基于js的APP多语言处理

    本文出自APICloud官方论坛, 感谢论坛版主哼哼哈兮 的分享.   本期分享一个js的多语言处理插件i18n.js,此插件是基于JQuery.i18n.properties修改而来的. 实现的原理 ...

  10. 有关lightning页面中页面加载时间计数器颜色分别表示的时间范围的问题

    之所以要转载这篇文章的原因是,有一次调查lightning中右上角有个页面加载时间控件颜色分别代表多少时间范围的问题,搜索查阅了很多资料和文件,最终在一篇有关Lighthouse前端性能优化测试工具的 ...