>  기사  >  백엔드 개발  >  mysql是通过什么方式跟PHP打交道的?

mysql是通过什么方式跟PHP打交道的?

WBOY
WBOY원래의
2016-06-06 20:43:55784검색

mysql是通过什么方式跟PHP打交道的?

回复内容:

mysql是通过什么方式跟PHP打交道的?

我觉得问题应该改为"PHP是通过什么方式跟mysql打交道的更加合适"

这里面有几层答案

首先, 可以说PHP是通过与C语言的扩展来和mysql打交道. PHP是可以用C语言写扩展的, 其他语言比如python, ruby, perl都可以. 所以很多情况下用C语言写一点点PHP/Python的扩展, 可以将原来的C语言mysql driver变成PHP/Python的mysql driver, 实际上最后还是在调用mysql的那个C语言版本的动态库(.dll或者.so)

很多东西都是这么来的, 比如opengl的库, crypto库, memcache库等等

再往下一层, 我们也可以说PHP是通过sock或者tcp来连接mysql服务器的. 如果mysql服务器和PHP运行在同一台机器上, 那么可以通过sock或者127.0.0.1的tcp连接与mysql服务器通信, 说白了也就是跨进程通信(即使在本地, 进程间通信往往也使用127.0.0.1+端口号这样的方式, 据说内核优化过, 不会走到网卡, 性能挺高)

如果不在同一台机器上, 那么就是走网卡的tcp连接了

最后, 是不是所有的driver都要用到C语言这一层呢? 如果协议简单, 完全可以在PHP这一层实现一个driver, 然后调用PHP的socket库来实现. 不过处于性能的考虑, 协议的复杂性(mysql服务器的协议), 日后的可维护性(mysql版本升级), 所以基本上没人这么干.

  • PHP mysql的操作,为什么要返回一个字符串数组,不返回真实的数据类型?
  • php-mysqli 源码
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.