PHP+MYSQL 读写分离简单实战
1、Introduction
之前写过2篇文章,分别是:
基于此,我们再实现简单的PHP+Mysql读写分离,从而提高数据库的负载能力。
2、代码实战
<?php class Db { private $res; function __construct($sql) { $querystr = strtolower(trim(substr($sql,0,6))); //如果是select,就连接slave服务器 if($querystr == 'select') { $res=$this->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://segmentfault.com/a/1190000008664288
(资源库 www.zyku.net)
您可能感兴趣的文章
- 02-18mongoDB 实现主从读写分离实现的实例代码
- 07-08帝国CMS7.0支持多MYSQL服务器读写分离,使网站更稳定
- 04-15小米11ultra电池温度查看方法
- 01-11小筑教育-小筑教育应用软件功能介绍
- 06-012021年腾讯云618年中大促活动特惠套餐
- 11-26华为p50pro怎么给快捷功能排序
- 09-18荣耀magic3如何设置勿扰模式
- 10-21小天才d2怎么更换壁纸
- 03-31红米k40游戏加速开启方法
- 01-27ios14关闭睡眠闹钟方法
- 09-20opporeno6本地文件同步步骤介绍
- 02-19小米11青春版微信视频开启美颜教程
- 12-06opporeno6红包提醒在哪里开启
- 11-25oppo手机取消Breeno语音服务方法介绍
- 10-09京东plus会员自动续费怎么关
- 02-01vivox60自定义手机铃音方法
- 11-22apache 将不带www的域名定向到带www的
- 01-11简单天气日历-简单天气日历应用软件功
- 07-05Linux mkisofs命令
- 02-28帝国CMS使用灵动标签调用Discuz帖子的
最近更新
阅读排行
猜你喜欢
- 09-19美团添加店铺位置教程分享
- 01-23华为手机相机怎么开启延时摄影
- 09-13小米手机如何取消长按识别
- 10-01抖音左右镜像视频怎么拍
- 02-25华为手机休眠时间设置方法
- 07-05MySQL查询结果也按照in里面的字段值顺
- 01-11指纹相册-指纹相册应用软件功能介绍
- 06-25网易云
- 11-10支付宝二十四节气壁纸在哪里领
- 01-11杰达拖车-杰达拖车应用软件功能介绍