memcached安装+php使用手记

转载 2007年10月07日 02:15:00
原贴:http://www.cublog.cn/u/3052/showart_346566.html

memcached安装+php使用手记
 
 
memcached安装+php使用手记
本文简要介绍一下安装的情况,以及PHP模块memcache使用情况:
提要:
1。安装memcached服务器端
2。安装phpmemcache支持模块
3。使用memcache情况,计数器、数据压缩
4。Memcache内存的更新清理(delete flush)
5。内存超量的测试(set)
1。安装memcached服务器端
memcached
安装说明(北南南北的站)
http://www.linuxsir.org/main/?q=node/184 
注意的是:如果你安装过程中出现错误,请看看是不是有模块没装:
autoconf
zlib (
压缩数据用)

2。安装phpmemcache支持模块
PHP
老家:
http://cn.php.net/manual/zh/ref.memcache.php
(PHP 4.3.3 or newer is required to use the memcache extension.
难道,4.3.3都装上了吗?好像没有吧,用4.4.4好像都要另外装的)

3。使用memcache情况,计数器、数据压缩
 
使用情况一:统计
<?php
//访问统计
$memcache = new Memcache;
$memcache->connect(’localhost’, 11211) or die ("Could not connect");
if($s=$memcache->get(’a’)) {
    
$s=$s+1;
    
$memcache->set(’a’,$s);
}
else
$memcache->set(’a’,1);
echo ’访问结果为:’.$s;
?>
其实我们可以用increment方法代替上面的做法
<?php
$memcache = new Memcache;
$memcache->connect(’localhost’, 11211) or die ("Could not connect");

if($s=$memcache->increment(’a’,1)) {
    
echo $s;    
}
else
$memcache->set(’a’,1);
?>
 
数据压缩 
<?php
$memcache = new Memcache;
$memcache->connect(’localhost’, 11211) or die ("Could not connect");
$test=(str_repeat(’jetwong’,100000));
$memcache->set(’b’,($test));
?>
使用压缩:
<?php
$memcache = new Memcache;
$memcache->connect(’localhost’, 11211) or die ("Could not connect");
$test=(str_repeat(’jetwong’,100000));
$memcache->set(’b’,($test),MEMCACHE_COMPRESSED);
?>

使用情况说明:
前台比较
目前内存
bytes
总共读取
bytes_read
总共写入
bytes_written
压缩前
700085
700081
416
压缩后
1131
1125
13
可能看到压缩后明显占用内存少了不少
 
4。Memcache内存的更新清理(delete flush)
<?php
$memcache = new Memcache;
$memcache->connect(’localhost’, 11211) or die ("Could not connect");

/*设置值*/
$status = $memcache->getStats();
echo ’设置前内存使用情况’.$status[’bytes’].’<br>’;
echo ’设置后’;
for($i=0;$i<9;$i++) {
    
$memcache->set(’b’.$i,rand(1,99));    
    
echo ’<br>’.$i.’->’.$memcache->get(’b’.$i);       
}

/*查看设置的值*/
$status = $memcache->getStats();
echo ’delete前内存使用情况’.$status[’bytes’].’<br>’;
echo ’<br>开始delete’;
for($i=0;$i<9;$i++) {
    
$memcache->delete(’b’.$i);    
    
echo ’<br>’.$i.’->’.$memcache->get(’b’.$i);
}

/*查看flush使用的情况*/
$status = $memcache->getStats();
echo ’使用flush前内存使用情况’.$status[’bytes’].’<br>’;
echo ’使用flush情况:’;
for($i=0;$i<9;$i++) {
    
$memcache->set(’b’.$i,rand(1,99));    
    
echo ’<br>’.$i.’->’.$memcache->get(’b’.$i);  
}
$memcache->flush();
echo ’flush之后:’;
for($i=0;$i<9;$i++) {        
    
echo ’<br>’.$i.’->’.$memcache->get(’b’.$i);
}
$status = $memcache->getStats();
echo ’flush后内存使用情况’.$status[’bytes’].’<br>’;
?>
 
 
5。内存超量的测试(set)
 我们把内存设为2M
./memcached -d -m 2 -p 11211 -u root
 
<?php
$memcache = new Memcache;
$memcache->connect(’localhost’, 11211) or die ("Could not connect");

//600K左右
$test1str_repeat(’jetlee’,100000);
//600K左右
$test2str_repeat(’jetlee’,100000);
//600K左右
$test3str_repeat(’李连杰’,200000);
//600K左右
$test4str_repeat(’连杰李’,100000);
//200K
$test5file_get_contents(’http://img.pconline.com.cn/images/photoblog/2988177/20068/4/1154688770042_mthumb.JPG’);
$test6file_get_contents(’http://img.pconline.com.cn/images/photoblog/1767557/20069/28/1159417108902_mthumb.jpg’);

for($i=1;$i<=6;$i++) {
    
$j=’test’.$i;
    
if($memcache->set($j,$$j)) {
        
echo $j.’->设置成功<br>’;
        
$status = $memcache->getStats();
        
echo ’内存:’.$status[’bytes’].’<br>’;
    }
    
else {
        
echo $j.’->设置失败<br>’;
    }
}
?>
执行结果:
test1->设置成功
内存:600042
test2->设置成功
内存:1200084
test3->设置失败
test4->设置成功
内存:1200084
test5->设置失败
test6->设置失败
 
刚好印证我们的计算,不过20万的repeat为什么会失败,不是太了解,,,,,,
 
总结:
示例:
<?
//设置篇
if($data = $memcache->get(’k’,$v)) {
    
//显示我们的数据
    }
else {
    
$data = get_from_database; //得到数据源
    if(!$memcache->set(’k’,$data), MEMCACHE_COMPRESSED) //开始设置
    log();    //不成功,记录失败信息    
}
?>
-----------OVER-----------

 原文地址 http://ju.qihoo.com/topframe/dingzhen.php?ju=1578152&ml=1578370&u=8a052e5402f8c9d9d3ea5ba45ca77db0&r
 

相关文章推荐

boost类库安装使用手记

  • 2015-01-05 14:46
  • 72KB
  • 下载

twiki安装使用手记

先从网上down下twiki的5.02版,开始配置。 准备工作: ========== 1. Ubuntu已经安装了开发环境,包括make, cc, gcc等 2. Ubuntu已经安...
  • wfing
  • wfing
  • 2011-11-07 18:53
  • 1609

AspxGridView使用手记

  • 2013-09-18 08:28
  • 98KB
  • 下载

sqlmap使用手记

  • 2012-03-01 16:13
  • 136KB
  • 下载

Python multiprocessing库使用手记(引子)

前段时间在做的一个Python项目,需要实现一个后台服务程序,程序流程比较复杂,而且可能经常变动,但是如果把整个流程切分成一些步骤,每个步骤有自己的输入输出和处理。只要将他们的输入输出接在一起,进行不...

AspxGridView使用手记

  • 2013-01-21 21:52
  • 1.13MB
  • 下载

hadoop Capacity Scheduler使用手记

由于集群资源有限,为了保证重要任务能够分配到足够的槽位,决定将hadoop的HIHO调度器换成Capacity Scheduler (Fair Scheduler无法实现最大槽位占有限制)。    ...

AspxGridView使用手记

  • 2013-08-23 15:59
  • 1.13MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)