zsyzhou 发表于 2017-3-20 09:43:49

php之Memcache

  Memcache主要是一款C/S系统管理软件,主要是通过数据缓存减轻数据库访问的压力
  一开始的Apache中是不支持memcache扩展的,要自己手动安装,下载memcache并解压


  (自己下载的版本有点多了)注意的是下载的版本要对应自己PHP的版本
  解压将目录下的php_memcache.dll文件拷贝到AppServ目录下新建mem文件夹(文件夹自取)


  



  修改php.ini文件配置:增加extension=php_memcache.dll配置


  

  测试
  输入网址:http://localhost/phpinfo.php
  查看是否有memcache扩展项


  

  memcache的ip为本机默认ip,默认端口为112211
  打开memcache服务指令为:memcached.exe -d install (指向拷贝的目标文件夹)
  启动服务指令:memcached.exe -d start
  

  

  使用Telnet作为memcached的客户端管理
  连接telnet指令:telnet localhost 11211
  查看状态的指令:stats


  



  

  memcached在php中的使用
  一、基本的memcached数据增加和修改等操作(未连接数据库)

<?php
$mem=new Memcache;
$mem->connect('localhost',11211);
//添加数据
//$mem->add("mystr","this is a memcache test", MEMCACHE_COMPRESSED, 3600);   //保存一个小时
//更改数据
$mem->set("mystr","wwwwwwwwwwww", MEMCACHE_COMPRESSED, 3600);
$mem->delete("mystr");//删除数据
$mem->flush();//删除所有数据
$str=$mem->get("mystr");
echo "String:".$str."<br>";
//存数组
$mem->add("myarr", array("aaa", "bbb", "ccc", "ddd"));
print_r($mem->get("myarr"));
echo '<br>';
//存对象
class Person{
var $name="kefeng";
var $age=22;
}
$mem->add("myob", new Person);
var_dump($mem->get("myob"));
echo '<br>';
echo $mem->getVersion();   //memcache版本
//得到状态
echo '<pre>';
print_r($mem->getStats());
echo '</pre>';
$mem->close();


  二、memcache缓存数据,如果没有缓存数据就从mysql中获取

<?php
$mem=new Memcache;
$mem->connect('localhost',11211);

/*
* 注意
* 1 如果同一个项目安装两次,key要有前缀
* 2 使用SQL语句作为下标,使用md5($sql)
*/
//从memcache中读取数据
$sql="select * from shops";
$key=md5($sql);
$data=$mem->get($key);
//如果没有才从数据库中读取
if(!$data){
$mysqli=new mysqli("localhost","root","xxxxx","sqldb");
$result=$mysqli->query($sql);
$data=array();
while($row=$result->fetch_assoc()){
$data[]=$row;
}
$result->free();
$mysqli->close();
$mem->set($key,$data,MEMCACHE_COMPRESSED,1800); //将数据库中获得的数据存入memcache中,建立缓存
echo $sql;
}
echo '<pre>';
print_r($data);
echo '</pre>';
$mem->close();


  

  

  

  

  

  

  

  

  

  

  

  

  

  


版权声明:本文为博主原创文章,未经博主允许不得转载。
页: [1]
查看完整版本: php之Memcache