摘要:之前写过篇文章,分别是主从同步的原理主从同步实战基于此,我们再实现简单的读写分离,从而提高数据库的负载能力。
1、Introduction
之前写过2篇文章,分别是:
Mysql主从同步的原理
Myql主从同步实战
基于此,我们再实现简单的PHP+Mysql读写分离,从而提高数据库的负载能力。
2、代码实战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, $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]; } /** * 获取结果 * @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());
更多精彩,请关注公众号“聊聊代码”,让我们一起聊聊“左手代码右手诗”的事儿。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/22518.html
阅读 2217·2023-04-26 01:50
阅读 689·2021-09-22 15:20
阅读 2509·2019-08-30 15:53
阅读 1543·2019-08-30 12:49
阅读 1667·2019-08-26 14:05
阅读 2670·2019-08-26 11:42
阅读 2268·2019-08-26 10:40
阅读 2559·2019-08-26 10:38