這篇文章主要介紹“如何排除客戶端連接MySQL失敗故障”,在日常操作中,相信很多人在如何排除客戶端連接MySQL失敗故障問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”如何排除客戶端連接MySQL失敗故障”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括本溪網(wǎng)站建設(shè)、本溪網(wǎng)站制作、本溪網(wǎng)頁制作以及本溪網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,本溪網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到本溪省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
遇到這種情況首先到服務(wù)器上看看 mysqld 進(jìn)程是否活著,采用的命令:
mysqladmin ping 或 ps -ef | grep mysqld
如果 MySQL 服務(wù)器上的 mysqld 進(jìn)程運(yùn)行正常,我們?cè)倏纯纯蛻舳四懿荒芎?mysqld 進(jìn)行通信,使用下面的命令進(jìn)行網(wǎng)絡(luò)連通的測(cè)試:
telnet localhost 3306
如果本地能通,再到客戶端的機(jī)器上把 localhost 換成 MySQL 服務(wù)器的 ip 地址進(jìn)行測(cè)試。如果不能通,通常有兩種原因,一種原因是 OS 或網(wǎng)絡(luò)的問題,或者是防火墻;另一種原因是 mysqld 自身根本沒有偵聽客戶端的連接請(qǐng)求, mysqld 啟動(dòng)后對(duì)于客戶端的偵聽是分三種情況。
第一種情況
是使用參數(shù) --skip-networking 跳過偵聽客戶端的網(wǎng)絡(luò)連接,用下面的命令我們可以看到 MySQL 根本沒有偵聽 3306 端口。
mysqld --no-defaults --console --user mysql --skip-networking & netstat -plunt|grep 3306
第二種情況
使用參數(shù) --bind-address 后面增加對(duì)客戶端訪問 IP 地址的限制,例如只偵聽本地的連接:
mysqld --no-defaults --user mysql --bind-address=127.0.0.1 & netstat -plunt|grep 3306 tcp 0 0 127.0.0.1:3306 0.0.0.0:* LISTEN 22767/mysqld tcp6 0 0 :::33060 :::* LISTEN 22767/mysqld mysqld --no-defaults --user mysql --bind-address='192.168.17.40' & netstat -plunt|grep 3306 tcp 0 0 192.168.17.40:3306 0.0.0.0:* LISTEN 23053/mysqld tcp6 0 0 :::33060 :::* LISTEN 23053/mysqld
第三種情況
對(duì)客戶端訪問 IP 地址的不進(jìn)行限制。
mysqld --no-defaults --user mysql & netstat -plunt|grep 3306 tcp6 0 0 :::33060 :::* LISTEN 23582/mysqld tcp6 0 0 :::3306 :::* LISTEN 23582/mysqld
我們通過查看網(wǎng)絡(luò)端口偵聽的情況可以推測(cè) mysqld 進(jìn)程的參數(shù)設(shè)置。
最后一種情況是賬戶密碼的問題,應(yīng)付這種情況我們有個(gè)有力的工具就是查看 MySQL 的 error log, error log 記載信息的詳細(xì)程度上由參數(shù) --log-error-verbosity 進(jìn)行控制的,這個(gè)參數(shù)的作用如下:
默認(rèn)為 2,設(shè)置為 3 可以記錄更多的信息,這個(gè)參數(shù)可以聯(lián)機(jī)設(shè)置:
mysql> set global log_error_verbosity=3; Query OK, 0 rows affected (0.00 sec)
當(dāng)密碼錯(cuò)誤
mysql -uroot -perrorpasswordmysql: [Warning] Using a password on the command line interface can be insecure.ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
在 MySQL 的 error log 里有這樣的記錄:
2020-11-03T07:59:40.720835Z 7 [Note] [MY-010926] [Server] Access denied for user 'root'@'localhost' (using password: YES)
看到這樣的記錄我們至少知道了客戶端是連接上了 MySQL 的服務(wù)的。如果把參數(shù) --log-error-verbosity 設(shè)置成的默認(rèn)值 2 時(shí)是沒有這個(gè)提示的,也就說沒有 note 類型的信息。
賬戶錯(cuò)誤
ERROR 1130 (HY000): Host '192.168.17.149' is not allowed to connect to this MySQL server
注意賬戶錯(cuò)誤時(shí),提示是 “is not allowed to connect to this MySQL server”,而密碼錯(cuò)誤時(shí)是 “Access denied for user”。
MySQL 中的一個(gè)賬戶是由 user 和 host 兩個(gè)部分組成,在 MySQL 中有個(gè) mysql 數(shù)據(jù)庫,里面有個(gè) user 表,表中 Host 和 User 為兩個(gè)主鍵列(primary key),唯一表示一個(gè)用戶。像這種情況通常是 host 字段部分是 localhost,把它改成通配符 "%" 即可。
到此,關(guān)于“如何排除客戶端連接MySQL失敗故障”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
名稱欄目:如何排除客戶端連接MySQL失敗故障
本文地址:http://chinadenli.net/article20/gidgco.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、App設(shè)計(jì)、品牌網(wǎng)站制作、網(wǎng)站導(dǎo)航、靜態(tài)網(wǎng)站、云服務(wù)器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)