php memcached方法有哪些
时间:2022-02-11 13:48
php memcached方法有:1、set();1、add();3、replace();4、get();5、delete();6、increment();7、decrement();8、flush();9、connect()等等。 本教程操作环境:windows7系统、PHP7.1版,DELL G3电脑 PHP操作Memcached的方法汇总 (一)memcache扩展 1、bool Memcache::set ( string #Key存在则更新值,不存在则设置k-v对。注:$var可以存储任何数据 2、bool Memcache::add ( string #key不存在的时候才添加 3、bool Memcache::replace ( string #替换存在的key值,不存在key则返回错误 4、string Memcache::get ( string array Memcache::get ( array #获取一个或者多个值 5、bool Memcache::delete ( string #删除key元素,设置了timeout则多少秒后删除 #【注意】有些版本对应memcached使用timeout将会导致删除失败(0可以) 6、int Memcache::increment ( string #key存在且能转换为数字,则加int;否则直接更换为value。当key不存在,则返回false 7、int Memcache::decrement ( string 8、bool Memcache::flush ( void ) #全部元素失效 9、bool Memcache::connect ( string #连接memcache服务器,执行完脚本后会自动关闭(使用close可以主动关闭) 10、bool Memcache::close ( void ) #关闭memcache的链接(这个函数不会关闭持久化连接) 11、mixed Memcache::pconnect ( string #建立持久化连接 12、bool Memcache::addServer ( string #增加一台服务器到连接池,通过此方法打开的服务,将会在脚本结束的时候关闭或者主动关闭close #使用此方法,网络连接不一定立即连接,而是等需要使用此服务器的时候,才会进行连接,因此即使添加大量的服务器到连接池也没有开销 参数: $status 控制此服务器是否被标记为在线状态(假若连接失败,连接池少了一个服务器,会影响原有的分配算法) 13、array Memcache::getExtendedStats ([ string #getExtendedStats()返回一个二维关联数据的服务器统计信息 #getExtendedStats(‘slabs’)获取到每个服务器上活动slabs分块的id #getExtendedStats('cachedump', $slabid, $limit)获取每个slab里面缓存的项 参数: #type 期望抓取的统计信息类型,可以使用的值有{reset, malloc, maps, cachedump, slabs, items, sizes} #slabid 用于与参数 #limit 用于和参数 14、int Memcache::getServerStatus ( string #返回一个服务器的状态,0表示服务器离线,非0表示在线。 15、array Memcache::getStats ([ string #getStats()返回一个关联数据的服务器统计信息。同上 16、string Memcache::getVersion ( void ) #返回版本号 17、bool Memcache::setCompressThreshold ( int #开启对于大值的自动压缩 参数: #threshold 控制多大值进行自动压缩的阈值。 #min_saving 指定经过压缩实际存储的值的压缩率,支持的值必须在0和1之间。默认值是0.2表示20%压缩率 18、bool Memcache::setServerParams ( string #用于运行时修改服务器参数 #参数同上 (二)memcached扩展 1、Memcached::__construct ([ string #默认情况下,Memcached实例在请求结束后会被销毁。但可以在创建时通过 2、public bool Memcached::addServer( string #增加指定服务器到服务器池中,此时不会建立与服务端的连接 3、public bool Memcached::addServers( array #添加多台服务器到服务池中 4、public bool Memcached::cas( float #执行一个"检查并设置"的操作,它仅在当前客户端最后一次取值后,该key
对应的值没有被其他客户端修改的情况下,
才能够将值写入。通过 5、public bool Memcached::casByKey ( float #指定服务器,同上 #【$server_key也是一个普通的key, *ByKey系列接口的工作过程是: 首先, 对$server_key进行hash, 得到$server_key应该存储的服务器, 然后将相应的操作在 $server_key所在的服务器上进行】 6、public bool Memcached::set( string #将value值(值可以是任何有效的非资源型php类型)存到key下 7、public bool Memcached::setByKey ( string #指定服务器,同上 8、public bool Memcached::setMulti ( array #存储多个元素 #$items array(‘key’=>’value’) 9、public bool Memcached::setMultiByKey ( string #指定服务器,同上 10、public bool Memcached::add( string #向一个新的key下面增加一个元素,key存在则失败 11、public bool Memcached::addByKey( string #在指定服务器上的一个新的key下增加一个元素 12、public bool Memcached::touch( string #为key设置新的过期时间 13、public bool Memcached::touchByKey( string #为指定服务器中的key设置过期时间 14、public bool Memcached::append( string #向已经存在的元素后追加 注意:如果Memcached::OPT_COMPRESSION常量开启,这个操作会失败,并引发一个警告,因为向压缩数据后追加数据可能会导致解压不了。 15、public bool Memcached::appendByKey ( string #向指定服务器已经存在的元素后追加 16、public bool Memcached::prepend( string #向一个已存在的元素前面追加数据 17、public bool Memcached::prependByKey( string #向指定服务器已经存在的元素前追加 18、public bool Memcached::replace ( string #替换已存在key下的元素 19、public bool Memcached::replaceByKey( string #替换指定服务器的key下的元素 20、public int Memcached::decrement ( string #减小数值元素的值 #不存在key返回错误、减到小于0结果为0、元素不是数值以0对待 21、public int Memcached::decrementByKey( string #指定服务器减小数值元素的值,不存在的key则初始化为0 22、public int Memcached::increment ( string #增加数值元素的值 23、public int Memcached::incrementByKey( string #同上 24、public bool Memcached::delete( string #删除一个元素 #设置时间后,表明在time时间后才删除,在这段时间内get、add、replace命令对该key都无效。 25、public bool Memcached::deleteByKey ( string #同上 26、public bool Memcached::deleteMulti ( array #删除多个key 27、public bool Memcached::deleteMultiByKey( string #同上 28、public bool Memcached::flush([ int #让所有缓冲区的数据失效 29、public mixed Memcached::get( string #检索一个元素 #$callback 回调函数,没有$key之值时,将会调用这个函数,会传入三个参数memcache对象、key、引用传递变量的返回值(true时返回) #$cas_token
配合cas使用。同一个客户端最后一个get将会生成一个64位唯一标识符存储,然后使用cas来查看更改,假若在此过程中被其他客户端修改则,返回false 30、public mixed Memcached::getByKey( string #从特定的服务器检索元素 31、public mixed Memcached::getMulti( array #检索多个元素,提供$cas值,则添加cas值 #$flags
只能为Memcached::GET_PRESERVE_ORDER,保证返回的key的顺序和请求时一致。 32、public array Memcached::getMultiByKey ( string #从特定服务器检索多个元素 33、public array Memcached::getAllKeys( void ) # Gets the keys stored on all the servers 34、public bool Memcached::getDelayed( array #向服务器端请求keys,这个方法不会等待响应而是立即返回bool,收集结果使用fetch、fetchAll #$with_cas true时,则表示同时记录cas值 # 35、public bool Memcached::getDelayedByKey( string #从指定服务器中请求多个keys 36、public array Memcached::fetch ( void ) #从最后一次请求中抓取下一个结果。 37、public array Memcached::fetchAll( void ) #抓取所有剩余的结果 38、public mixed Memcached::getOption( int #获取Memcached的选项值 # OPT_*系列常量中的一个。 39、public bool Memcached::setOption( int #设置一个memcached选项 40、public bool Memcached::setOptions( array #设置多个memcached选项 41、public int Memcached::getResultCode( void ) #返回最后一次操作的结果代码 42、public string Memcached::getResultMessage( void ) #返回最后一次操作的结果描述消息 43、public array Memcached::getServerByKey( string #获取key所映射的服务器信息 44、public array Memcached::getServerList( void ) #获取服务器池中服务器表 45、public array Memcached::getStats ( void ) #获取服务器池中的统计信息 46、public array Memcached::getVersion( void ) #获取服务器池中所有服务器版本信息 47、public bool Memcached::isPersistent( void ) #测试服务器是否永久连接 48、public bool Memcached::isPristine ( void ) #测试memcache是否最近创建的 49、public bool Memcached::quit ( void ) #关闭连接 50、public bool Memcached::resetServerList( void ) #重置所有服务器的服务器服务信息 51、public void Memcached::setSaslAuthData( string #Set the credentials to use for authentication (以上是自己在参考手册学习memcached的时候,整理的笔记,顺便也将它贴出来吧,若有不足或者错误的地方请各位指出哈) 推荐学习:《PHP视频教程》 以上就是php memcached方法有哪些的详细内容,更多请关注gxlsystem其它相关文章!$key
, mixed $var
[, int $flag
[, int $expire
]] )$key
, mixed $var
[, int $flag
[, int $expire
]] )$key
, mixed $var
[, int $flag
[, int $expire
]] )$key
[, int &$flags
] )$keys
[, array &$flags
] )$key
[, int $timeout
= 0 ] )$key
[, int $value
= 1 ] )$key
[, int $value
= 1 ] )$host
[, int $port
[, int $timeout=1
]] )$host
[, int $port
[, int $timeout
]] )$host
[, int $port
= 11211 [, bool $persistent
[, int $weight
[, int $timeout
[, int $retry_interval
[, bool $status
[, callback
$failure_callback
[, int $timeoutms
]]]]]]]] )$persistent
是否持久化,默认true
$weight
表示权重
$retry_interval
服务器连接失败时重试时间,默认为15秒,-1表示不重试
$failure_callback
连接失败后执行的函数(在故障转移前执行),包含两个参数,失败主机host和port
$type
[, int $slabid
[, int $limit
= 100 ]]] )type
联合从指定slab分块拷贝数据,cachedump命令会完全占用服务器通常用于 比较严格的调试。type
联合来设置cachedump时从服务端获取的实体条数。$host
[, int $port
= 11211 ] )$type
[, int $slabid
[, int $limit
= 100 ]]] )$threshold
[, float $min_savings
] )$host
[, int $port
= 11211 [, int $timeout
[, int $retry_interval
= false [, bool $status
[, callback $failure_callback
]]]]] )$persistent_id
] )persistent_id
为每个实例指定唯一的ID,在请求间共享实例。所有通过相同的persistent_id
值创建的实例共享同一个连接。<?php
# 创建一个普通的对象
$m1 = new Memcached();
echo get_class($m);
/* 创建持久化对象 */
$m2 = new Memcached('story_pool');
$m3 = new Memcached('story_pool');
# 现在$m2和$m3共享相同的连接 ,可以使用isPresistent进行检测
?>
$host
, int $port
[, int $weight
= 0 ] )$servers
)$cas_token
,
string $key
, mixed $value
[, int $expiration
] )cas_token
参数进行检查$cas_token
,
string $server_key
, string $key
, mixed $value
[, int $expiration
] )$key
, mixed $value
[, int $expiration
] )$server_key
, string $key
, mixed $value
[, int $expiration
] )$items
[, int $expiration
] )$server_key
, array $items
[, int $expiration
] )$key
, mixed $value
[, int $expiration
] )$server_key
, string $key
, mixed $value
[, int $expiration
] )$key
, int $expiration
)$server_key
, string $key
, int $expiration
)$key
, string $value
)value
参数对应的字符串值<?php
$a = new Memcached();
$a->addServer('192.168.95.11', 11211);
#$a->addServer('192.168.95.11', 11210);
#$a->setOption(Memcached::OPT_COMPRESSION, false);
$b=$a->append('e','popop');
echo "<pre>";
print_r($b);
echo "</pre>";die;
?>
$server_key
, string $key
, string $value
)value
参数对应的字符串值$key
, string $value
)$server_key
, string $key
, string $value
)value
参数对应的字符串值$key
, mixed $value
[, int $expiration
] )$server_key
, string $key
, mixed $value
[, int $expiration
] )$key
[, int $offset
= 1 ] )$server_key
, string $key
[, int $offset
= 1 [, int $initial_value
= 0 [, int $expiry
= 0 ]]] )$key
[, int $offset
= 1 ] )$server_key
, string $key
[, int $offset
= 1 [, int $initial_value
= 0 [, int $expiry
= 0 ]]] )$key
[, int $time
= 0 ] )$server_key
, string $key
[, int $time
= 0 ] )$keys
[, int $time
= 0 ] )$server_key
, array $keys
[, int $time
= 0 ] )$delay
= 0 ] )$key
[, callback $cache_cb
[,
float &$cas_token
]] )$server_key
, string $key
[, callback $cache_cb
[,
float &$cas_token
]] )$keys
[, array &$cas_tokens
[, int $flags
]] )$server_key
, array $keys
[, string &$cas_tokens
[, int $flags
]] )$keys
[, bool $with_cas
[,
callback $value_cb
]]
)$value_cb
结果回调函数处理
$server_key
, array $keys
[, bool $with_cas
[,
callback $value_cb
]]
)$option
)$option
, mixed $value
)$options
)$server_key
)$username
, string $password
)