php持久化连接和非持久化连接的区别
php红连接mysql的 函数为 mysql_connect() 和 mysql_pconnect()
成都创新互联-专业网站定制、快速模板网站建设、高性价比曹妃甸网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式曹妃甸网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖曹妃甸地区。费用合理售后完善,10多年实体公司更值得信赖。
mysql_connect() 非持久化连接
mysql_pconnect() 持久化连接
两者区别:
简单的来说mysql_pconnect是用来在php与mysql间建立一条持续连接, 一般php的执行模式是脚本开始执行时初始化所有资源, 脚本运行结束后释放所有资源. 而mysql_pconnect的方式则不这样, mysql_connect每次都是重新通过tcp 或者unix domian socket跟sql服务器建立关系, 每次握手都是要消耗不少服务器资源的.
使用pconnect时, 有请求连接mysql时, php会检查是否之前有条相同的连接(以相同的用户名密码连接到同一个mysql服务器)已经建立, 如果有的话就直接使用这条连接。
mysql_connect与mysql_pconnect不会带来功能的差异, 只有性能上的差别.
PHP 连接数据库什么情况下才会用到持久链接 mysql
数据库持久连接理解
原来的mysql_connect是非持久连接,所以即使你在当前脚本中没有使用mysql_close函数进行关闭连接。脚本执行完毕后,连接标识会自动释放掉。这里是什么完成自动上释放的操作呢?php跟java一样,有一个垃圾资源回收系统,对于不再用到的资源会自动进行内存回收。怎么实现的,不知道。
pconnect()是建立持久连接,特点是:当前脚本执行完毕后。该连接标识不会被释放掉。下一个脚本文件还可以使用。
持久连接的实际用处:假如一个php脚本文件,同时会有多个用户访问该页面。里面涉及到数据库查询操作。如果使用非持久连接的话,那么每个用户都会从新建立一个数据库连接。而持久连接,多个用户访问同一个文件的时候,可以共享一个数据库连接标识。这样减少了连接次数。
使用持久连接常常是将php作为apache的一个扩展的时候进行的。
php连接mysql时是否有保持连接的办法
如果想持久连接. 可以使用 mysql_pconnect()
持久连接确实比每次都连接效率要高
但有个局限性. 一般数据库服务器的并发连接数是有限制的.
在持久连接模式下, 每个php进程, 都单独保持一个数据库连接,
如果数据库连接限制为 16 , 当有第17个连接请求来的时候,就会出现无法处理的情况
非持久连接的特性使的连接资源及时释放,就可以大大的避免连接数的问题(当然在高并发情况下 , 还是有可能发生的)
非持久连接的效率问题... 可以通过增加高速缓存层解决 (针对一些时效性要求不太高的情况)
缓存的增加, 能极大的减少数据库访问.
总结: 持久连接虽然效率高, 但会存在局限性. 同时维护也比较麻烦.
非持久连接效率低些, 但可以通过缓存解决.而且维护成本很低,
ps: 目前的大多数开源系统都是使用非持久连接.
分享名称:php数据库持久连接 php连接数据库查询数据
网页网址:http://scpingwu.com/article/hjihhh.html