国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

MySQL數(shù)據(jù)庫主機(jī)127.0.0.1與localhost區(qū)別

2024-07-25 19:08:30
字體:
供稿:網(wǎng)友

可能有很多朋友都會(huì)碰到一個(gè)問題不知道127.0.0.1與localhost有什么區(qū)別,但是有的時(shí)間會(huì)發(fā)現(xiàn)使用localhost連接不了,但是改成127.0.0.1即可了連接了,那么他們會(huì)有什么區(qū)別呢,下面我給大家介紹。

  1. mysql -h 127.0.0.1 的時(shí)候,使用 TCP/IP 連接, mysql server 認(rèn)為該連接來自于127.0.0.1或者是"localhost.localdomain"
  2. mysql -h localhost 的時(shí)候,是 不使用TCP/IP 連接的,而使用 Unix socket ;此時(shí),mysql server則認(rèn)為該client是來自"localhost"
  3. mysql權(quán)限管理中的"localhost"有特定含義:

注意:雖然兩者連接方式有區(qū)別,但當(dāng)localhost 為默認(rèn)的127.0.0.1時(shí),兩種連接方式使用的權(quán)限記錄都是以下的1.row的記錄(因?yàn)橛涗浽谇埃缺黄ヅ洌?/p>

*************************** 1. row *************************** Host: localhost User: root ...... *************************** 2. row *************************** Host: 127.0.0.1 User: root 

證明:

shell> mysql -h 127.0.0.1 mysql> status; Currentuser: root@localhost SSL: Notin use Current pager: stdout Using outfile: '' Using delimiter: ; Server version: 5.1.33-log Source distribution Protocol version: 10 Connection: 127.0.0.1 via TCP/IP shell> mysql -h locahostmysql> status; Currentuser: root@localhost SSL: Notin use Current pager: stdout Using outfile: '' Using delimiter: ; Server version: 5.1.33-log Source distribution Protocol version: 10 Connection: Localhost via UNIX socket

發(fā)現(xiàn)問題

昨天在幫同事編譯安裝Linux環(huán)境時(shí),遇到一個(gè)問題:

Web服務(wù)器是apache,數(shù)據(jù)庫是MySQL。

于是寫了一個(gè)測(cè)試連接數(shù)據(jù)庫的PHP頁面:

$mysql = mysql_connect('localhost','root','');

打開 http://localhost/test.php 測(cè)試

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

檢查環(huán)境正常

以為是數(shù)據(jù)庫沒有啟動(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ù)庫

apache也重啟了,一樣無效

疑點(diǎn):為何網(wǎng)頁執(zhí)行失敗,命令執(zhí)行卻成功

這下就郁悶了,使用php命令直接執(zhí)行就成功,通過網(wǎng)頁執(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加入

127.0.0.1 qttc

使用qttc當(dāng)主機(jī)連接也正常,唯獨(dú)就不認(rèn)localhost。

localhost連接方式不同導(dǎo)致

為了了解PHP連接數(shù)據(jù)庫時(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ū)段里添加

protocol=tcp

總結(jié)

以上所述是小編給大家介紹的MySQL數(shù)據(jù)庫主機(jī)127.0.0.1與localhost區(qū)別,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MYSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 汕头市| 博兴县| 襄垣县| 库尔勒市| 苍溪县| 西昌市| 夏河县| 阜宁县| 五寨县| 湟中县| 宁南县| 德格县| 青阳县| 错那县| 富锦市| 金山区| 湘西| 永州市| 汝阳县| 沂南县| 中卫市| 通州区| 兴国县| 西贡区| 进贤县| 岳普湖县| 新建县| 措勤县| 阿拉尔市| 杂多县| 西城区| 马边| 密云县| 华安县| 云霄县| 定安县| 道真| 天气| 海晏县| 扎鲁特旗| 凤庆县|