溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL自動(dòng)停機(jī)的問(wèn)題的實(shí)例解析

發(fā)布時(shí)間:2020-07-20 14:42:11 來(lái)源:億速云 閱讀:410 作者:小豬 欄目:MySQL數(shù)據(jù)庫(kù)

這篇文章主要講解了MySQL自動(dòng)停機(jī)的問(wèn)題的實(shí)例解析,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

最近幫別人做的一個(gè)項(xiàng)目機(jī)器上面跑MySQL老是隔一段時(shí)間就自動(dòng)停了。剛開(kāi)始以為是以外停止,也沒(méi)注意,就手動(dòng)再啟動(dòng)??墒沁^(guò)了沒(méi)兩天又停止了。

后來(lái)仔細(xì)查了查mysqld的日志:

2020-05-27T10:15:12.569342Z 0 [System] [MY-010116] [Server] /usr/libexec/mysqld (mysqld 8.0.17) starting as process 19493
2020-05-27T10:15:14.448256Z 0 [System] [MY-010229] [Server] Starting crash recovery...
2020-05-27T10:15:14.475411Z 0 [System] [MY-010232] [Server] Crash recovery finished.
2020-05-27T10:15:14.691345Z 0 [Warning] [MY-010068] [Server] CA certificate ca.pem is self signed.
2020-05-27T10:15:15.677386Z 0 [System] [MY-010931] [Server] /usr/libexec/mysqld: ready for connections. Version: '8.0.17'  socket: '/var/lib/mysql/mysql.sock'  port: 3306  Source distribution.
2020-05-27T10:15:15.951210Z 0 [System] [MY-011323] [Server] X Plugin ready for connections. Socket: '/var/lib/mysql/mysqlx.sock' bind-address: '::' port: 33060
2020-05-27T11:26:19.955004Z 0 [System] [MY-010116] [Server] /usr/libexec/mysqld (mysqld 8.0.17) starting as process 19757
2020-05-27T11:26:20.181302Z 0 [ERROR] [MY-012681] [InnoDB] mmap(137363456 bytes) failed; errno 12
2020-05-27T11:26:20.181360Z 1 [ERROR] [MY-012956] [InnoDB] Cannot allocate memory for the buffer pool
2020-05-27T11:26:20.181379Z 1 [ERROR] [MY-012930] [InnoDB] Plugin initialization aborted with error Generic error.
2020-05-27T11:26:20.181401Z 1 [ERROR] [MY-010334] [Server] Failed to initialize DD Storage Engine
2020-05-27T11:26:20.181543Z 0 [ERROR] [MY-010020] [Server] Data Dictionary initialization failed.
2020-05-27T11:26:20.183642Z 0 [ERROR] [MY-010119] [Server] Aborting
2020-05-27T11:26:20.184163Z 0 [System] [MY-010910] [Server] /usr/libexec/mysqld: Shutdown complete (mysqld 8.0.17)  Source distribution.

上面顯示是Cannot allocate memory for the buffer pool,無(wú)法分配內(nèi)存給緩存池。馬上想到是內(nèi)存不足,這臺(tái)機(jī)器是1GB的內(nèi)存,還跑著 Nginx 和 PHP-FPM 。

使用 top 看了看 mysqld 占用的內(nèi)存達(dá)到了48% 。內(nèi)存占用還是蠻高的。

當(dāng)然了升級(jí)機(jī)器配置是比較好的辦法,但是畢竟經(jīng)費(fèi)有限。所以我們先給它加個(gè)swap交換空間:

dd if=/dev/zero of=/swapfile bs=1M count=2048
mkswap /swapfile
swapon /swapfile
systemctl restart mysqld

上面我們加了2GB的交換空間給機(jī)器。然后重啟 mysqld。再使用top看了看,發(fā)現(xiàn)交換空間漸漸被使用了。

睡了一覺(jué)起來(lái)一看,mysqld服務(wù)沒(méi)有再自動(dòng)停止,內(nèi)存占用已經(jīng)下降到22%,看了看錯(cuò)誤日志,也是空的。

嗯,看來(lái)還不錯(cuò)嘛。再觀察個(gè)幾天看看,沒(méi)問(wèn)題的話應(yīng)該就好了

看完上述內(nèi)容,是不是對(duì)MySQL自動(dòng)停機(jī)的問(wèn)題的實(shí)例解析有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI