首页 > 系统服务 > 详细

利用memcached实现并发时候,设置缓存锁

时间:2015-11-09 19:24:34      阅读:477      评论:0      收藏:0      [点我收藏+]

利用了memcached中 add()方法。

memcached:add($key) 成功时返回 TRUE, 或者在失败时返回 FALSE。 如果这个key已经存在返回FALSE。 

利用add的原子性来判断是否需要执行业务代码。

/**
 * @param null $key
 * 
 * @author 20779182@qq.com
 */
public function add_cache($key=null)
{
    $memcacheClass = new Memcached();
    $data = $memcacheClass->get($key);
    if(! $data) {
        do {
            $write_key = ‘write‘;
            if($memcacheClass->add($write_key, $write_key, 10 * 60)) {
                // 加锁成功,执行业务操作
                $data = $model->get();
                $memcacheClass->set($key, $data, 30 * 60); // 将数据存入缓存
                $memcacheClass->delete($write_key);
                $is_retry = false;
            } else {
                // 如果加锁不成功,等待一段时间之后重试
                sleep(10);
                $is_retry = true;
            }
        } while($is_retry);
    }
}


利用memcached实现并发时候,设置缓存锁

原文:http://my.oschina.net/liuke1556/blog/528133

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!