phplock(php进程锁) v1.0 beta1

  在web开发中我们经常对我们的数据库耗时操作做缓存,但是可能出现一个陷阱,在缓存失效的一瞬间,大量的访问得到缓存失效的标示,都去后端查询数据库,导致同时大量的数据库耗时查询,出现数据库宕机等问题。此问题隐藏深,不容易查找。本项目主要用于解决php的进程间锁问题。

  示例:

  

复制代码 代码如下:

  <?php

  /**

  * 测试例子,同时打开两个页面,可以发现总是同时只能一个页面进入到锁区间的代码

  * @link http://code.google.com/p/phplock/

  * @author sunli

  * @svnversion $Id: test.php 2 2009-11-24 07:14:27Z sunli1223 $

  * @version v1.0 beta1

  * @license Apache License Version 2.0

  * @copyright [email protected]

  */

  require 'class.phplock.php';

  $lock = new PHPLock ( 'lock/', 'lockname' );

  $lock->startLock ();

  $lock->startLock ();

  //process code

  echo "<span>进入锁</span><br />\r\n";

  ob_end_flush();

  flush();

  ob_flush();

  sleep ( 5 ); //休眠20秒,模拟并发操作

  echo "执行完成<br />\r\n";

  $lock->unlock ();

  $lock->endLock ();

  echo "释放锁完成<br />\r\n";

  /**

  * cache操作

  *

  * @return $array

  */

  function getCache($key) {

  return $cache;

  }

  /**

  * 设置缓存

  *

  * @param string $key

  * @param array $value

  */

  function setCache($key,$value) {

  }

  $cache=getCache($key);

  if (! $cache) {

  //缓存不存在,开始加锁

  $lock = new PHPLock ( 'lock/', $key );

  $lock->startLock ();

  $lock->startLock ();

  //尝试判断缓存是否有数据,可能已经有访问重建缓存了,就不需要再次查询数据库

  $cache=getCache();

  if(!$cache){

  //数据库查询操作,代码省略了

  $data=$dbdata;

  setCache($key,$data);

  }

  //释放锁

  $lock->unlock ();

  $lock->endLock ();

  }

  ?>

  相关文章推荐

  PHP 进程锁定问题分析研究