PHP+memcached+Mysql(主從)




/*
index.php   程序入口,用來構造sql(如查詢,更新)
config.php  配置參數(memcache,mysql)
init.php    封裝memcached操作(memcache連接,設置,獲取)
mysqli.php  封閉mysql操作(mysql主連接,mysql從連接,mysql主更新,mysql從查詢)
*/

index.php
<?php
require 'init.php';              //加載init.php
$mem = new Memcached;            //建立memcached對象,對象爲$mem
/*
$mem->set('en_xx','bucuo',0,30); //測試連接memcached,用來調試很不錯。
echo($mem->get('en_xx'));
$mem->set('cn_jjyy','wokao',0,30);
echo($mem->get('cn_jjyy'));
*/

require 'mysqli.php';
$sq = new Mysql;    
//下面這兩個sql是人爲構造的,這也可以做成一個接口                
$sql = "Select * from traffic";                   
//$sql = "insert into traffic(id,acct_mth,amount) values(14,14,46)";
//進行判斷,如果sql語句中有頭有select(不區分大小寫)
if(preg_match ("/^select/i", $sql)){
    $mdsql = md5($sql);
    if(!$result=$mem->get('cn_'.$mdsql)){      //這裏選擇的是cn memcached,大家也可以根據需求在前面做個條件來將數據存取放入到另一個memcached中。
           $result = $sq->fetArray($sql); //查詢是 從mysql
           foreach($result as $var){
                echo $var['amount'];
            }
           $mem->set('cn_'.$mdsql,$result,0,600); //添加到 名爲cn的memcached 服務器
    }else{
            foreach($result as $var){
                echo $var['amount']."<br>";
          }
    }
}else{
    $sq->mquery($sql);     //更新是 主mysql
}

?>

config.php
<?php
$memcached = array( 
     'cn'=>array('192.168.x.y',11211),
     'en'=>array('192.168.y.x',11211)
     );
$mysql    = array( 
     'master'=>array('x','root','','test'),
     'slave_1'=>array('y','root','','test'), 
     'slave_2'=>array('z','root','','test') //可以靈活添加多臺從服務器
     );
?>

init.php
<?php
class Memcached
{
private $mem;
public $pflag=''; // memcached pconnect tag
    private function memConnect($serkey){     //建立memcached連接,這些都很容易理解
                require 'config.php';
                $server = $memcached;  //$memcached是cn,en的數組
                $this->mem = new Memcache;  
                $link = !$this->pflag ? 'connect' : 'pconnect' ;
                $this->mem->$link($server[$serkey][0],$server[$serkey][1]) or $this->errordie('memcached connect error');
      }

    public function set($ser_key,$values,$flag='',$expire=''){  //設置獲取數據
               $this->memConnect($this->tag($ser_key));
                if($this->mem->set($ser_key,$values,$flag,$expire)) return true;
                else return false;
      }

    public function get($ser_key){
               $this->memConnect($this->tag($ser_key));
               if($var=$this->mem->get($ser_key)) return $var;
               else return false;
      }
    private function tag($ser_key){
               $tag=explode('_',$ser_key);
               return $tag[0];
      }
    private function errordie($errmsg){
                die($errmsg);
      }
/*  這段函數是我用來在類中做調試用的。
    public function show($messages){
               echo $messages;
    }
*/
}
?>

mysqli.php
<?php
class Mysql
{
/* 這段函數是我用來調試的
public function show($messages){
               var_dump($messages);
    }
*/
private   $mysqlmaster;
private   $myssqlslave;

public function __construct(){   //構造函數
         require 'config.php';
         $msg = $mysql;          //$mysql是master,slave_1,slave_2
         $this->mysqlmaster = new mysqli($msg['master'][0],$msg['master'][1],$msg['master'][2],$msg['master'][3]); //master mysql
         $this->mysqlslave = $this->autotranscat($msg); // slave mysql

         if(mysqli_connect_errno()){
                     printf("Connect failed: %s\n",mysqli_connect_error());
                      exit();
          }
        if(!$this->mysqlmaster->set_charset("latin1") && !$this->mysqlslave->set_charset("latin1")){
                    exit("set charset error");
          }
}
private function autotranscat($mysql){        //這段函數的作用是獲取從服務器序列號,如1,2
        session_start();                      //啓動會話
       $_SESSION['SID']!=0 || $_SESSION['SID']=0;  //如果不爲0,就不做賦值操作(那第一次訪問的話,肯定會做賦值操作的)
        if($_SESSION['SID'] >=count($mysql)-1) $_SESSION['SID'] = 1;  //上面那個動作是爲這個動作準備的
        else $_SESSION['SID']++;
        $key = 'slave_'.$_SESSION['SID'];
        return new mysqli($mysql[$key][0],$mysql[$key][1],$mysql[$key][2],$mysql[$key][3]);
}

public function mquery($sql){ //mysql主 insert update
if(!$this->mysqlmaster->query($sql)){
   return false;
}
}

public function squery($sql){   //mysql從 查詢
if($result=$this->mysqlslave->query($sql)){
   return $result;
}else{
   return false;
};
}
public function fetArray($sql){  //mysql從 查詢 入口
if($result=$this->squery($sql)){
   while($row=$result->fetch_array(MYSQLI_ASSOC)){
    $resultraa[] = $row;
   };
   return $resultraa;
}
}
}
?>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章