找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1682|回复: 0
打印 上一主题 下一主题

mysql_connect localhost和127.0.0.1的区别(网络层阐述)

[复制链接]

2617

主题

2617

帖子

7789

积分

论坛元老

Rank: 8Rank: 8

积分
7789
跳转到指定楼层
楼主
发表于 2018-2-14 05:47:36 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

            connects.php
[U]复制代码[/U] 代码如下:
mysql_connect('127.0.0.1','root','zzzizzz1');
mysql_connect('localhost','root','zzzizzz1');
使用strace获取系统调用:
[U]复制代码[/U] 代码如下:
strace php connects.php 2>&1 | grep connect
#127.0.0.1 -> internet socket
connect(3, {sa_family=AF_INET, sin_port=htons(3306), sin_addr=inet_addr("127.0.0.1")}, 16) = -1 EINPROGRESS (Operation now in progress)
#localhost -> unix domain socket
connect(7, {sa_family=AF_FILE, path="/var/run/mysqld/mysqld.sock"}, 110) = 0
Socket原本是为网络通讯设计的,但后来在Socket的框架上发展出一种IPC机制,就是UNIX Domain Socket。
虽然网络socket也可用于同一台主机的进程间通讯(通过loopback地址127.0.0.1),但是UNIX Domain Socket用于IPC更有效率:
不需要经过网络协议栈,不需要打包拆包、计算校验和、维护序号和应答等,只是将应用层数据从一个进程拷贝到另一个进程。
这是因为,IPC机制本质上是可靠的通讯,而网络协议是为不可靠的通讯设计的。
UNIX Domain Socket也提供面向流和面向数据包两种API接口,类似于TCP和UDP,但是面向消息(UDP)的UNIX Domain Socket也是可靠的,消息既不会丢失也不会顺序错乱。
            
            
您可能感兴趣的文章:
  • linux mysql忘记密码的多种解决或Access denied for user ''root''@''localhost''
  • Can''t connect to MySQL server on localhost (10061)解决方法
  • php运行提示Can''t connect to MySQL server on ''localhost''的解决方法
  • mysql error 1130 hy000:Host''localhost''解决方案
  • Can''t connect to MySQL server on ''localhost'' (10048)问题解决方法
  • Mac os 解决无法使用localhost连接mysql问题
  • php mysql localhost,127.0.0.1和ip区别
  • PHP中使用localhost连接Mysql不成功的解决方法
  • mysql Access denied for user ‘root’@’localhost’ (using password: YES)解决方法
  • mysql ERROR 1044 (42000): Access denied for user ''''@''localhost'' to database
  • IPv6设置后如何解决MySQL无法连接localhost的问题
  • MySQL ERROR 1045 (28000): Access denied for user ''root''@''localhost'' (using password: NO) 的原因分解决办法
  • MySQL 可以用localhost 连接,但不能用IP连接的问题解决方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端