本文總結分析了PHP存取資料庫叢集的方法。分享給大家供大家參考,具體如下:
一般常見的有三種做法:
1、自動判斷sql是否為讀,來選擇資料庫的連接:
實例化php DB類的時候,需要一次連接兩台伺服器,然後根據slq選擇不同的連接,舉個例子:
$link_w = mysql_connect($w_host,$user,$pwd); $link_r = mysql_connect($r_host,$user,$pwd); //执行sql if(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程式設計有幫助。
以上就介紹了PHP存取資料庫叢集的方法小結,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。