一次MySQL啟動(dòng)導(dǎo)致的事故實(shí)戰(zhàn)記錄
MySQL` 啟動(dòng)存在端口被監(jiān)聽(tīng), 但服務(wù)沒(méi)完全啟動(dòng)的情況.
背景
MySQL 啟動(dòng)時(shí)會(huì)進(jìn)行 第一次 初始化數(shù)據(jù)庫(kù), 等待 MySQL 完全啟動(dòng)后, 再進(jìn)行 第二次 初始化數(shù)據(jù)庫(kù).
第一次 初始化數(shù)據(jù)庫(kù)使用 --skip-networking (這個(gè)選項(xiàng)表示禁止 MySQL 的 TCP/IP 連接方式) 啟動(dòng) MySQL 進(jìn)行初始化,
初始化完成后會(huì)關(guān)閉 --skip-networking 選項(xiàng)重新啟動(dòng) MySQL.
第二次 初始化數(shù)據(jù)庫(kù)會(huì)設(shè)置 root 密碼.
判斷 MySQL 已完全啟動(dòng)的方式
嘗試主動(dòng)連接 MySQL, 連接成功則表明服務(wù)已完全啟動(dòng)
mysql -hlocalhost -P3306 -uroot
事故
由于上面的判斷方式使用的是 socket 進(jìn)行連接數(shù)據(jù)庫(kù), 但第一次只是禁止 MySQL 的 TCP/IP 連接方式,
所以沒(méi)等 第一次 初始化數(shù)據(jù)庫(kù)完成可能就已經(jīng)進(jìn)行了 第二次 初始化數(shù)據(jù)庫(kù),
而 第二次 初始化數(shù)據(jù)庫(kù)提前于 第一次 初始化數(shù)據(jù)庫(kù)設(shè)置 root 密碼, 導(dǎo)致 第一次 初始化連不上數(shù)據(jù)庫(kù)而失敗,
最后沒(méi)有開(kāi)啟 TCP/IP 連接方式, 應(yīng)用無(wú)法連接數(shù)據(jù)庫(kù).
第一次修改
使用 -h127.0.0.1 進(jìn)行連接數(shù)據(jù)庫(kù)
mysql -h127.0.01 -P3306 -uroot
但由于 root 用戶(hù)的 host 設(shè)置的是 localhost, 不允許 127.0.0.1 進(jìn)行連接, 第一次修改失敗.
第二次修改
wait-for-it.sh 127.0.0.1:3306 --timeout=300 mysql -hlocalhost -P3306 -uroot
wait-for-it.sh 用于檢測(cè) 127.0.0.1:3306 是否處于監(jiān)聽(tīng)狀態(tài), 如果是, 則表明 第一次 初始化數(shù)據(jù)庫(kù)完成了,
然后再使用 localhost 去嘗試連接數(shù)據(jù)庫(kù).
原文鏈接: k8scat.com/posts/wait-…
總結(jié)
到此這篇MySQL啟動(dòng)導(dǎo)致的事故的文章就介紹到這了,更多相關(guān)MySQL啟動(dòng)導(dǎo)致事故內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。