久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP+MYSQL實現讀寫分離簡單實戰

本篇文章主要介紹了PHP+MYSQL實現讀寫分離,實例分析了讀寫分離的技巧,從而提高數據庫的負載能力,具有一定的參考價值,有興趣的可以了解一下。

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());

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡單分析了插值查找算法的概念、原理并結合實例形式分析了php實現針對有序表插值查找的相關操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實現服務端分頁的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP實現APP微信支付的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP實現的多維數組排序算法,結合實例形式對比分析了php針對多維數組及帶有鍵名的多維數組進行排序相關操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要為大家詳細介紹了php結合ajaxuploadfile實現無刷新文件上傳功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細介紹了PHP開發接口使用RSA進行加密解密方法,對此有興趣的朋友可以學習下。
主站蜘蛛池模板: 日本一区二区三区四区 | 亚洲欧美一区二区三区视频 | 黄色一级网 | av一区二区三区四区 | 午夜视频免费在线观看 | 亚洲喷水 | 91电影在线播放 | 国产高清一二三区 | 国产精品18毛片一区二区 | 精品久久香蕉国产线看观看亚洲 | 日韩视频一区二区 | 国产aa| 日韩精品一区二区三区视频播放 | 久久精品国产一区 | 色婷婷久久久久swag精品 | 天堂久久天堂综合色 | 久久婷婷香蕉热狠狠综合 | 91精品国产综合久久香蕉麻豆 | 亚洲视频免费在线观看 | 中文在线视频观看 | 国产一区二区电影 | 亚洲一区二区精品视频 | 国产成人午夜精品影院游乐网 | 一区二区三区四区日韩 | 久久99精品国产 | 久久久久久久国产 | 久久久久久免费毛片精品 | 一级久久久久久 | 日日碰狠狠躁久久躁婷婷 | 日韩一区二区三区精品 | 国产日韩欧美 | 天天干天天爽 | 欧美片网站免费 | 亚洲精品久久久一区二区三区 | 日韩精品在线观看网站 | 成人av资源在线 | 亚洲一区二区三区高清 | 国产精品一区二区不卡 | a爱视频 | 亚洲成人精选 | 日本精品一区 |