PHP+MYSQL實(shí)現(xiàn)讀寫(xiě)分離簡(jiǎn)單實(shí)戰(zhàn)
1、Introduction
之前寫(xiě)過(guò)2篇文章,分別是:
基于此,我們?cè)賹?shí)現(xiàn)簡(jiǎn)單的PHP+Mysql讀寫(xiě)分離,從而提高數(shù)據(jù)庫(kù)的負(fù)載能力。
2、代碼實(shí)戰(zhàn)
<?php class Db { private $res; function __construct($sql) { $querystr = strtolower(trim(substr($sql,0,6))); //如果是select,就連接slave服務(wù)器 if($querystr == 'select') { $res=$this->slave_select($sql); $this->res=$res; } //如果不是select,就連接master服務(wù)器 else { $res=$this->master_change($sql); $this->res=$res; } } /** * slave從庫(kù)返回sql查詢(xún)結(jié)果 * @param $sql * @return array */ private function slave_select($sql){ //該處只是隨機(jī)獲取slave節(jié)點(diǎn)的ip,當(dāng)然,還可以采用其他算法獲取slave_ip $slave_server=$this->get_slave_ip(); $dsn="mysql:host=$slave_server;dbname=test"; $user='root'; $pass='123456'; $dbh=new PDO($dsn, $user, $pass); return $dbh->query($sql)->fetchAll(PDO::FETCH_ASSOC); } /**master主庫(kù)返回sql執(zhí)行結(jié)果 * @param $sql * @return int */ private function master_change($sql){ $master_server='192.168.33.22'; $dsn="mysql:host=$master_server;dbname=test"; $user='root'; $pass='123456'; $dbh=new PDO($dsn, $user, $pass); return $dbh->exec($sql); } /** * 隨機(jī)獲取slave-ip * @return mixed */ private function get_slave_ip(){ $slave_ips=['192.168.33.33','192.168.33.44']; $count=count($slave_ips)-1; $random_key=mt_rand(0,$count); return $slave_ips[$random_key]; } /** * 獲取結(jié)果 * @return int */ public function get_res(){ return $this->res; } } $sql1 = "select * from t1"; $sql2 = "insert into t1 (name) values ('haha')"; $sql3 = "delete from t1 where id=1"; $sql4 = "update t1 set name='Jerry' where id=2"; $db = new Db($sql1); //$db = new Db($sql2); //$db = new Db($sql3); //$db = new Db($sql4); var_dump($db->get_res());
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
PHP手機(jī)號(hào)中間四位用星號(hào)*代替顯示的實(shí)例
本篇文章主要介紹了PHP手機(jī)號(hào)中間四位用星號(hào)*代替顯示的實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06php檢查函數(shù)必傳參數(shù)是否存在的實(shí)例詳解
這篇文章主要介紹了php檢查函數(shù)必傳參數(shù)是否存在的實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-08-08php 處理png圖片白色背景色改為透明色的實(shí)例代碼
這篇文章主要介紹了php 處理png圖片白色背景色改為透明色的實(shí)例代碼,文中通過(guò)實(shí)例代碼給大家介紹了用PHP的GD庫(kù)把圖片的背景替換成透明背景,需要的朋友參考下2018-12-12PHP獲取input輸入框中的值去數(shù)據(jù)庫(kù)比較顯示出來(lái)
這篇文章主要介紹了PHP獲取input輸入框中的值去數(shù)據(jù)庫(kù)比較顯示出來(lái)的相關(guān)資料,前端還算比較簡(jiǎn)單,php后臺(tái)接受并查詢(xún),本文給大家介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11Linux下手動(dòng)編譯安裝PHP擴(kuò)展的例子分享
這篇文章主要介紹了Linux下手動(dòng)編譯安裝PHP擴(kuò)展的例子分享,本文以PDO_MYSQL為例,講解手動(dòng)編譯安裝PHP擴(kuò)展的方法,需要的朋友可以參考下2014-07-07CodeIgniter配置之SESSION用法實(shí)例分析
這篇文章主要介紹了CodeIgniter配置之SESSION用法,結(jié)合實(shí)例形式分析了PHP中session的運(yùn)行原理并演示了CI框架下session的配置與使用方法,需要的朋友可以參考下2016-01-01php使用array_chunk函數(shù)將一個(gè)數(shù)組分割成多個(gè)數(shù)組
這篇文章主要介紹了php使用array_chunk函數(shù)將一個(gè)數(shù)組分割成多個(gè)數(shù)組,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-12-12