PHP+MYSQL 读写分离简单实战
时间:2017-11-23 12:33:03|栏目:PHP|点击: 次
1、Introduction
之前写过2篇文章,分别是:
Mysql主从同步的原理
Myql主从同步实战
基于此,我们再实现简单的PHP+Mysql读写分离,从而提高数据库的负载能力。
2、代码实战
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());
栏 目:PHP
本文标题:PHP+MYSQL 读写分离简单实战
本文地址:http://www.ziyuanwuyou.com/html/chengxusheji/PHPjiaocheng/162.html
您可能感兴趣的文章
- 12-18PHP的魅力:解锁Web开发的无限可能
- 12-18深入了解PHP:Web开发的必备技能
- 12-18PHP在动态网站设计中的实战应用
- 12-18PHP:构建高效Web服务的秘密武器
- 12-18PHP在网站开发中的关键作用及最佳实践
- 12-18探索PHP的无限可能:在Web开发中的实际应用场景
- 12-18PHP在网站开发中的重要性及其优势分析
- 12-18从基础到进阶:PHP在Web开发中的全方位解析
- 12-18PHP助力开发者实现创意无限
- 12-18PHP实战:轻松搭建强大的Web应用程序
阅读排行
推荐教程
- 12-18探索PHP的无限可能:在Web开发中的实际应用场景
- 12-18PHP在网站开发中的关键作用及最佳实践
- 12-18PHP开发新手必学:构建网站的核心技巧
- 12-18优化你的PHP开发体验:工具配置全攻略
- 12-18PHP在网站开发中的实际应用案例解析
- 12-18PHP开发进阶教程:打造高效能网站
- 12-18深入了解PHP:Web开发的必备技能
- 12-18PHP开发详解:数据库与网站的完美结合
- 12-18PHP开发工具配置详解:提升开发效率的关键
- 12-18PHP开发者必备技能:高效错误处理和异常处理实战指南
重要申明:本站所有的资源文章、图片、评论等,均由网友发表或上传并维护或收集自网络,本站不保留版权,如侵权,请联系站长删除!与本站立场无关,所有资源仅作学习参考,不能作其它用途。
如果侵犯了您的权利,请与我们联系,我们将在24小时内进行删除,本站均不负任何责任。
联系QQ:592269187 | 邮箱:592269187@qq.com
Copyright © 2024-2060 资源无忧教程网 版权所有湘ICP备2022014703号