PHP訪問(wèn)數(shù)據(jù)庫(kù)集群的方法小結(jié)
本文總結(jié)分析了PHP訪問(wèn)數(shù)據(jù)庫(kù)集群的方法。分享給大家供大家參考,具體如下:
一般常見(jiàn)的有三種做法:
1、自動(dòng)判斷sql是否為讀,來(lái)選擇數(shù)據(jù)庫(kù)的連接:
實(shí)例化php DB類的時(shí)候,需要一次連接兩臺(tái)服務(wù)器,然后根據(jù)slq選擇不同的連接,舉個(gè)例子:
$link_w = mysql_connect($w_host,$user,$pwd);
$link_r = mysql_connect($r_host,$user,$pwd);
//執(zhí)行sql
if(preg_match("/^select/i", trim($sql))) {
mysql_query($sql,$link_r);
}else {
mysql_query($sql,$link_w);
}
這個(gè)方法的優(yōu)點(diǎn)就是開(kāi)發(fā)者執(zhí)行sql不用區(qū)分讀或者寫(xiě),在db類的底層自己判斷,缺點(diǎn)是,往往只需要讀或者寫(xiě)時(shí)也需要打開(kāi)兩個(gè)連接。
2、調(diào)用的時(shí)候自己選擇:
當(dāng)執(zhí)行sql前一般是能確定是寫(xiě)還是讀,所以開(kāi)發(fā)者需要手動(dòng)的調(diào)用不同的連接,舉個(gè)例子:
$w_db = new DB('w');
$w_db -> query('insert into .....');
當(dāng)sql為讀:
$r_db = new DB('r');
$r_db -> query('select .....');
主要通過(guò),傳的參數(shù)來(lái)區(qū)別sql是讀還是寫(xiě),每次調(diào)用sql前需要調(diào)用開(kāi)發(fā)者自己判斷。
3、使用MySQL Proxy做中間層代理,會(huì)自動(dòng)將判斷sql是讀或者寫(xiě),將請(qǐng)求轉(zhuǎn)發(fā)給服務(wù)器。優(yōu)點(diǎn)是程序不用更改任何代碼,只要啟動(dòng)mysql proxy 時(shí)分別指定讀或?qū)懙姆?wù)器:
--proxy-backend-addresses --proxy-read-only-backend-addresses
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php操作office文檔技巧總結(jié)(包括word,excel,access,ppt)》、《php日期與時(shí)間用法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP 用數(shù)組降低程序的時(shí)間復(fù)雜度
時(shí)間復(fù)雜度是開(kāi)發(fā)人員用來(lái)衡量應(yīng)用程序算法優(yōu)劣的主要因素??陀^地說(shuō),算法的優(yōu)劣除了和時(shí)間復(fù)雜度有關(guān),還與空間復(fù)雜度密切相關(guān)。2009-12-12
php計(jì)劃任務(wù)之驗(yàn)證是否有多個(gè)進(jìn)程調(diào)用同一個(gè)job的方法
這篇文章主要介紹了php計(jì)劃任務(wù)之驗(yàn)證是否有多個(gè)進(jìn)程調(diào)用同一個(gè)job的方法,涉及php針對(duì)計(jì)劃任務(wù)中進(jìn)程調(diào)用的相關(guān)使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-12-12
PHP操作SQL Server數(shù)據(jù)庫(kù)實(shí)現(xiàn)表的改查與統(tǒng)計(jì)
這篇文章主要介紹了如何利用PHP對(duì)MS SQL Server數(shù)據(jù)表的查詢、統(tǒng)計(jì)與修改,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-03-03
php簡(jiǎn)單統(tǒng)計(jì)在線人數(shù)的方法
這篇文章主要介紹了php簡(jiǎn)單統(tǒng)計(jì)在線人數(shù)的方法,涉及php針對(duì)文本文件的讀寫(xiě)與相關(guān)數(shù)學(xué)運(yùn)算技巧,需要的朋友可以參考下2016-05-05
php 多個(gè)變量指向同一個(gè)引用($b = &$a)用法分析
這篇文章主要介紹了php 多個(gè)變量指向同一個(gè)引用($b = &$a)用法,結(jié)合實(shí)例形式分析了PHP變量引用原理、優(yōu)缺點(diǎn)及相關(guān)操作技巧,需要的朋友可以參考下2019-11-11
drupal 代碼實(shí)現(xiàn)URL重寫(xiě)
開(kāi)啟了url_alter后,將實(shí)現(xiàn)兩個(gè)HOOK,hook_url_inbound_alter與hook_url_outbound_alter,作用是重寫(xiě)URL,第三方URL重寫(xiě)模塊都需要實(shí)現(xiàn)它。2011-05-05
php利用ffmpeg提取視頻中音頻與視頻畫(huà)面的方法詳解
想要提取視頻中的音頻信息,首選的技術(shù)是ffmpeg,ffmpeg是一個(gè)非常有用的命令行程序,它可以用來(lái)轉(zhuǎn)碼媒體文件。這篇文章主要給大家介紹了PHP利用ffmpeg提取視頻中音頻與視頻畫(huà)面的相關(guān)資料,需要的朋友可以參考下。2017-06-06

