男女疯狂一边摸一边做羞羞视频|啊好深好硬快点用力别停动态图|亚洲一区无码中文字幕|特级无码毛片免费视频播放▽|久久狠狠躁免费观看|国内精品久久久久久网站

mysqli 擴展和持久化連接

從 PHP 5.3 mysqli 擴展開(kāi)始支持持久化連接。 持久化連接已經(jīng)在 PDO MYSQL 和 ext/mysql 中提供支持。 持久化連接的目的在于重用客戶(hù)端到服務(wù)器之間的連接, 而不是每次在需要的時(shí)候都重新建立一個(gè)連接。 由于持久化連接可以將已經(jīng)建立的連接緩存起來(lái),以備后續的使用, 所以省去了建立新的連接的開(kāi)銷(xiāo), 因此可以帶來(lái)性能上的提升。

不像 mysql 擴展,mysqli 沒(méi)有提供一個(gè)特殊的方法用于打開(kāi)持久化連接。 需要打開(kāi)一個(gè)持久化連接時(shí),你必須在 連接時(shí)在主機名前增加p:。

使用持久化連接也會(huì )存在一些風(fēng)險, 因為在緩存中的連接可能處于一種不可預測的狀態(tài)。 例如,如果客戶(hù)端未能正常關(guān)閉連接, 可能在這個(gè)連接上殘留了對庫表的鎖, 那么當這個(gè)連接被其他請求重用的時(shí)候,這個(gè)連接還是處于 有鎖的狀態(tài)。 所以,如果要很好的使用持久化連接,那么要求代碼在和數據庫進(jìn)行交互的時(shí)候, 確保做好清理工作,保證被緩存的連接是一個(gè)干凈的,沒(méi)有殘留的狀態(tài)。

mysqli 擴展的持久化連接提供了內建的清理處理代碼。 mysqli 所做的清理工作包括:

  • 回滾處于活動(dòng)狀態(tài)的事務(wù)

  • 關(guān)閉并且刪除臨時(shí)表

  • 對表解鎖

  • 重置會(huì )話(huà)變量

  • 關(guān)閉預編譯 SQL 語(yǔ)句(在PHP中經(jīng)常發(fā)生)

  • 關(guān)閉處理程序

  • 釋放通過(guò) GET_LOCK() 獲得的鎖

這確保了將連接返回到連接池的時(shí)候, 它處于一種“干凈”的狀態(tài),可以被其他客戶(hù)端進(jìn)程所使用。

mysqli 擴展 通過(guò)自動(dòng)調用 C-API 函數 mysql_change_user() 來(lái)完成這個(gè)清理工作。

自動(dòng)清理的特性有優(yōu)點(diǎn)也有缺點(diǎn)。 優(yōu)點(diǎn)是程序員不再需要擔心附加的清理代碼, 因為它們會(huì )自動(dòng)調用。 然而缺點(diǎn)就是 性能 可能會(huì ) 慢一點(diǎn), 因為每次從連接池返回一個(gè)連接都需要執行這些清理代碼。

這個(gè)自動(dòng)清理的代碼可以通過(guò)在編譯 php 時(shí)定義 MYSQLI_NO_CHANGE_USER_ON_PCONNECT 來(lái)關(guān)閉。

注意:

mysqli 擴展在使用 MySQL Native Driver 或 Mysql Client Library(libmysql)時(shí)都支持持久化連接。

男女疯狂一边摸一边做羞羞视频|啊好深好硬快点用力别停动态图|亚洲一区无码中文字幕|特级无码毛片免费视频播放▽|久久狠狠躁免费观看|国内精品久久久久久网站