PHP中使用localhost連接Mysql不成功的解決方法
發(fā)現(xiàn)問題
昨天在幫同事編譯安裝Linux環(huán)境時,遇到一個問題:
WEB服務器是apache,數(shù)據(jù)庫是MySQL。
于是寫了一個測試連接數(shù)據(jù)庫的PHP頁面:
打開 http://localhost/test.php 測試
提示:Can't connect to local MySQL server through socket...
檢查環(huán)境正常
以為是數(shù)據(jù)庫沒有啟動,于是查看一下進程,MySQL在進程里,重啟了一下MySQL.
使用mysql -u root -p 可以進入MySQL操作界面
直接使用/usr/local/php5/bin/php /web/test.php執(zhí)行可以連上數(shù)據(jù)庫
apache也重啟了,一樣無效
疑點:為何網(wǎng)頁執(zhí)行失敗,命令執(zhí)行卻成功
這下就郁悶了,使用php命令直接執(zhí)行就成功,通過網(wǎng)頁執(zhí)行就失敗。難道是apache導致?網(wǎng)上搜索了大堆資料也沒找到解決方案,重新編譯安裝apache問題依舊。
把localhost改成127.0.0.1成功
把localhost改成127.0.0.1后竟然連接成功了,開始陷入思考困局:localhost失敗127.0.0.1卻成功?
ping localhost 地址是127.0.0.1沒錯
打開hosts加入
127.0.0.1 qttc
使用qttc當主機連接也正常,唯獨就不認localhost。
localhost連接方式不同導致
為了了解PHP連接數(shù)據(jù)庫時,主機填寫localhost與其它的區(qū)別閱讀了大量資料,最后得知:
當主機填寫為localhost時mysql會采用 unix domain socket連接
當主機填寫為127.0.0.1時mysql會采用tcp方式連接
這是linux套接字網(wǎng)絡的特性,win平臺不會有這個問題
解決方法
在my.cnf的[mysql]區(qū)段里添加
保存重啟MySQL,問題解決!
相關文章
php對數(shù)組內(nèi)元素進行隨機調(diào)換的方法
這篇文章主要介紹了php對數(shù)組內(nèi)元素進行隨機調(diào)換的方法,通過自定義函數(shù)實現(xiàn)對數(shù)組內(nèi)元素進行隨機調(diào)換的功能,涉及php操作數(shù)組的相關技巧,需要的朋友可以參考下2015-05-05
php使用PDO事務配合表格讀取大量數(shù)據(jù)插入操作實現(xiàn)方法
這篇文章主要介紹了php使用PDO事務配合表格讀取大量數(shù)據(jù)插入操作實現(xiàn)方法,涉及php使用excel_reader操作Excel文件及PDO操作數(shù)據(jù)庫的相關技巧,需要的朋友可以參考下2017-02-02
PHP中使用foreach()遍歷二維數(shù)組的簡單實例
下面小編就為大家?guī)硪黄狿HP中使用foreach()遍歷二維數(shù)組的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06

