本文实例讲述了php 扩展memcached命令用法。分享给大家供大家参考,具体如下:
传送门:
windows 下没有memcached的扩展,只有memcache的扩展。亲测,两者之间还是有很大差别的。所以建议还是在linux做。
<?php
$mem = new memcached();
//添加一台服务器资源
$mem->addserver('127.0.0.1', '11211');
//添加多台,分布式存储,第三个参数为权重值
/*
$servers = array(
array('127.0.0.1', 11211, 33),
array('127.0.0.2', 11211, 67),
);
$res = $mem->addservers($servers);
*/
//设置:键 值 过期时间(秒)
$mem->set('name', 'huangyuxin', 5);
//注意:最大生命周期可设置为60*60*24*30 三十天的时间
//再往后的话要加上时间戳 time()+60*60*24*31(三十一天)
//获取值
$value = $mem->get('name');
//添加值,如果存在此键,false
$result = $mem->add('name','zhangsan');
//追加: 键 值 ,追加在一个已经存在的值得后面,不存在也为false
//setoption 这一句必须加上,不然追加不上
//prepend 前面追加
//如果memcached::opt_compression常量开启,这个操作会失败,并引发一个警告,因为向压缩数据 后追加数据可能会导致解压不了。
$mem->setoption(memcached::opt_compression, false);
$mem->append('name','haha');
$value = $mem->get('name');
//这个是减掉元素的值,两个参数,第二个参数决定减掉数值几,默认是 1 ,increment 是加
$mem->set('age', 12, 30);
$mem->decrement('age');
$mem->decrement('age',2);
$value = $mem->get('age');
//删除元素
$mem->delete('age');
$mem->delete('age',60);
/*
注意:
服务端在这段时间拒绝对这个key的add和replace命令.
由于这个时间段的存在, 元素被放入一个删除队列
表明它不可以通过get命令获取到值
但是同时 add和replace命令也从服务端内存删除
(表明元素会被立即删除并且之后对这个 key的存储命令也会成功)
*/
//删除多个
$mem->add('age', 12, 60);
$mem->add('name', 'huangyuxin', 60);
$res = $mem->deletemulti(array('age','name'));
//作废 :flush不会 真正的释放已有元素的内存, 而是逐渐的存入新元素重用那些内存。
$mem->flush(10);//10秒内清除元素
//获取所有键
$mem->getallkeys();
/*
memcached::getdelayed()向memcached服务端发出一个检索
keys指定的多个 key对应元素的请求。这个方法不会等待响应而
是立即返回。当你需要收集元素值时, 调memcached::fetch()
或 memcached::fetchall()。如果with_cas设置为true,会
同时请求每个元素的cas标记。
*/
$m->set('int', 99);
$m->set('array', array(11, 12));
$m->getdelayed(array('int', 'array'), true);
var_dump($m->fetchall());
//获取多个值的信息
$mem->set('age', 12, 60);
$mem->set('name', 'huangyuxin', 60);
$res = $mem->getmulti(array('age', 'name'));
//设置多个键
$items = array(
'key1' => 'value1',
'key2' => 'value2',
'key3' => 'value3',
);
$mem->setmulti($items);
$res = $mem->get('key1');//value
//返回系统常量
var_dump($mem->getoption(memcached::opt_compression));
//返回最后一次操作的结果描述消息
$mem->add('a', 'bar'); // first time should succeed
echo $mem->getresultmessage(), "\n"; //success
//查看此key在哪个服务器上
$mem->add('a', 'bar'); // first time should succeed
$res = $mem->getserverbykey('a');
//array(3) { ["host"]=> string(9) "127.0.0.1" ["port"]=> int(11211) ["weight"]=> int(0) }
//返回服务器列表
var_dump($mem->getserverlist());
//返回服务器状态
var_dump($mem->getserverlist());
//服务器版本
print_r($mem->getversion());
//判断是否是持久链接
$res = $mem->ispersistent();
//memcached::replace()和memcached::set()类似,但是如果 服务端不存在key, 操作将失败。
$m->set('hh', 'aaaa');
$m->replace('hh', 'bbbb');
$res = $m->get('hh');
//删除从已知的服务器列表中的所有缓存服务器,重置回空。
$mem->resetserverlist();
//对某一key重新设置生命周期
$m->set('aaaa', 'aaaa', 600);
$m->touch('aaaa', 5);
$value= $m->get('aaaa');
//关闭打开的链接
$m->quit();
var_dump($value);
以下后缀为bykey一般为多台memcached server使用,掌握以上的命令,下面基本都会用了。
touch->touchbykey
setmulti->setmultibykey
getmulti->getmultibykey
replace->replacebykey
append->appendbykey
prepend->prependbykey
getserverbykey
getdelay->getdelayedbykey
increment->incrementbykey
decrement->decrementbykey
add->addbykey
get->getbykey
delete->deletemultibykey
$m->addbykey('指定服务器','键',"值")
请叫我喵一声