《PHP實例:PHP+MYSQL實現(xiàn)讀寫分離簡單實戰(zhàn)》要點:
本文介紹了PHP實例:PHP+MYSQL實現(xiàn)讀寫分離簡單實戰(zhàn),希望對您有用。如果有疑問,可以聯(lián)系我們。
PHP實戰(zhàn)1、Introduction
PHP實戰(zhàn)之前寫過2篇文章,分別是:
PHP實戰(zhàn)Mysql主從同步的原理?
PHP實戰(zhàn)Myql主從同步實戰(zhàn)?
PHP實戰(zhàn)基于此,我們再實現(xiàn)簡單的PHP+Mysql讀寫分離,從而提高數(shù)據(jù)庫的負載能力.
PHP實戰(zhàn)2、代碼實戰(zhàn)
PHP實戰(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從庫返回sql查詢結(jié)果
* @param $sql
* @return array
*/
private function slave_select($sql){
//該處只是隨機獲取slave節(jié)點的ip,當然,還可以采用其他算法獲取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主庫返回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);
}
/**
* 隨機獲取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());
PHP實戰(zhàn)以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持維易PHP.
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/1483.html