首页 > 后端开发 > php教程 > bigger than bigger phplockphp进程锁 v10 beta1

bigger than bigger phplockphp进程锁 v10 beta1

WBOY
发布: 2016-07-29 08:41:17
原创
1083 人浏览过

在web开发中我们经常对我们的数据库耗时操作做缓存,但是可能出现一个陷阱,在缓存失效的一瞬间,大量的访问得到缓存失效的标示,都去后端查询数据库,导致同时大量的数据库耗时查询,出现数据库宕机等问题。此问题隐藏深,不容易查找。本项目主要用于解决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 sunli1223@gmail.com
*/
require 'class.phplock.php';
$lock = new PHPLock ( 'lock/', 'lockname' );
$lock->startLock ();
$lock->startLock ();
//process code
echo "进入锁
\r\n";
ob_end_flush();
flush();
ob_flush();
sleep ( 5 ); //休眠20秒,模拟并发操作
echo "执行完成
\r\n";
$lock->unlock ();
$lock->endLock ();
echo "释放锁完成
\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 进程锁定问题分析研究

以上就介绍了bigger than bigger phplockphp进程锁 v10 beta1,包括了bigger than bigger方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板