|
發(fā)現(xiàn)問題
昨天在幫同事編譯安裝Linux環(huán)境時(shí),遇到一個(gè)問題:
WEB服務(wù)器是apache,數(shù)據(jù)庫(kù)是MySQL。
于是寫了一個(gè)測(cè)試連接數(shù)據(jù)庫(kù)的php頁(yè)面:
復(fù)制代碼 代碼如下:$mysql = mysql_connect('localhost','root','');
打開 http://localhost/test.php 測(cè)試
提示:Can't connect to local MySQL server through socket...
檢查環(huán)境正常
以為是數(shù)據(jù)庫(kù)沒有啟動(dòng),于是查看一下進(jìn)程,MySQL在進(jìn)程里,重啟了一下MySQL.
使用mysql -u root -p 可以進(jìn)入MySQL操作界面
直接使用/usr/local/php5/bin/php /web/test.php執(zhí)行可以連上數(shù)據(jù)庫(kù)
apache也重啟了,一樣無效
疑點(diǎn):為何網(wǎng)頁(yè)執(zhí)行失敗,命令執(zhí)行卻成功
這下就郁悶了,使用php命令直接執(zhí)行就成功,通過網(wǎng)頁(yè)執(zhí)行就失敗。難道是apache導(dǎo)致?網(wǎng)上搜索了大堆資料也沒找到解決方案,重新編譯安裝apache問題依舊。
把localhost改成127.0.0.1成功
把localhost改成127.0.0.1后竟然連接成功了,開始陷入思考困局:localhost失敗127.0.0.1卻成功?
ping localhost 地址是127.0.0.1沒錯(cuò)
打開hosts加入
復(fù)制代碼 代碼如下:
127.0.0.1 qttc
使用qttc當(dāng)主機(jī)連接也正常,唯獨(dú)就不認(rèn)localhost。
localhost連接方式不同導(dǎo)致
為了了解php連接數(shù)據(jù)庫(kù)時(shí),主機(jī)填寫localhost與其它的區(qū)別閱讀了大量資料,最后得知:
當(dāng)主機(jī)填寫為localhost時(shí)mysql會(huì)采用 unix domain socket連接
當(dāng)主機(jī)填寫為127.0.0.1時(shí)mysql會(huì)采用tcp方式連接
這是linux套接字網(wǎng)絡(luò)的特性,win平臺(tái)不會(huì)有這個(gè)問題
解決方法
在my.cnf的[mysql]區(qū)段里添加
復(fù)制代碼 代碼如下:protocol=tcp
保存重啟MySQL,問題解決!
php技術(shù):PHP中使用localhost連接Mysql不成功的解決方法,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。