php连接mysql的方式,用的多的是mysql扩展、mysqli扩展、pdo_mysql扩展,是官方供给的。php的运行机制是页面执行完会释放所有该php进程中的所有资源的,倘若有多个并发拜访本地的测试页面 http://127.0.0.1/1.php按照php跟web服务器的区别,会开相应的线程或者进程去处理该请求,请求完了会释放结果的。亦便是php没法从语言层面从页面到页面之间传递有些数据,然则mysql_pconnect跟pdo中的ATTR, 设置array(PDO::ATTR_PERSISTENT => true)如下是能够实现长连接的。
$conn = new PDO($dsn, DB_USER, DB_PASSWORD,
array(PDO::ATTR_PERSISTENT => true)
);
长连接的功效我觉得是在高负载的状况下,经过复用长连接,减少了每一个页面的创立数据库连接的时间,而这个创立mysql connection的时间,在我的设备上 在数据库connnections < 10的状况下 , mysql pdo 创立connection time 为0.003ms, mysqli创立connection time为0.14ms在数据库connection接近满的时候,mysql pdo创立connection time为0.13ms, mysqli创立connection time为0.13ms以上样本都是在大概估测时间,时间太小欠好估计。其实创立连接的时间并不长,那这般为何必须mysql长连接、连接池这般的东西呢。那是在高负载下,例如server单机能够接受的mysql并发在200上下,web server的单机并发在700上下,那样当大批量500并发连接压过来的时候, web server没到满负荷, mysql提前到了满负荷,就会引起所有页面没法响应、或已然创立好数据库连接的页面执行很慢。
php中的mysql长连接因为php的运行方式有多种,因而长连接实现亦有多种。必须web服务器支持才能够实现长连接,由于php是无进程池跟连接池这种概念的,绝大都数状况下php应用本身不是一个应用服务器(后起之秀swoole, 是一个优秀的php应用服务器,不外是在c层面做的)。因而php的长连接其实是搭载apache这般的带有mpm模块的webserver, linux 下apache会守护一个进程池,开启了apache mpm功能之后,apache会默认维持一个进程池,mysql长连接之后的连接,并无做为socet连接关闭,而是做为一个不释放的东西,放进了进程池/线程池里面去。等必须连接的时,apache从它守护的进程池/线程池里面取出mysql socket connnection, 而后就能够复用此连接了。
这儿测试一下,首要本机环境是archlinux , 后文所用mysql httpd php都是自己编译的源代码,都在/home/dengpan/opt目录。httpd的mpm模型这儿采用的是worker, httpd的mpm(apache用于并行方面功能的,俗叫作多路处理模块)其实有perfork、worker、event三种。mpm的好处是让apache随时有些备用的spare或空闲的子进程(服务器线程池),随时等待新过来的请求,这般客户端不必须在请求服务之前等待子进程的产生。
运用什么mpm,必须单独指定编译进去apache里面去,例如编译work mpm到apache里面去,例如我的最简化httpd的编译参数是
./configure \
--with-apr=/home/dengpan/opt/apr-1.5.2 \
--with-apr-util=/home/dengpan/opt/apr-util-1.5.4 \
--prefix=/home/dengpan/opt/httpd-2.4.
|