PHP+MYSQL實(shí)現(xiàn)讀寫分離簡(jiǎn)單實(shí)戰(zhàn)
1、Introduction
之前寫過2篇文章,分別是:
基于此,我們?cè)賹?shí)現(xiàn)簡(jiǎn)單的PHP+Mysql讀寫分離,從而提高數(shù)據(jù)庫的負(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從庫返回sql查詢結(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主庫返回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獲取數(shù)組長(zhǎng)度的方法(有實(shí)例)
php獲取數(shù)組長(zhǎng)度的方法,php為我們提供了兩個(gè)函數(shù)可以計(jì)算一維數(shù)組長(zhǎng)度,如count,sizeof都可以直接統(tǒng)計(jì)數(shù)組長(zhǎng)度,還有獲取二維數(shù)組的方法。2013-10-10
基于Laravel實(shí)現(xiàn)的用戶動(dòng)態(tài)模塊開發(fā)
這篇文章主要給大家介紹了關(guān)于基于Laravel實(shí)現(xiàn)的用戶動(dòng)態(tài)模塊開發(fā)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09
phpMyAdmin自動(dòng)登錄和取消自動(dòng)登錄的配置方法
這篇文章主要介紹了phpMyAdmin自動(dòng)登錄和取消自動(dòng)登錄的配置方法,需要的朋友可以參考下2014-05-05
laravel5.1框架基礎(chǔ)之Blade模板繼承簡(jiǎn)單使用方法分析
這篇文章主要介紹了laravel5.1框架基礎(chǔ)之Blade模板繼承簡(jiǎn)單使用方法,結(jié)合實(shí)例形式分析了laravel5.1框架模板繼承原理、實(shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-09-09
php調(diào)用dll的實(shí)例操作動(dòng)畫與代碼分享
這是我錄制的一個(gè)gif操作動(dòng)畫,圖片比較大,如果大家在線看圖感覺不流暢的話可以把圖片保存到本機(jī)再看2012-08-08
Thinkphp5+PHPExcel實(shí)現(xiàn)批量上傳表格數(shù)據(jù)功能
這篇文章主要介紹了Thinkphp5+PHPExcel實(shí)現(xiàn)批量上傳表格數(shù)據(jù)功能,需要的朋友可以參考下2017-11-11

