> php教程 > php手册 > 用memcached实现的php锁机制

用memcached实现的php锁机制

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-06 20:11:02
원래의
1234명이 탐색했습니다.

?php/** * 使用Memcache实现给进程加锁的类 * * Copyright (C) 2013 JeffJing * * 一些时候需要让系统的某些操作串行化,这个时候就要对这些操作来加上一把锁。 好比你去上厕所, 你要先推厕所门看能否进去,进去的话上锁,其他人就进不来了, 等你拉完粑粑之

 <?php /**
 * 使用Memcache实现给进程加锁的类
 *
 * Copyright (C) 2013 JeffJing
 *
 * 一些时候需要让系统的某些操作串行化,这个时候就要对这些操作来加上一把锁。 好比你去上厕所, 你要先推厕所门看能否进去,进去的话上锁,其他人就进不来了, 等你拉完粑粑之后把锁打开,这样的话就保证了厕所永远只有1个人, 上厕所的过程是串行化的, 同时只有1个人上。
 * 网上的一些解决方案大多是使用文件的, 我就纳闷了,加锁的时候创建一个文件, 解锁的时候把文件删掉。
 * 我就纳闷: Why not memcached ? 顺手写了这么一个 , 希望对大家"拉粑粑"的这种操作有所帮助
 *
 * 举个栗子:
 * 	$key = '厕锁';
 * 	if(MemLock::addLoack($key)) {
 * 		//拉粑粑喽,pu~pu~~~~~
 * 		MemLock::releaseLock($key);
 * 	} else {
 * 		//不好意思, 厕所有人啦!!
 * 	}
 *
 */
class MemLock {
	private static $memcache = null;
	/**
	 * 获取memcached连接
	 *
	 * @return Memcached
	 */
	public static function getConnection() {
		if (! isset ( self::$memcache )) {
			self::$memcache = new Memcache ();
			self::$memcache->connect ( '127.0.0.1', 11211 );
		}
		return self::$memcache;
	}
	/**
	 * 加锁
	 *
	 * @param $key 锁关键字
	 * @param $expireTime   超时时间, 当进程在锁定后出错,这样永远不会释放锁了,只能等到缓存失效
	 *
	 * @return boolean true 成功获取到锁 false 获取锁失败
	 */
	public static function addLock($key, $expireTime = 120) {
		$memcache = self::getConnection ();
		if($memcache->add($key, 1, false, $expireTime)) {
			return true;
		}
		return false;
	}
	/**
	 * 释放锁
	 *
	 * @param $key 锁关键字
	 *
	 * @return boolean true 释放成功 false 释放失败
	 */
	public static function releaseLock($key) {
		$memcache = self::getConnection ();
		return $memcache->delete ( $key );
	}
로그인 후 복사

声明: 本文采用 CC BY-NC-SA 3.0 协议进行授权

转载请注明来源:小景的博客

本文链接地址:http://www.phpv5.com/blog/mem-lock

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿