PHP訪問資料庫叢集的方法小結_php技巧

來源:互聯網
上載者:User

本文總結分析了PHP訪問資料庫叢集的方法。分享給大家供大家參考,具體如下:

一般常見的有三種做法:

1、自動判斷sql是否為讀,來選擇資料庫的串連:

執行個體化php DB類的時候,需要一次串連兩台伺服器,然後根據slq選擇不同的串連,舉個例子:

$link_w = mysql_connect($w_host,$user,$pwd);$link_r = mysql_connect($r_host,$user,$pwd);//執行sqlif(preg_match("/^select/i", trim($sql))) {  mysql_query($sql,$link_r);}else {  mysql_query($sql,$link_w);}

這個方法的優點就是開發人員執行sql不用區分讀或者寫,在db類的底層自己判斷,缺點是,往往只需要讀或者寫時也需要開啟兩個串連。

2、調用的時候自己選擇:

當執行sql前一般是能確定是寫還是讀,所以開發人員需要手動的調用不同的串連,舉個例子:

$w_db = new DB('w');$w_db -> query('insert into .....');

當sql為讀:

$r_db = new DB('r');$r_db -> query('select .....');

主要通過,傳的參數來區別sql是讀還是寫,每次調用sql前需要調用開發人員自己判斷。

3、使用MySQL Proxy做中介層代理,會自動將判斷sql是讀或者寫,將請求轉寄給伺服器。優點是程式不用更改任何代碼,只要啟動mysql proxy 時分別指定讀或寫的伺服器:

--proxy-backend-addresses--proxy-read-only-backend-addresses

更多關於PHP相關內容感興趣的讀者可查看本站專題:《php操作office文檔技巧總結(包括word,excel,access,ppt)》、《php日期與時間用法總結》、《php物件導向程式設計入門教程》、《php字串(string)用法總結》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧匯總》

希望本文所述對大家PHP程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.