资讯专栏INFORMATION COLUMN

PHP+MYSQL 读写分离简单实战

junnplus / 2112人阅读

摘要:之前写过篇文章,分别是主从同步的原理主从同步实战基于此,我们再实现简单的读写分离,从而提高数据库的负载能力。

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

相关文章

  • PHP+MYSQL 读写分离简单实战

    摘要:之前写过篇文章,分别是主从同步的原理主从同步实战基于此,我们再实现简单的读写分离,从而提高数据库的负载能力。 1、Introduction 之前写过2篇文章,分别是: Mysql主从同步的原理Myql主从同步实战 基于此,我们再实现简单的PHP+Mysql读写分离,从而提高数据库的负载能力。 2、代码实战

    RdouTyping 评论0 收藏0
  • 云原生数据库如何打造业务弹性

    摘要:实战阿里云数据库为业务架构变迁做好准备目前,阿里云的数据库形态已经覆盖了互联网中的业务场景。演进路线阿里云上提供了这么多的数据库产品,在实际应用中该如何进行选择呢我们已经为业务的快速发展和更新迭代做好了准备。 摘要: 云计算带来了业务弹性上的极大优势,阿里云数据库高级产品专家时慢从应用架构的变迁,客户实战案例,业务分析等方面详细介绍POLARDB,及如何利用POLARDB设计互联网创新...

    fou7 评论0 收藏0
  • mysql主从读写分离实战

    摘要:环境主从配置配置服务器,从库最好大于主库注意要唯一开启模式强制一致性,开启后对特定的不被支持开启二进制日志默认为混合模式,更改成复制,为了数据一致性从库才会记录主库同步的操作日志跳过复制线程配置设置,注意要唯一从库设置为只 环境 mysql-5.7.19 Centos7 master: 192.168.111.64 slave: 192.168.111.66 主从配置 master...

    kelvinlee 评论0 收藏0
  • mysql主从读写分离实战

    摘要:环境主从配置配置服务器,从库最好大于主库注意要唯一开启模式强制一致性,开启后对特定的不被支持开启二进制日志默认为混合模式,更改成复制,为了数据一致性从库才会记录主库同步的操作日志跳过复制线程配置设置,注意要唯一从库设置为只 环境 mysql-5.7.19 Centos7 master: 192.168.111.64 slave: 192.168.111.66 主从配置 master...

    The question 评论0 收藏0
  • mysql主从读写分离实战

    摘要:环境主从配置配置服务器,从库最好大于主库注意要唯一开启模式强制一致性,开启后对特定的不被支持开启二进制日志默认为混合模式,更改成复制,为了数据一致性从库才会记录主库同步的操作日志跳过复制线程配置设置,注意要唯一从库设置为只 环境 mysql-5.7.19 Centos7 master: 192.168.111.64 slave: 192.168.111.66 主从配置 master...

    ephererid 评论0 收藏0

发表评论

0条评论

junnplus

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<