搜尋
首頁後端開發PHP問題PHP如何用資料庫連線池實作?

PHP如何用資料庫連線池實作?

Jun 24, 2021 pm 02:35 PM
php資料庫連線池

對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[&#39;host&#39;] = $mysql->host;
            $dbconfig[&#39;user&#39;] = $mysql->user;
            $dbconfig[&#39;password&#39;] = $mysql->password;
            $dbconfig[&#39;db&#39;] = $mysql->db;
            $dbconfig[&#39;port&#39;] = $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 &#39;./utils.php&#39;;
        }
        // 初始化 配置文件信息
        $this->dbconfig = XMLUtil::getDBConfiguration ();

        // 准备好数据库连接池“伪队列”
        $this->poolsize = $poolsize;
        $this->dbpool = array ();
        for($index = 1; $index <= $this->poolsize; $index ++) {
            $conn = mysqli_connect ( $this->dbconfig [&#39;host&#39;], $this->dbconfig [&#39;user&#39;], $this->dbconfig [&#39;password&#39;], $this->dbconfig [&#39;db&#39;] ) 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如何用資料庫連線池實作?

當申請的資料庫連結資源大於資料庫連線池的上限時,不予提供。並提示異常。

PHP如何用資料庫連線池實作?

已滿後拒絕放入

當資料庫連線池內已滿的時候,如果想回首自訂的資料庫連結資源,則不予支持,並報錯提示。
PHP如何用資料庫連線池實作?

總結

回顧一下,本試驗主要是以物件導向的角度,設計並實作了一個簡易的資料庫連線池。在一定程度上對PHP程式碼的最佳化起到了作用。

另外簡單的使用了simplexml對於XML檔案的解析處理, 以及常用的檔案讀取的操作。

相關學習影片分享:php影片教學

以上是PHP如何用資料庫連線池實作?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:CSDN。如有侵權,請聯絡admin@php.cn刪除
酸與基本數據庫:差異和何時使用。酸與基本數據庫:差異和何時使用。Mar 26, 2025 pm 04:19 PM

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

PHP安全文件上傳:防止與文件相關的漏洞。PHP安全文件上傳:防止與文件相關的漏洞。Mar 26, 2025 pm 04:18 PM

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

PHP輸入驗證:最佳實踐。PHP輸入驗證:最佳實踐。Mar 26, 2025 pm 04:17 PM

文章討論了PHP輸入驗證以增強安全性的最佳實踐,重點是使用內置功能,白名單方法和服務器端驗證等技術。

PHP API率限制:實施策略。PHP API率限制:實施策略。Mar 26, 2025 pm 04:16 PM

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

php密碼哈希:password_hash和password_verify。php密碼哈希:password_hash和password_verify。Mar 26, 2025 pm 04:15 PM

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

OWASP前10 php:描述並減輕常見漏洞。OWASP前10 php:描述並減輕常見漏洞。Mar 26, 2025 pm 04:13 PM

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

PHP XSS預防:如何預防XSS。PHP XSS預防:如何預防XSS。Mar 26, 2025 pm 04:12 PM

本文討論了防止PHP中XSS攻擊的策略,專注於輸入消毒,輸出編碼以及使用安全增強的庫和框架。

PHP接口與抽像類:何時使用。PHP接口與抽像類:何時使用。Mar 26, 2025 pm 04:11 PM

本文討論了PHP中接口和抽像類的使用,重點是何時使用。界面定義了無實施的合同,適用於無關類和多重繼承。摘要類提供常見功能

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

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

DVWA

DVWA

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

SublimeText3 Mac版

SublimeText3 Mac版

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

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器