/*


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;


}


}


}


?>

php memcached+Mysql(主从)的更多相关文章

  1. memcached+Mysql(主从)

    昨天和守住看了下http://hi.baidu.com/156544632/blog/item/3b26527b68623ff00bd18746.html这篇文章,思路很好,但感觉就是太乱了,而且还出 ...

  2. LVS+Keepalived+Squid+Nginx+MySQL主从高性能集群架构部署方案

    方案一,在tomcat的workers.properties里面配置相关条件 worker.tomcat.lbfactor= worker.tomcat.cachesize= worker.tomca ...

  3. Mysql主从配置,实现读写分离

    大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...

  4. mysql主从数据库

    Mysql主从配置,实现读写分离 大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库 ...

  5. mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理

    转自:http://www.cnblogs.com/kevingrace/p/6261091.html 在mysql工作中接触最多的就是mysql replication mysql在复制方面还是会有 ...

  6. 黄聪:Mysql主从配置,实现读写分离

    大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...

  7. mysql主从配置,读写分离

    Mysql主从配置,实现读写分离 大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库 ...

  8. 配置mysql主从数据库

    来源地址:https://www.cnblogs.com/alvin_xp/p/4162249.html Mysql主从配置,实现读写分离 大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡 ...

  9. Mysql主从分离介绍及实现

    参考: http://www.cnblogs.com/panxuejun/p/5887118.html https://www.cnblogs.com/alvin_xp/p/4162249.html ...

随机推荐

  1. Windows系统服务的编写。

    实验资源下载地址:点击打开链接 只是不知道能不能从服务向桌面进程传递消息,,就像两个桌面进程之间用Sendmessage似的..希望有知道的大神可以指点一下..不胜感激.. 因为微软在Vista之后, ...

  2. loadrunner监控度量项及中文解释

    1. Number of Concurrent Users (NCU) 并发用户数 – 在指定时刻,系统观察到的并发用户连接数. 2. Request Per Second (RPS) 每秒处理请求数 ...

  3. C#验证IP地址

    using System.Net; try { IPAddress a = IPAddress.Parse(输入的IP字符串); } catch (System.Exception ex) { Mes ...

  4. SQL点滴18—SqlServer中的merge操作,相当地风骚

    原文:SQL点滴18-SqlServer中的merge操作,相当地风骚 今天在一个存储过程中看见了merge这个关键字,第一个想法是,这个是配置管理中的概念吗,把相邻两次的更改合并到一起.后来在tec ...

  5. PO Box简介

    使用Erlang写程序的时候,经常会碰到一种情况:因为Erlang进程的mailbox是没有大小限制的,所以它会一直接受消息,直到Erlang节点内存溢出.在大多数情况下,我们可以通过限制消息生产者的 ...

  6. CF - 96D - Volleyball

    题意:一个无向图,有n个点,m条边,每条边有距离w,每个点有两个属性(1.从这点出发能到的最远距离,2.从这点出发的费用(不论走多远都一样)),一个人要从点x到点y,问最小费用是多少. 题目链接:ht ...

  7. LeetCode之Maximum Product Subarray

    1.(原文)问题描述 Find the contiguous subarray within an array (containing at least one number) which has t ...

  8. 解决水晶报表提示“未知的查询引擎错误” FOR VS2010

    原文:解决水晶报表提示“未知的查询引擎错误” FOR VS2010 在VS2010环境下运行水晶报表(当然要先装上Crystal Report For VS2010), 在SetDataSource方 ...

  9. HTML 5 在Web SQL 使用演示样本

    Web sql 这是一个模拟数据库浏览器.可以使用JS操作SQL完成数据读取和写入,但是这件事情并不多,现在支持的浏览器,而其W3C规格已经停止支持.外形似它的前景不是很亮. W3C 规范:http: ...

  10. ASP.NET页面生命周期和asp.net应用程序生命周期

    作为一个asp.net程序员,不了解ASP.NET页面生命周期和asp.net应用程序生命周期是绝对不行的,那永远只能是菜鸟级别.我很早就学过,可是没次还是得去翻,一些事件还是记不住,还是记在自己的b ...