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

5年以前  |  阅读数:483 次  |  编程语言:PHP 

1、Introduction

之前写过2篇文章,分别是:

Mysql主从同步的原理

Myql主从同步实战

基于此,我们再实现简单的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());

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例