MySQL只會(huì)當(dāng)SQL涉及相關(guān)表時(shí),才把表的數(shù)據(jù)調(diào)入內(nèi)存,并會(huì)根據(jù)LRU算法,在CACHE中保留上個(gè)查詢的結(jié)果緩沖。
“只有客戶發(fā)展了,才有我們的生存與發(fā)展!”這是創(chuàng)新互聯(lián)的服務(wù)宗旨!把網(wǎng)站當(dāng)作互聯(lián)網(wǎng)產(chǎn)品,產(chǎn)品思維更注重全局思維、需求分析和迭代思維,在網(wǎng)站建設(shè)中就是為了建設(shè)一個(gè)不僅審美在線,而且實(shí)用性極高的網(wǎng)站。創(chuàng)新互聯(lián)對(duì)做網(wǎng)站、成都做網(wǎng)站、網(wǎng)站制作、網(wǎng)站開(kāi)發(fā)、網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站優(yōu)化、網(wǎng)絡(luò)推廣、探索永無(wú)止境。
平時(shí),表不是會(huì)被加載到內(nèi)存中去的。
show table status;
然后你可以查看 Data_length 得到數(shù)據(jù)長(zhǎng)度,但只是參考,并不精確。 MyISAM的數(shù)據(jù)文件就在datadir/dbname中的 tablename.myd, *.myi, *.frm, 但innodb 的都存于一個(gè)ibdata文件中。
查看 /proc/meminfo
Tips:
“大內(nèi)存頁(yè)”也稱傳統(tǒng)大頁(yè)、大頁(yè)內(nèi)存等有助于 Linux 進(jìn)行虛擬內(nèi)存的管理,標(biāo)準(zhǔn)的內(nèi)存頁(yè)為 4KB,這里使用“大內(nèi)存頁(yè)”最大可以定義 1GB 的頁(yè)面大小,在系統(tǒng)啟動(dòng)期間可以使用“大內(nèi)存頁(yè)”為應(yīng)用程序預(yù)留一部分內(nèi)存,這部分內(nèi)存被占用且永遠(yuǎn)不會(huì)被交換出內(nèi)存,它會(huì)一直保留在那里,直到改變配置。(詳細(xì)介紹請(qǐng)看下面鏈接官方解釋?zhuān)?/p>
那么這么大頁(yè)內(nèi)存是分配給誰(shuí)的呢?
查詢一下:
shell /proc/sys/vm/hugetlb_shm_group
27
shell id 27
uid=27(mysql) gid=27(mysql) groups=27(mysql)
hugetlb_shm_group 文件里填的是指定大頁(yè)內(nèi)存使用的用戶組 id,這里查看到是 MySQL 組 id,那既然是給 MySQL 的為什么 free 等于 total,并且 mysql 還只有 20 多 G 實(shí)際使用內(nèi)存呢?
原來(lái)在 MySQL 中還有專(zhuān)門(mén)啟用大內(nèi)存頁(yè)的參數(shù),在 MySQL 大內(nèi)存頁(yè)稱為 large page。
查看 MySQL 配置文件
發(fā)現(xiàn)配置文件中確實(shí)有 large-page 配置,但出于禁用狀態(tài)。
后與業(yè)務(wù)確認(rèn),很早之前確實(shí)啟用過(guò) mysql 的 large page,不過(guò)后面禁用了。排查到這基本就有了結(jié)論。
結(jié)論
這套環(huán)境之前開(kāi)啟了 20000 的大內(nèi)存頁(yè),每頁(yè)大小為 2MB,占用了 40G 內(nèi)存空間,給 MySQL 使用,并且 MySQL 開(kāi)啟了 large page,但后來(lái)不使用的時(shí)候,只關(guān)閉了 MySQL 端的 large page 參數(shù),但沒(méi)有實(shí)際更改主機(jī)的關(guān)于大內(nèi)存頁(yè)的配置,所以導(dǎo)致,實(shí)際上主機(jī)上的還存在 20000 的大內(nèi)存頁(yè),并且沒(méi)在使用,這一部分長(zhǎng)期空閑,并且其他程序不能使用。
所以 MySQL 在使用 20G 內(nèi)存左右,整個(gè)主機(jī)內(nèi)存就飽和了,然后在部分條件下,就觸發(fā)了 OOM,導(dǎo)致 mysqld 被 kill,但主機(jī)上又有 mysqld_safe 守護(hù)程序,所以又再次給拉起來(lái),就看到了文章初的偶爾連接不上的現(xiàn)象。
如何查看MySQL占用的內(nèi)存都用在哪了1、查看物理CPU的個(gè)數(shù)[root@MysqlCluster01 ~]# cat /proc/cpuinfo |grep “physical id”|sort |uniq|wc -l12、查看邏輯CPU的個(gè)數(shù)[root@MysqlCluster01 ~]# cat /proc/cpuinfo |grep “processor”|wc -l43、查看CPU是幾核(即,核心數(shù))[root@MysqlCluster01 ~]# cat /proc/cpuinfo |grep “cores”|uniqcpu cores : 44、查看CPU的主頻[root@MysqlCluster01 ~]# cat /proc/cpuinfo |grep MHz|uniqcpu MHz : 2499.9825、當(dāng)前操作系統(tǒng)內(nèi)核信息[root@MysqlCluster01 ~]# uname -aLinux MysqlCluster01 2.6.32-431.20.3.el6.x86_64 #1 SMP Thu Jun 19 21:14:45 UTC 2014 x86_64 x86_64 x86_64 GNU/Linux6、當(dāng)前操作系統(tǒng)發(fā)行版信息[root@MysqlCluster01 ~]# cat /etc/issueCentOS release 6.4 (Final)Kernel
on an m7、內(nèi)存使用情況[root@MysqlCluster01 ~]# free -mtotal used free shared buffers cachedMem: 7863 2738 5125 0 141 835-/+ buffers/cache: 1761 6102Swap: 3967 0 3967如何查看MySQL占用的內(nèi)存都用在哪了