WEB服務器是apache,數據庫是MySQL。于是寫了一個測試連接數據庫的PHP頁面:
復制代碼 代碼如下:$mysql = mysql_connect('localhost','root','');打開 http://loca " /> 欧美a级成人淫片免费看,有码一区,欧美亚洲一

中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

PHP中使用localhost連接Mysql不成功的解決方法

發現問題

昨天在幫同事編譯安裝Linux環境時,遇到一個問題:
WEB服務器是apache,數據庫是MySQL。

于是寫了一個測試連接數據庫的php頁面:
復制代碼 代碼如下:$mysql = mysql_connect('localhost','root','');

打開 http://localhost/test.php 測試

提示:Can't connect to local MySQL server through socket...

檢查環境正常

以為是數據庫沒有啟動,于是查看一下進程,MySQL在進程里,重啟了一下MySQL.

使用mysql -u root -p 可以進入MySQL操作界面

直接使用/usr/local/php5/bin/php /web/test.php執行可以連上數據庫
apache也重啟了,一樣無效

疑點:為何網頁執行失敗,命令執行卻成功

這下就郁悶了,使用php命令直接執行就成功,通過網頁執行就失敗。難道是apache導致?網上搜索了大堆資料也沒找到解決方案,重新編譯安裝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連接數據庫時,主機填寫localhost與其它的區別閱讀了大量資料,最后得知:

當主機填寫為localhost時mysql會采用 unix domain socket連接
當主機填寫為127.0.0.1時mysql會采用tcp方式連接
這是linux套接字網絡的特性,win平臺不會有這個問題

解決方法

在my.cnf的[mysql]區段里添加
復制代碼 代碼如下:protocol=tcp
保存重啟MySQL,問題解決!

php技術PHP中使用localhost連接Mysql不成功的解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲 成人 在线 | 中文字字幕一区二区三区四区五区 | 国产精品av久久久久久久久久 | 久久精品91| 一区在线视频 | 成人性生交大片免费看中文带字幕 | 日韩精品在线网站 | 国产精品日日摸夜夜添夜夜av | 成人国产精品久久 | 国产精品视频免费观看 | 免费观看a级毛片在线播放 黄网站免费入口 | 三级在线视频 | 91av在线免费观看 | 中文字幕精品一区 | 国户精品久久久久久久久久久不卡 | 一区二区免费在线观看 | 国产精品亚洲综合 | 成人国产精品久久久 | 在线国产视频观看 | 中文字幕一区二区三区乱码在线 | 一区视频 | www.99热| 国内自拍偷拍一区 | 午夜视频在线视频 | 日韩免费视频 | 久久久久久国产精品免费免费狐狸 | 亚洲网站在线观看 | 久久一热 | 日韩中文字幕网 | 毛片一区二区 | 天天综合网永久 | 欧美精品一区二区在线观看 | 中文字幕一级 | 国产福利免费视频 | 精品在线一区二区三区 | 一区二区三区在线免费观看 | 亚洲福利在线视频 | 91精品国产91久久久久久最新 | 在线中文字幕第一页 | 亚洲精品无| 在线观看国产视频 |