mysql_connect localhost和127.0.0.1的区别(网络层阐述)
发布:smiling 来源: PHP粉丝网 添加日期:2021-05-18 20:30:04 浏览: 评论:0
这篇文章主要介绍了mysql_connect localhost和127.0.0.1的区别(网络层阐述),本文从网络通信层面讲解了它们的不同,需要的朋友可以参考下
connects.php 代码如下:
mysql_connect('127.0.0.1','root','zzzizzz1');
mysql_connect('localhost','root','zzzizzz1');
使用strace获取系统调用:
- 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也是可靠的,消息既不会丢失也不会顺序错乱。
Tags: mysql_connect localhost
相关文章
- ·undefined function mysql_connect(2014-09-11)
- ·php mysql_connect 与mysql_pconnect函数与实例教程(2014-09-12)
- ·PHP提示Deprecated: mysql_connect(): The mysql extension is deprecated的解决方法(2021-04-10)
- ·phpmyadmin连接远程数据库配置方法(2014-03-13)
- ·PHP中使用localhost连接Mysql不成功的解决方法(2021-04-07)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)