脚本宝典收集整理的这篇文章主要介绍了PHP+MYSQL实现读写分离简单实战,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
1、Introduction
之前写过2篇文章,分别是:
基于此,我们再实现简单的PHP+MysqL读写分离,从而提高数据库的负载能力。
PHP;">
slave_select($sql);
$this->res=$res;
}
//如果不是select,就连接master服务器
else
{
$res=$this->master_change($sql);
$this->res=$res;
}
}
/**
- slave从库返回SQL查询结果
- @param $sql
- @return array
*/
PRivate function slave_select($sql){
//该处只是随机获取slave节点的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执行结果
- @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,$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];
}
/**
- 获取结果
- @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+MYSQL实现读写分离简单实战全部内容,希望文章能够帮你解决PHP+MYSQL实现读写分离简单实战所遇到的问题。
如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。