一、PHP 連接數(shù)據(jù)庫(kù)什么情況下才會(huì)用到持久鏈接 mysql_pconnect()
一般模式,當(dāng)php-cgi隨請(qǐng)求結(jié)束時(shí),mysql_close()是否執(zhí)行,并無(wú)大的影響,因?yàn)檫@種情況下,mysql連接也會(huì)隨進(jìn)程結(jié)束而關(guān)閉;
當(dāng)開(kāi)啟php-fpm pm=static方式可能用到,因?yàn)榇藭r(shí),php-cgi進(jìn)程是持久的,當(dāng)建立長(zhǎng)連接后,后面的請(qǐng)求將可以繼續(xù)請(qǐng)求wait_timeout時(shí)間內(nèi)的的連接,wait_timeout會(huì)出現(xiàn)MySQL server has gone away 錯(cuò)誤,這是你要加上重連機(jī)制。
持久數(shù)據(jù)庫(kù)連接是指在腳本結(jié)束運(yùn)行時(shí)不關(guān)閉的連接。當(dāng)收到持久連接的請(qǐng)求時(shí),PHP 將檢查是否已經(jīng)存在相同的持久連接(前面已經(jīng)開(kāi)啟的)——如果存在,將直接使用這個(gè)連接。如果不存在,則建立新的連接。所謂“相同”的連接是指用相同的用戶名和密碼連接到相同主機(jī)的連接。
對(duì) web 服務(wù)器的工作方式和負(fù)載分配方式?jīng)]有完全理解可能會(huì)錯(cuò)誤地理解持久連接。特別是持久連接不會(huì)在相同的連接上提供建立“用戶會(huì)話”的能力,也不提供有效建立事務(wù)的能力。實(shí)際上,要非常清楚的了解持久連接不會(huì)提供任何非持久連接無(wú)法實(shí)現(xiàn)的功能。
延伸閱讀:
二、為什么要持久化連接
這和 web 服務(wù)器的工作方式有關(guān)。web 服務(wù)器可以通過(guò)三種方法來(lái)利用 PHP 生成 web 頁(yè)面。
名列前茅種方法是將 PHP 自以為 CGI“包裝器”用作一個(gè)單獨(dú)運(yùn)行的語(yǔ)言解釋器(CGI Wapper)。當(dāng)以這種方法運(yùn)行時(shí),PHP 會(huì)為向 web 服務(wù)器的每個(gè) PHP 頁(yè)面請(qǐng)求創(chuàng)建并銷毀 PHP 解釋器的時(shí)候?qū)嵗S捎谄鋾?huì)隨每個(gè)請(qǐng)求的結(jié)束而銷毀,因此其獲取的任何資源(例如指向 SQL 數(shù)據(jù)庫(kù)服務(wù)器的鏈接)都會(huì)在銷毀時(shí)關(guān)閉。在這種情況下,不會(huì)從使用持久連接中獲得任何好處——因?yàn)楦静粫?huì)持久。
第二,也是最流行的方法是把 PHP 用作多進(jìn)程 web 服務(wù)器的一個(gè)模塊,這種方法目前只適用于 Apache。多進(jìn)程的服務(wù)器通常有一個(gè)父進(jìn)程和一組子進(jìn)程協(xié)調(diào)運(yùn)行,子進(jìn)程負(fù)責(zé)提供網(wǎng)頁(yè)的工作。每當(dāng)接收達(dá)到客戶端提出請(qǐng)求時(shí),該請(qǐng)求會(huì)傳遞給尚未給其它客戶端提供服務(wù)的某個(gè)子進(jìn)程。這也就是說(shuō)當(dāng)相同的客戶端第二次向服務(wù)端發(fā)出請(qǐng)求時(shí),它將有可能由與名列前茅次不同的某個(gè)子進(jìn)程提供服務(wù)。在開(kāi)啟了一個(gè)持久連接后,所有請(qǐng)求 SQL 服務(wù)的后繼頁(yè)面都能夠重用與 SQL 服務(wù)器建立的相同連接。
最后一種方法是將 PHP 用作多線程 web 服務(wù)器的插件。目前 PHP 支持 WSAPI 和 NSAPI(在 Windows 上),允許 PHP 作為 Netscape FastTrack(iPlanet)、Microsoft 的 Internet Information Server (IIS) 和 O’Reilly 的 WebSite Pro 等多線程服務(wù)器的插件使用。該行為與前面描述的多過(guò)程模型相同。