国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - 使用PHP實現Mysql讀寫分離

使用PHP實現Mysql讀寫分離

2020-05-04 14:52PHP教程網 PHP教程

本篇文章是對使用PHP實現Mysql讀寫分離的方法進行了詳細的分析介紹,需要的朋友參考下

本代碼是從uchome的代碼修改的,是因為要解決uchome的效率而處理的。這個思維其實很久就有了,只是一直沒有去做,相信也有人有同樣的想法,如果有類似的,那真的希望提出相關的建議。

封裝的方式比較簡單,增加了只讀數據庫連接的接口擴展,不使用只讀數據庫也不影響原代碼使用。有待以后不斷完善。。
為了方便,試試建立了google的一個項目:
http://code.google.com/p/mysql-rw-php/
希望給有需要的朋友帶來幫助。

PHP實現的Mysql讀寫分離
主要特性:
1.簡單的讀寫分離
2.一個主數據庫,可以添加更多的只讀數據庫
3.讀寫分離但不用擔心某些特性不支持
4.缺點:同時連接兩個數據庫

英文比較爛,也寫幾個字吧
php code for mysql read/write split
feature:
simply rw split
one master,can add more slaves
support all mysql feature
link to the master and slave at the same time
PHP代碼:
mysql_rw_php.class.php

復制代碼 代碼如下:

<?php
/****************************************
*** mysql-rw-php version 0.1
*** code by hqlulu#gmail.com
*** http://www.aslibra.com
*** http://code.google.com/p/mysql-rw-php/
*** code modify from class_mysql.php (uchome)
****************************************/
class mysql_rw_php {
  //查詢個數
  var $querynum = 0;
  //當前操作的數據庫連接
  var $link = null;
  //字符集
  var $charset;
  //當前數據庫
  var $cur_db = '';
  //是否存在有效的只讀數據庫連接
  var $ro_exist = false;
  //只讀數據庫連接
  var $link_ro = null;
  //讀寫數據庫連接
  var $link_rw = null;
  function mysql_rw_php(){
  }
  function connect($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0, $halt = TRUE) {
    if($pconnect) {
      if(!$this->link = @mysql_pconnect($dbhost, $dbuser, $dbpw)) {
        $halt && $this->halt('Can not connect to MySQL server');
      }
    } else {
      if(!$this->link = @mysql_connect($dbhost, $dbuser, $dbpw)) {
        $halt && $this->halt('Can not connect to MySQL server');
      }
    }

    //只讀連接失敗
    if(!$this->link && !$halt) return false;

    //未初始化rw時,第一個連接作為rw
    if($this->link_rw == null)
      $this->link_rw = $this->link;
    if($this->version() > '4.1') {
      if($this->charset) {
        @mysql_query("SET character_set_connection=$this->charset, character_set_results=$this->charset, character_set_client=binary", $this->link);
      }
      if($this->version() > '5.0.1') {
        @mysql_query("SET sql_mode=''", $this->link);
      }
    }
    if($dbname) {
      $this->select_db($dbname);
    }
  }
  //連接一個只讀的mysql數據庫
  function connect_ro($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0){
    if($this->link_rw == null)
      $this->link_rw = $this->link;
    $this->link = null;
    //不產生halt錯誤
    $this->connect($dbhost, $dbuser, $dbpw, $dbname, $pconnect, false);
    if($this->link){
      //連接成功
      //echo "link ro sussess!<br>";
      $this->ro_exist = true;
      $this->link_ro = $this->link;
      if($this->cur_db){
        //如果已經選擇過數據庫則需要操作一次
        @mysql_select_db($this->cur_db, $this->link_ro);
      }
    }else{
      //連接失敗
      //echo "link ro failed!<br>";
      $this->link = &$this->link_rw;
    }
  }
  //設置一系列只讀數據庫并且連接其中一個
  function set_ro_list($ro_list){
    if(is_array($ro_list)){
      //隨機選擇其中一個
      $link_ro = $ro_list[array_rand($ro_list)];
      $this->connect_ro($link_ro['dbhost'], $link_ro['dbuser'], $link_ro['dbpw']);
    }
  }
  function select_db($dbname) {
    //同時操作兩個數據庫連接
    $this->cur_db = $dbname;
    if($this->ro_exist){
      @mysql_select_db($dbname, $this->link_ro);
    }
    return @mysql_select_db($dbname, $this->link_rw);
  }
  function fetch_array($query, $result_type = MYSQL_ASSOC) {
    return mysql_fetch_array($query, $result_type);
  }
  function fetch_one_array($sql, $type = '') {
    $qr = $this->query($sql, $type);
    return $this->fetch_array($qr);
  }
  function query($sql, $type = '') {
    $this->link = &$this->link_rw;
    //判斷是否select語句
    if($this->ro_exist && preg_match ("/^(\s*)select/i", $sql)){
      $this->link = &$this->link_ro;
    }
    $func = $type == 'UNBUFFERED' && @function_exists('mysql_unbuffered_query') ?
      'mysql_unbuffered_query' : 'mysql_query';
    if(!($query = $func($sql, $this->link)) && $type != 'SILENT') {
      $this->halt('MySQL Query Error', $sql);
    }
    $this->querynum++;
    return $query;
  }
  function affected_rows() {
    return mysql_affected_rows($this->link);
  }
  function error() {
    return (($this->link) ? mysql_error($this->link) : mysql_error());
  }
  function errno() {
    return intval(($this->link) ? mysql_errno($this->link) : mysql_errno());
  }
  function result($query, $row) {
    $query = @mysql_result($query, $row);
    return $query;
  }
  function num_rows($query) {
    $query = mysql_num_rows($query);
    return $query;
  }
  function num_fields($query) {
    return mysql_num_fields($query);
  }
  function free_result($query) {
    return mysql_free_result($query);
  }
  function insert_id() {
    return ($id = mysql_insert_id($this->link)) >= 0 ? $id : $this->result($this->query("SELECT last_insert_id()"), 0);
  }
  function fetch_row($query) {
    $query = mysql_fetch_row($query);
    return $query;
  }
  function fetch_fields($query) {
    return mysql_fetch_field($query);
  }
  function version() {
    return mysql_get_server_info($this->link);
  }
  function close() {
    return mysql_close($this->link);
  }
  function halt($message = '', $sql = '') {
    $dberror = $this->error();
    $dberrno = $this->errno();
    echo "<div style=\"position:absolute;font-size:11px;font-family:verdana,arial;background:#EBEBEB;padding:0.5em;\">
        <b>MySQL Error</b><br>
        <b>Message</b>: $message<br>
        <b>SQL</b>: $sql<br>
        <b>Error</b>: $dberror<br>
        <b>Errno.</b>: $dberrno<br>
        </div>";
    exit();
  }
}
?>

 

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 亚洲中午字幕 | 亚洲视频一区在线观看 | 国产精品久久久久久久久久久久久 | 国产一区二区三区免费 | 国产综合精品一区二区三区 | 久久com | 久久精品91 | 欧美激情在线精品一区二区三区 | 日韩中文字幕av在线 | 青青草成人在线 | 羞羞羞羞 | 日韩av一区二区在线观看 | www.国产精 | 久久综合久久久 | 视频一区二区三区免费观看 | 国产精品成人免费视频 | 色播一区二区 | 九九亚洲精品 | 久久成人18免费网站 | 91在线资源 | 欧美日韩免费 | 国产日本韩国在线 | 国产精品黄色 | 午夜在线小视频 | 成人免费在线观看视频 | 成人午夜电影在线观看 | 久久久久无码国产精品一区 | 99精品一区 | 亚洲第一福利视频 | 日韩精品一二三区 | 91国内精品久久 | 影音先锋男人网 | 午夜av影院 | 欧美视频在线免费 | 中文字幕av亚洲精品一部二部 | 国产精品日产欧美久久久久 | 国内自拍第一页 | 黄色毛片一级 | 久久久久99精品国产片 | 日韩视频精品在线 | 亚洲精品专区 |