php连接mysql服务器时localhost与127.0.0.1的区别

前两天配置phpmyadmin时一直连接出错, 在网上有人说将主机host改为127.0.0.1(默认的是localhost), 改了之后就成功了, 在手册中找到了这么一段,应该就是这个原因了:

<手册中 mysqli目录下的Connections一节>

The MySQL server supports the use of different transport layers for connections. Connections use TCP/IP, Unix domain sockets or Windows named pipes.

The hostname localhost has a special meaning. It is bound to the use of Unix domain sockets. It is not possible to open a TCP/IP connection using the hostname localhost you must use 127.0.0.1 instead.

Example #1 Special meaning of localhost

<?php
$mysqli  = new  mysqli ( "localhost" ,  "user" ,  "password" ,  "database" );
if ( $mysqli -> connect_errno ) {
    echo  "Failed to connect to MySQL: ("  .  $mysqli -> connect_errno  .  ") "  .  $mysqli -> connect_error ;
}
echo  $mysqli -> host_info  .  "\n" ;

$mysqli  = new  mysqli ( "127.0.0.1" ,  "user" ,  "password" ,  "database" ,  3306 );
if ( $mysqli -> connect_errno ) {
    echo  "Failed to connect to MySQL: ("  .  $mysqli -> connect_errno  .  ") "  .  $mysqli -> connect_error ;
}

echo  $mysqli -> host_info  .  "\n" ;
?>

以上例程会输出:

Localhost via UNIX socket
127.0.0.1 via TCP/IP

大意就是说主机名localhost只能在使用socket连接到mysql服务时使用, 如果通过tcp/ip协议连接mysql服务则主机名只能使用127.0.0.1 而不能用localhost.



转载于:https://my.oschina.net/u/912810/blog/315524

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值