mysql中localhost和127.0.0.1的区别
mysql的默认的root用户会有很多行,自习观察后你就会发现每行的用户名或密码可能相同,但是host一定不同,host是登陆用户的主机名,也就是说,'localhost','127.0.0.1','phpgao.local','%'都算不同的用户!
理解了这一点后,那么我的问题就附上水面了!
有些TX经常会遇到这个问题:
使用PHP连接mysql数据库,使用localhost作为主机名总是连接失败,但是使用'127.0.0.1'就可以顺利连接,这到底是为什么? mysql中HOST为localhost和127.0.0.1到底有什么区别?
经过一番搜索,老高总结如下:
使用到的命令
mysql>status;
mysql>show grants;
- 类Unix系统下,如果不使用-h指定主机名或者使用了localhost,那么会使用unix domain socket与mysql服务器沟通,比TCP/IP快一些!所以你想使用TCP/IP协议,请将host指定为'127.0.0.1'。
- PHP连接mysql如果使用'localhost'发生问题,首先可以明确的是PHP会试着使用unix domain socket与服务器连接,所以请检查php.ini中
mysql.default_socket = /var/mysql/mysql.sock
是否配置正确。 - 如果想要明确连接方式,可以再配置文件中显式声明
protocol=tcp
- 在mysql的官方文档中解释道:如果mysql在win上跑,如果系统开启了--enable-named-pipe,然后访问服务器的时候没有指定hostname,那么mysql客户端会以pipe为优先连接,如果连接失败,那么再会去尝试使用TCP/IP去连接。你可以指定hostname为
.
在win下强制使用pipes。
If the MySQL server is running on Windows, you can connect using TCP/IP. If the server is started with the --enable-named-pipe option, you can also connect with named pipes if you run the client on the host where the server is running. The name of the named pipe is MySQL by default. If you do not give a host name when connecting to mysqld, a MySQL client first tries to connect to the named pipe. If that does not work, it connects to the TCP/IP port. You can force the use of named pipes on Windows by using . as the host name.
Reference:
http://stackoverflow.com/questions/19712307/mysql-localhost-127-0-0-1 http://stackoverflow.com/questions/3715925/localhost-vs-127-0-0-1 http://dev.mysql.com/doc/refman/5.5/en/can-not-connect-to-server.html http://madproject.com/general/connect-to-mysql-using-localhost-instead-of-127-0-0-1-on-a-mac/ http://stackoverflow.com/questions/9714899/php-mysql-difference-between-127-0-0-1-and-localhost http://superuser.com/questions/744972/connecting-to-mysql-from-127-0-0-1-instead-of-from-localhost http://blog.csdn.net/xifeijian/article/details/12879395 http://blog.csdn.net/topasstem8/article/details/18357789
相关文章
- Mysql:2003 - Can't connect to MySQL server on 'localhost' (10061 "Unknown error") 解决方法
- Oracle与MySQL: 不同之处(oracle与mysql的区别)
- Redis与MySQL的优劣对比(redis和mysql的区别)
- MySQL数据库类型及其应用(mysql所有类型)
- MySQL中视图与表的区别与联系(mysql视图与表的区别)
- MySQL引擎的差异:深入比较(mysql引擎区别)
- 深度探究NoSQL与MySQL的差异(nosql和mysql的区别)
- MySQL和DB2:两者有何不同?(mysql与db2的区别)
- 比较Oracle和MySQL:异同之处(oracle和mysql区别)
- 对比分析:MySQL和Oracle的差异(mysql和oracle区别)
- MySQL中PK和NN的作用及区别(mysql中pk nn)
- MySQL中mod的含义及用法(mysql中mod的意思)
- C语言中实现MySQL数据库操作(c 中运行mysql)
- MySQL中位运算的应用(bit在mysql)
- 比较AQL与MySQL的异同(aql和mysql的区别)
- MySQL中函数与事件的使用方法详解(mysql中函数 事件)
- 写命令区别MySQL 三大读(mysql 三大读)
- 深入浅出MySQL探究X锁与U锁的区别与应用(mysql x锁 u锁)
- MySQL多种索引类型的使用和区别(mysql 不同 索引)
- MySQL下载及安装教程快速掌握MySql下载及安装方法,更高效地使用MySql数据库(mysql下载了在哪)
- MySQL中不等于的使用和区别(mysql不等于和区别)
- MySQL下载故障,怎么办(mysql下载打不开)