memcached---------------------------------个人笔记

********************************************************Memcached缓存技术**************************************************************************


1:基本概念

   最早是danga的一个项目,为Live Journal服务的,做成了一个软件。

   介绍;Memcached是一种缓存技术,它可以将你的数据放入内存,从而通过内存访问提速。因为内存的速度是最快的(cpu的寄存器更快,但价格高昂),Mencached的主要目的就是提速。








2:三种方式访问

   1)直接访问数据库(最慢的方案)

   2)使用真静态(磁盘   学生成绩页面,稍快)

   3)访问内存(Memcached服务维护了一张内存表(hahstable)(key;一般是子串,不能重复   value:可以放入字符串,数值,数组,对象,bool,二进制数据【图片视频】),最快)      

      //第一次我访问数据库,将该学员的成绩直接放入Memcached。


      MYSQL里面也有一张内存表,目前技术停留在希望能够将数据全部放入mysql内存表。







3:安装并使用Mencached

   

   软件:memcached-1.2.6-win32-bin.zip


   安装步骤:

   1)下载memcached软件

   2)安装:将exe文件拷到apache并列的一个文件夹下

      进入到cmd,切换到memcached.exe文件所在目录    cd  所在目录

      mencached.exe  -d  install

      3)启动memcached

      第一种,可以到服务点击启动,就是任务管理器,点击启动

      第二种,命令行启动,mencached.exe  -d  start|stop            

              如果你在win7下启动不成功,则可以使用如下shell方式:memcached.exe  -p  端口号【因为它是shell方式,所以不要关闭控制台了】(不一定是11211,0-65535空闲的端口即可,端口号使用2个字节表示。有名端口:0-1024不要去占用)

              apache  80  

              mysql   3306

              ftp     21

              ssh     22

              oracle  1521

              stmp    25等面试可能会被问到。

              使用netstat  -an如果看到11211端口在监听,说明启动成功

              使用netstat  -anb可以看到各个端口是在监听什么程序,还可以看到有哪些用户连接到我们的服务器

              使用netstat  -a可以看到连到服务器的ip与主机

              使用netstat  -a  192.168.1.100可以知道192.168.1.100对应的主机名

              

        如果没有安装好,原因可能使:

        1)如果你是windows7,win7对安全性要求高,所以必须以adminstartor身份安装。

           你切换成adminstartor,去安装,再启动

        2)你的memcached.exe目录有中文,或者特殊字符,保证路径没有中文与特殊字符即可。

    

      4)准备研究如何对memcached进行curd操作(memcached服务)

         php程序操作(memcache扩展操作,memcached扩展操作,直接使用socket编程来操作)用得最多

         telnet工具


         看看telnet如何操作(curd)

         1)登录到telnet连接到memcached服务

           如在cmd控制台里面:telnet  127.0.0.1   11211

         2)增加

           add  key名  0  存放时间(s)  数据大小(字符)

           add key1  0  30   5

           hello

          3)获取

           get   key值

           get   key1  

          4)修改

           set key名   0   存放时间   数据大小                  如果key名不存在,相当于增加一个新的,如果存在,相当于替换。

           replace key名    存放时间   数据大小                 如果key名不存在,则失败,这个指令要求key名必须存在。

          5)删除

           delete  key名

          6)其它指令

           append    append   key100 0  40 2  gg     将两个字符gg添加到key100中(在后面加)

           preend                                                               (在前面加)

           flush_all 可以统一将数据清空

           stats     统计表,大家可以去计算出命中率cmd_hits/cmd_get越高越好!!!!!







4:如何使用php程序操作我们的mencached服务crud?

   步骤,准备工作: 

   1)将php_mencache.dll拷贝到php的ext下(不同版本的php对应着不同版本的.dll文件)

     【为了让php可以操作,danga公司提供了.dll动态链接库php_mencache.dll(VC编译)】

   2)加载配置,修改php.in文件,加载php_mencache.dll(该文件就是封装了一堆函数)

      搜extension,加入;加载php_mencache.dll文件

                       extension=php_mencache.dll

     3)重启apache

     4)我们写程序来完成crud操作

        men1.php

        <?php

              //创建一个men对象实例

              $men=new Mencache();

              

              if(!$men->connect("127.0.0.1".11211)){

                     die("连接失败");

              }

              //增加

              //1增加一个字符串

              $men->add('key1'."beijing".MEMCACHE_COMPRESSED.60)){

                    echo "添加ok";

              }

              //添加数字

              雷同

              //添加数组

              $arr=array("北京"."添加");

              雷同

              

              //4.添加对象

              class Dog{

                 public $name;

                 public $age;

                 public  function __construct($name.$age){

                     $this->name=$name;

                     $this->age=$age;

                 }

              }

              $dog1=new Dog('小狗'.50);

              if($men->set('key1'.$dog1.MENCACHE_COMPRRESSED.60)){

                   echo '添加ok ':

              }


              //5添加null.bool

              if($men->set('key1'.null.MENCACHE_COMPRRESSED.60)){

                   echo '添加null ok ':

              }

              if($men->set('key1'.false.MENCACHE_COMPRRESSED.60)){

                   echo '添加ok ':

              }


              //资源类型进入

              $con=mysql_connect("127.0.0.1"."root"."root");

              if(!$con){

                 die('连接数据库失败');

              }

              if($men->set('key1'.$con.MENCACHE_COMPRESSED.60)){

                    echo "添加资源Ok";

              }//资源实际上添加失败

              //在添加数组时,根据需要,希望序列化再放入


              serialize($arr)           如果根据需要也可以json_encode($arr)     json_decode反序列化

              //查询

              $val=$men->get('key1');

              echo '<br/>val='.$val;                

          //修改

          $men->replace("key1".'hello'.MENCACHE_COMPRESSED.60)){

               echo "replaca ok";

          }else{

            echo "不ok";

          }

          //删除

          if($men->delete('key1')){

              echo 'key1删除';

          }else{

               echo 'key1不存在';

          }

          //过期时间最大是30天,但可以通过时间戳延长。将过期时间写成time()+31*3600*24即可!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!尤其要注意!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

                                                      将expire设为0表示,永不过期(只要mencache不重启,就永远在mem中)

        ?>



        men2.php

        <?php

            

            class Dog{

              public $name;

              public $age;

              public function __construct($name.$age){

                     $this->name=$name;

                     $this->age=$age;

                }

              }

              //这个文件区操作mencached服务

              //创建一个men对象实例

              $men=new Memcache;

              if(!$men->connect("127.0.0.1".11211)){

                     die("连接失败");

              }

              //在另外的文件中取出对象时,有一个注意的地方,对于php5.2这个版本会提示错误,对5.3这个版本会提示incomplete信息,需要将Dog类黏贴过来。

              $dog=$men->get('key1');

              var_dump($dog);

              

       ?>

       练习:请大家使用php程序Memcache.dll完成对mencache的增删改查。





五:直接用php源代码操作mencached服务

    如果管理员不让我们去加载mencache.dll文件,我们可以直接通过原码操作(上网上找)

    我们先关闭扩展:注销extension:php_memcache.dll

    men3.php

    粘贴拷贝过去

    一般mencached-client.php!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!里面会有一段案例,黏贴到men3.php,稍加修改即可。








6:mencached机制的深入了解


  1)基于c/s架构,协议简单

  2)基于libevent的事件处理

  3)内置内存存储方式,在数据爆满的情况下使用LRU算法删除。

  4)基于客户端分布式的

     写一段代码说明一下

     men4.php

<?php


  //我的电脑上右两个mencached服务:进入路径,再启用一个9999端口。即为两个mencached服务。

  $mem=new Memcache();                     //先在php.ini里面打开扩展,优先使用扩展,次选现成的函数

  $mem->addServer(127.0.0.1'.11211);

  $mem->addServer('127.0.0.1'.9999);

  //这里注意,将key1放入到11211端口的memcache还是9999这个memcache就不需要我们去操心了,由$mem对象本身维护。(哈希,散列算法决定)

  if($mem->add('key1'.'hello'.MEMCACHE_COMPRESSED.200)){

     echo 'add  ok';

  }


  



?>

  如何从多个memcache服务中取出你的key1值

<?php

  $mem=new  Memcache;

  $mem->addServer(127.0.0.1'.11211);

  $mem->addServer('127.0.0.1'.9999);

  

  $val=$mem->get('key1');

  echo '程序中取出分布的值='.$val;


?>


总结:

1:mem服务相互之间数据不是同步的,数据时分布存放的

2:将什么数据放入到那一个memcached是有客户端的mem对象决定的

3:当执行addServer时,并不是立即去连接mem服务,而是通过计算,hash后才去决定连接那一个mem服务,因此当你大量加入服务器到连接池,没有多余的开销。












7:Memcached细节讨论


   1)生命周期

      从数据放入Memcache开始计时,直到时间到了,就销毁,如果时间为0,则表示永不过期。

      mmemcache的数据被销毁的情况如下:

                      1:时间到

                      2:重启memcache服务

                      3:重启memcache服务所在的机器

                      4:delete/flush销毁数据

    2)如何将session数据放入Memcached服务中

       走一段代码

       mem6.php

<?php

  //传统的代码

  session_start();

  $_SESSION['name']='天龙八部';

  $_SESSION['city']='beijing';

  class Dog{

    public  $name;

  }

  $dog1=new Dog;

  $dog1->name='abcde';

  $_SESSION['dog']=$dog1;

  //如果session数据如mem,那么它一定是以session_id为key值进行添加

  //取出

  $name=$_SESSION['name'];

  echo "name=$name";  

  echo "session=".session_id();

?>

  步骤:

  1)修改php.ini文件,搜session

     关于session_save_handler=?        files|user|memcache三种,换成第三种即可。

     关于session.save_path="?"    写成"tcp://127.0.0.1:11211"     

  3:测试一把,重启apache

    测试ok




思考一个问题:

如果管理员不让我们修改php.ini文件,我们如何处理session入memcached这个功能?

我们通过一个函数可以去动态地修改php.ini的配置信息!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!临时在本页面生效,不影响其它php页面,也不会去修改php.ini文件本身。

(将php.ini文件复原)


<?php

  //加入如下代码即可!!!!!!!!!!!!!!!!!!!!!!!!!!

  ini_set("session.save_handler"."memcache");

  ini_set("session.save_path"."tcp://127.0.0.1:9999");




  //传统的代码

  session_start();

  $_SESSION['name']='天龙八部';

  $_SESSION['city']='beijing';

  class Dog{

    public  $name;

  }

  $dog1=new Dog;

  $dog1->name='abcde';

  $_SESSION['dog']=$dog1;

  //如果session数据如mem,那么它一定是以session_id为key值进行添加

  //取出

  $name=$_SESSION['name'];

  echo "name=$name";  

  echo "session=".session_id();

?>



php.ini文件里

safe_mode=off

safe_mode=on的区别在于安全模式给出的权限更小。






memcached与session的比较

memcached主要的目的是提速,因此它是一种无状态的数据,即:数据不与用户绑定。

session数据是与用户绑定的,因此它是一种有状态数据。


memcached安全性

如何使用memcached服务才是安全的?

在windows下,通过启用防火墙保护我们的memcached(放在内网)。

在linux下,也可以启用防火墙,

setup配置防火墙

iptables -a  input  -p tcp  -s  127.0.0.1 -dport 11211 -j  ACCEPT  




适合放入memcached的数据:变化频繁,具有不稳定的数据,不需要实时入库的数据适合放入memcached,还有门户网站的新闻等,觉得页面静态化不能满足。



与memcached相关相似的技术:Redis(key/value数据库)!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!




你可能感兴趣的:(PHP,memcached)