MySQL连接中127.0.0.1和localhost的关系

 

 

在测试的时候数据库配置为localhost时 , 始终显示数据库拒绝访问,

MySQL连接中127.0.0.1和localhost的关系

 

 

为了测试是root是否被设置了禁止登陆 , 用Navicat登陆显示成功 :

MySQL连接中127.0.0.1和localhost的关系

 

后将localhost改成127.0.0.1 ,发现测试成功 .

MySQL连接中127.0.0.1和localhost的关系

 

后来发现是我计算机hosts文件的问题 :

MySQL连接中127.0.0.1和localhost的关系

localhost不能正确的指定IP地址的原因 .

 

解决方法 :

方法① 用127.0.0.1地址连接 .

方法② 删掉多余的映射只留127 . 0.0.1和localhost的映射 .

MySQL连接中127.0.0.1和localhost的关系

测试成功 :

MySQL连接中127.0.0.1和localhost的关系

 

总结一下127.0.0.1和localhost的区别 :

localhost  本质上是一个域名 , 翻译过来也就是本地服务器的意思 . 在MySQL连接中使用socket方式 .

127.0.0.1  本质上是一个IP地址 , 即本地回环地址 , 在MySQL连接中使用TCP/IP方式 , 一般通过3306端口进入访问 .

 

两者属于并没有什么联系 .只是在计算机中用host联系起来 :

MySQL连接中127.0.0.1和localhost的关系

 

MySQL连接中127.0.0.1和localhost的关系

 

同时区别一下127.0.0.1   , localhost , 本机IP:

MySQL连接中127.0.0.1和localhost的关系