搜尋
首頁後端開發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刪除
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

如何为 Golang 数据库连接配置连接池?如何为 Golang 数据库连接配置连接池?Jun 06, 2024 am 11:21 AM

如何为Go数据库连接配置连接池?使用database/sql包中的DB类型创建数据库连接;设置MaxOpenConns以控制最大并发连接数;设置MaxIdleConns以设定最大空闲连接数;设置ConnMaxLifetime以控制连接的最大生命周期。

php怎么判断有没有小数点php怎么判断有没有小数点Apr 20, 2022 pm 08:12 PM

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php怎么设置implode没有分隔符php怎么设置implode没有分隔符Apr 18, 2022 pm 05:39 PM

在PHP中,可以利用implode()函数的第一个参数来设置没有分隔符,该函数的第一个参数用于规定数组元素之间放置的内容,默认是空字符串,也可将第一个参数设置为空,语法为“implode(数组)”或者“implode("",数组)”。

php怎么将url的参数转化成数组php怎么将url的参数转化成数组Apr 21, 2022 pm 08:50 PM

转化方法:1、使用“mb_substr($url,stripos($url,"?")+1)”获取url的参数部分;2、使用“parse_str("参数部分",$arr)”将参数解析到变量中,并传入指定数组中,变量名转为键名,变量值转为键值。

如何使用数据库连接池来管理MySQL连接?如何使用数据库连接池来管理MySQL连接?Jun 29, 2023 pm 08:04 PM

如何使用数据库连接池来管理MySQL连接?数据库连接池是一种经常被使用的技术,用于管理数据库连接的创建和释放。在高并发的环境下,使用数据库连接池可以有效地控制连接的数量,避免过多的连接造成性能问题。本文将介绍如何使用数据库连接池来管理MySQL连接。MySQL是一种常用的关系型数据库,其连接数是有限的。在访问MySQL数据库时,每次创建连接都需要进行一系列的

php怎么去除首位数字php怎么去除首位数字Apr 20, 2022 pm 03:23 PM

去除方法:1、使用substr_replace()函数将首位数字替换为空字符串即可,语法“substr_replace($num,"",0,1)”;2、用substr截取从第二位数字开始的全部字符即可,语法“substr($num,1)”。

php怎么去掉右边几个字符php怎么去掉右边几个字符Apr 21, 2022 pm 07:45 PM

去掉方法:1、用substr_replace()删除右边n位置开始的全部字符,语法“substr_replace($str,"",-n)”,参数“n”为需要去除的字符个数;2、用substr(),语法“substr($str,0,-n)”。

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脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

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

DVWA

DVWA

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

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具