mysql_connect localhost和127.0.0.1的区别(网络层阐述)
程序员文章站
2022-05-13 21:37:59
connects.php
复制代码 代码如下:
mysql_connect('127.0.0.1','root','zzzizzz1');
mysql_connect...
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也是可靠的,消息既不会丢失也不会顺序错乱。
上一篇: npoi读取excel
推荐阅读
-
Localhost 与127.0.0.1和IP的区别是什么
-
mysql_connect localhost和127.0.0.1的区别(网络层阐述)
-
[ASP.NET]关于DOT NET的IIS配置LocalHost访问和127.0.0.1访问的区别
-
连接MYSQL时,主机名为localhost和127.0.0.1的区别_MySQL
-
mysql_connect localhost和127.0.0.1的区别(网络层阐述)
-
mysql_connect localhost和127.0.0.1的区别(网络层阐述)
-
mysql_connect localhost和127.0.0.1的区别(网络层阐述)_PHP
-
Localhost 与127.0.0.1和IP的区别是什么
-
mysql_connect localhost和127.0.0.1的区别(网络层阐述),_PHP教程
-
mysql_connect localhost和127.0.0.1的区别(网络层阐述)