對PHP程式而言,最佳化永無止境。而資料庫連接池就在某種程度上起到了優化的作用。其使得對使用者的每一個請求而言,無需每次都像資料庫申請連結資源。而是透過已存在的資料庫連接池中的連結來返回,從時間上,效率上,都是一個大大的提升。因此本篇文章就帶領你們一起了解PHP如何用資料庫連結池實現?
相關推薦:PHP陣列中什麼是尋找演算法?如何找到?
xml
#XML作為一門高可用的結構化語言,作為設定檔真的是言簡意賅,雖然相較於近來設定檔界的YAML, JSON等翹楚來說,可能有效資料的佔比比較小,但是這種冗餘是有其存在的價值的。
基本上,看完xml的節點就可以知道其功能。這也是為什麼大專案都會使用XML作為設定檔的原因。
可以容忍冗餘,但是不能帶來一點歧義,或是維護困難方面的問題。
在PHP中,使用XML檔案會是一件賞心悅目的事情,雖然相對於Java程式而言,如此。但相較於Python處理,PHP程序就顯得沒有那麼優雅了。
讀取設定檔
讀取設定檔其實說白了就是對檔案的讀取,然後包裝一下。我常用的有以下兩種方式。
簡易方式
第一次使用這個簡易方式的時候,真的是有點鬱悶。
$content = file_get_contents("filename.xml");echo $content;
結果使用瀏覽器存取這個測試用的php檔案時,卻只顯示了xml的內容部分,但是節點資訊什麼的根本沒有顯示。
然後我還特地查閱了一下幫助文檔,這個函數返回的結果是字符串無疑的啊。然後vardump之後也證明了這一點。於是也沒有多想,還以為這種方式能自動的過濾掉XML的標籤TAG資訊呢。
最後一個偶然的測試,打開了網頁源代碼,發現這個函數確實讀到了XML的所有信息,只不過顯示在瀏覽器上就會被瀏覽器給自動解析了。所以只能看到相關的內容部分。
常規方式
常規方式就是按部就班的讀取檔案了。其餘的話和上述方案一致。
// 读取配置文件内容 $handle = fopen("filepath", "r"); $content = fread($handle, filesize("filepath"));
PHP解析XML
上述兩種讀取文件,其實都是為了PHP解析XML來做準備的。關於PHP解析XML的方式的部落格有很多。方式也有很多,像simplexml,XMLReader,DOM啦等等。但是對於比較小型的xml設定文件,simplexml就足夠了。
設定檔
<?xml version="1.0" encoding="UTF-8" ?><mysql> <!-- 为防止出现意外,请按照此标准顺序书写.其实也无所谓了 --> <host>localhost</host> <user>root</user> <password>123456</password> <db>test</db> <port>3306</port></mysql>
解析
<?php /** * 作为解析XML配置文件必备工具 */ class XMLUtil { public static $dbconfigpath = "./db.config.xml"; public static function getDBConfiguration() { $dbconfig = array (); try { // 读取配置文件内容 $handle = fopen(self::$dbconfigpath, "r"); $content = fread($handle, filesize(self::$dbconfigpath)); // 获取xml文档根节点,进而获取相关的数据库信息 $mysql = simplexml_load_string($content); // 将获取到的xml节点信息赋值给关联数组,方便接下来的方法调用 $dbconfig['host'] = $mysql->host; $dbconfig['user'] = $mysql->user; $dbconfig['password'] = $mysql->password; $dbconfig['db'] = $mysql->db; $dbconfig['port'] = $mysql->port; // 将配置信息以关联数组的形式返回 return $dbconfig; } catch ( Exception $e ) { throw new RuntimeException ( "<mark>读取数据库配置文件信息出错!</mark><br />" ); } return $dbconfig; }
資料庫連線池
對PHP程式而言,最佳化永無止境。而資料庫連接池就在某種程度上起到了優化的作用。其使得對使用者的每一個請求而言,無需每次都像資料庫申請連結資源。而是透過已存在的資料庫連接池中的連結來返回,從時間上,效率上,都是一個大大的提升。
於是,這裡簡單的模擬了一下資料庫連接池的實作。核心在於維護一個「池」。
從池子中取,用畢,歸還給池子。
<?php /**x * PHP中的数据库 工具类设计 * 郭璞 * 2016年12月23日 * **/ class DbHelper { private $dbconfig; private $dbpool; public $poolsize; public function __construct($poolsize = 20) { if (! file_exists ( "./utils.php" )) { throw new RuntimeException ( "<mark>utils.php文件丢失,无法进行配置文件的初始化操作!</mark><br />" ); }else { require './utils.php'; } // 初始化 配置文件信息 $this->dbconfig = XMLUtil::getDBConfiguration (); // 准备好数据库连接池“伪队列” $this->poolsize = $poolsize; $this->dbpool = array (); for($index = 1; $index <= $this->poolsize; $index ++) { $conn = mysqli_connect ( $this->dbconfig ['host'], $this->dbconfig ['user'], $this->dbconfig ['password'], $this->dbconfig ['db'] ) or die ( "<mark>连接数据库失败!</mark><br />" ); array_push ( $this->dbpool, $conn ); } } /** * 从数据库连接池中获取一个数据库链接资源 * * @throws ErrorException * @return mixed */ public function getConn() { if (count ( $this->dbpool ) <= 0) { throw new ErrorException ( "<mark>数据库连接池中已无链接资源,请稍后重试!</mark>" ); } else { return array_pop ( $this->dbpool ); } } /** * 将用完的数据库链接资源放回到数据库连接池 * * @param unknown $conn * @throws ErrorException */ public function release($conn) { if (count ( $this->dbpool ) >= $this->poolsize) { throw new ErrorException ( "<mark>数据库连接池已满</mark><br />" ); } else { array_push ( $this->dbpool, $conn ); } } }
測試
申請過多時,拒絕請求
在申請資料庫連線小於20的時候,程式直接從資料庫連線池中獲取。
當申請的資料庫連結資源大於資料庫連線池的上限時,不予提供。並提示異常。
已滿後拒絕放入
當資料庫連線池內已滿的時候,如果想回首自訂的資料庫連結資源,則不予支持,並報錯提示。
總結
回顧一下,本試驗主要是以物件導向的角度,設計並實作了一個簡易的資料庫連線池。在一定程度上對PHP程式碼的最佳化起到了作用。
另外簡單的使用了simplexml對於XML檔案的解析處理, 以及常用的檔案讀取的操作。
相關學習影片分享:php影片教學
以上是PHP如何用資料庫連線池實作?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文比較了酸和基本數據庫模型,詳細介紹了它們的特徵和適當的用例。酸優先確定數據完整性和一致性,適合財務和電子商務應用程序,而基礎則側重於可用性和

本文討論了確保PHP文件上傳的確保,以防止諸如代碼注入之類的漏洞。它專注於文件類型驗證,安全存儲和錯誤處理以增強應用程序安全性。

本文討論了在PHP中實施API速率限制的策略,包括諸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之類的庫。它還涵蓋監視,動態調整速率限制和手

本文討論了使用password_hash和pyspasswify在PHP中使用密碼的好處。主要論點是,這些功能通過自動鹽,強大的哈希算法和SECH來增強密碼保護

本文討論了OWASP在PHP和緩解策略中的十大漏洞。關鍵問題包括注射,驗證損壞和XSS,並提供用於監視和保護PHP應用程序的推薦工具。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

記事本++7.3.1
好用且免費的程式碼編輯器

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器