中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > Web开发 > PHP > PHP综合
php的pconnect()
作者:未知 时间:2005-09-13 23:32 出处:Blog.ChinaUnix.net 责编:chinaitpower
              摘要:php的pconnect()

PHP在連結MYSQL時有兩個FUNCTION
CONNECT與PCONNECT
這兩個函式的差別在哪裡?
一般的標準答案都是:
PCONNECT是持續性的連接,PHP會重複使用已經存在的資料庫連線

但是再追問下去,能說得出來的人就少了許多
常見的疑問有:
什麼時候要用CONNECT什麼時候用PCONNECT?
mysql_close何時使用?
為什麼DATABASE上有一堆SLEEP的PROCESS?
明明用PCONNECT為何每次RESOURCE ID都不同?

先回歸到最簡單的解釋,pconnect會去檢查是否有已經存在的資料庫連線。
若有,就使用舊的連線;若無,就新開啟一個連線
但是這裡所說得檢查連線,是指這一個APACHE行程所開啟的資料庫連線
而不是這一台WEB SERVER所開啟的資料庫連線。
一台WEB SERVER上可能有上百個APAHE行程(2.0預設最大150個)
也就是說 在最大情況下可能會有上百個PCONNECT造成的資料庫連線
(實際上會遠少於此)
所以同樣使用PCONNECT是會出現不同RESOURCE ID的
因為他可能是在不同行程上面執行

而PCONNECT是不會在查詢完成後就關閉,而是會等待一定時間
這個時間可以由MYSQL上的wait_timeout設定
而且mysql_close並無法關閉pconnect所開啟的連線,只能關閉connect所開啟的資料庫連線。當然如果沒有CLOSE在經過TIMEOUT時間之後也是會被DB DROP掉。

PCONNECT必須要小心使用,在寫的不好的CODE中,會殘留一大批的DATABASE CONNECTION。最大值可以這樣計算
每台SERVER的APACHE行程數 * 所有WEB SERVEWR數量
當然不需要我來提醒,每個連線都會消耗DB的CPU TIME與MEMORY

寫WEB CODE時,不論使用何種語言,有兩點一定要再動手寫之前先有答案
一是,要從DATABASE抓取什麼資料
二是,要傳送什麼資料到USER端
(其實這也不只用於WEB)
DATABASE的連線是很慢的,能夠一次抓取完所需的資料,就不要分兩次

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有