首页 > 代码库 > memcached 乐观锁实现:cas
memcached 乐观锁实现:cas
Memcached::cas(check and set)使用了乐观锁,避免了并发访问时可能出现的覆盖修改问题.
成功时返回 TRUE
, 或者在失败时返回 FALSE
。 如果在元素尝试存储时发现在本客户端最后一次获取后被其他客户端修改,Memcached::getResultCode() 将返回Memcached::RES_DATA_EXISTS
。
以下是使用举例,使用do,while结构及cas方法,如果cas方法
$m = new Memcached (); $m -> addServer ( ‘localhost‘ , 11211 ); do { /* 获取ip列表以及它的标记 */ $ips = $m -> get ( ‘ip_block‘ , null , $cas ); /* 如果列表不存在, 创建并进行一个原子添加(如果其他客户端已经添加, 这里就返回false)*/ if ( $m -> getResultCode () == Memcached :: RES_NOTFOUND ) { $ips = array( $_SERVER [ ‘REMOTE_ADDR‘ ]); $m -> add ( ‘ip_block‘ , $ips ); /* 其他情况下,添加ip到列表中, 并以cas方式去存储, 这样当其他客户端修改过, 则返回false */ } else { $ips [] = $_SERVER [ ‘REMOTE_ADDR‘ ]; $m -> cas ( $cas , ‘ip_block‘ , $ips ); } } while ( $m -> getResultCode () != Memcached :: RES_SUCCESS );
memcached 乐观锁实现:cas
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。