怎么查询mysql内存 查看mysql内存大小( 二 )


show table status;
然后你可以查看 Data_length 得到数据长度,但只是参考,并不精确 。MyISAM的数据文件就在datadir/dbname中的 tablename.myd, *.myi, *.frm, 但innodb 的都存于一个ibdata文件中 。
如何查看mysql内存占用原因查看 /proc/meminfo
Tips:
“大内存页”也称传统大页、大页内存等有助于 Linux 进行虚拟内存的管理,标准的内存页为 4KB,这里使用“大内存页”最大可以定义 1GB 的页面大?。谙低称舳诩淇梢允褂谩按竽诖嬉场蔽τ贸绦蛟ち粢徊糠帜诖妫獠糠帜诖姹徽加们矣涝恫换岜唤换怀瞿诖?nbsp;, 它会一直保留在那里,直到改变配置 。(详细介绍请看下面链接官方解释)
那么这么大页内存是分配给谁的呢?
查询一下:
shell /proc/sys/vm/hugetlb_shm_group
27
shell id 27
uid=27(mysql) gid=27(mysql) groups=27(mysql)
hugetlb_shm_group 文件里填的是指定大页内存使用的用户组 id , 这里查看到是 MySQL 组 id,那既然是给 MySQL 的为什么 free 等于 total , 并且 mysql 还只有 20 多 G 实际使用内存呢?
原来在 MySQL 中还有专门启用大内存页的参数,在 MySQL 大内存页称为 large page 。
查看 MySQL 配置文件
发现配置文件中确实有 large-page 配置,但出于禁用状态 。
后与业务确认,很早之前确实启用过 mysql 的 large page,不过后面禁用了 。排查到这基本就有了结论 。
结论
这套环境之前开启了 20000 的大内存页,每页大小为 2MB , 占用了 40G 内存空间 , 给 MySQL 使用,并且 MySQL 开启了 large page,但后来不使用的时候,只关闭了 MySQL 端的 large page 参数,但没有实际更改主机的关于大内存页的配置,所以导致,实际上主机上的还存在 20000 的大内存页,并且没在使用,这一部分长期空闲 , 并且其他程序不能使用 。
所以 MySQL 在使用 20G 内存左右,整个主机内存就饱和了,然后在部分条件下,就触发了 OOM,导致 mysqld 被 kill,但主机上又有 mysqld_safe 守护程序,所以又再次给拉起来,就看到了文章初的偶尔连接不上的现象 。
怎么查看mysql内存大小putty命令将线上db,导出后,导入到office db
一.
两种方案:
1,将数据直接从online--office,通过mysqldump
通过本地putty等和ecs建隧道,然后传数据到本地.(本地win可以按照gzip,压缩后传到office server)
2,先在ecs上mysqldump压缩,然后下载下来
下载方案:
1,rsync daemon
2,rsync ssh
3,scp
4,sz ----这种速度较快,前三者都差不多,记得md5sum
怎么查询mysql内存的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于查看mysql内存大小、怎么查询mysql内存的信息别忘了在本站进行查找喔 。

推荐阅读