PHP进程锁 phplock

Apache
PHP
跨平台
2009-12-02
草屋主人

PHP在多进程模式下(并发的web访问)由于没有内置的锁支持,在处理一些资源的之后,很容易出现并发性问题。

在web开发中我们经常对我们的数据库耗时操作做缓存,但是可能出现一个陷阱,在缓存失效的一瞬间,大量的访问得到缓存失效的标示,都去后端查询数据库,导致

同时大量的数据库耗时查询,出现数据库宕机等问题。此问题隐藏深,不容易查找。本项目主要用于解决php的进程间锁问题。

php

/**
 * 测试例子,同时打开两个页面,可以发现总是同时只能一个页面进入到锁区间的代码
 * @link http://code.google.com/p/phplock/
 * @author sunli
 * @blog http://sunli.cnblogs.com
 * @svnversion  $Id: test.php 4 2009-11-25 05:05:13Z 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 ();
$status
= $lock->Lock ();
if (! $status) {
        echo
"加锁失败";
       
exit ();
}
//process code
echo
"进入锁
\r\n"
;
ob_end_flush
();
flush
();
ob_flush
();
sleep
( 10 ); //休眠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) {

}
$key
= 'cachekey';
$cache
= getCache ( $key );
if (! $cache) {
       
//缓存不存在,开始加锁
        $lock
= new PHPLock ( 'lock/', $key );
        $lock
->startLock ();
        $lock
->Lock ();
       
//尝试判断缓存是否有数据,可能已经有访问重建缓存了,就不需要再次查询数据库
        $cache
= getCache ( $key );
       
if (! $cache) {
               
//数据库查询操作,代码省略了
                $data
= $dbdata;
                setCache
( $key, $data );
       
}
       
//释放锁
        $lock
->unlock ();
        $lock
->endLock ();
}

?>
加载中

评论(0)

暂无评论

暂无资讯

暂无问答

PHP并发操作下的加锁

代码如下: 文件锁类 <?php /** * CacheLock 进程锁,主要用来进行cache失效时的单进程cache获取,防止过多的SQL请求穿透到数据库 * 用于解决PHP在并发时候的锁控制,通过文件/eaccelerator进行...

2016/11/17 17:09
84
0
软件系统开发中的数据交换协议

软件系统开发中的数据交换协议

2014/06/05 19:36
152
0
关系数据库还是NoSQL数据库

上一篇简单的说明了为什么要使用NoSQL。接下来我们看下如何把NoSQL引入到我们的项目中,我们到底要不要把NoSQL引入到项目中。 在过去,我们只需要学习和使用一种数据库技术,就能做几乎所有的...

2014/06/19 00:25
9
0
NoSQL开篇——为什么要使用NoSQL

【编者按】NoSQL在2010年风生水起,大大小小的Web站点在追求高性能高可靠性方面,不由自主都选择了NoSQL技术作为优先考虑的方面。今年伊始,InfoQ中文站有幸邀请到凤凰网的孙立先生,为大家分...

2014/08/29 09:57
51
0
NoSQL开篇——为什么要使用NoSQL

【编者按】NoSQL在2010年风生水起,大大小小的Web站点在追求高性能高可靠性方面,不由自主都选择了NoSQL技术作为优先考虑的方面。今年伊始,InfoQ中文站有幸邀请到凤凰网的孙立先生,为大家分...

2014/06/19 00:37
4
0
NoSQL开篇——为什么要使用NoSQL

【编者按】NoSQL在2010年风生水起,大大小小的Web站点在追求高性能高可靠性方面,不由自主都选择了NoSQL技术作为优先考虑的方面。今年伊始,InfoQ中文站有幸邀请到凤凰网的孙立先生,为大家分...

2014/06/19 00:21
3
0
关系数据库还是NoSQL数据库

在过去,我们只需要学习和使用一种数据库技术,就能做几乎所有的数据库应用开发。因为成熟稳定的关系数据库产品并不是很多,而供你选择的免费版本就更加少了,所以互联网领域基本上都选择了免...

2014/10/16 14:03
26
0
关系数据库还是NoSQL数据库

上一篇简单的说明了为什么要使用NoSQL。接下来我们看下如何把NoSQL引入到我们的项目中,我们到底要不要把NoSQL引入到项目中。 在过去,我们只需要学习和使用一种数据库技术,就能做几乎所有的...

2014/06/19 01:04
11
0

没有更多内容

加载失败,请刷新页面

没有更多内容

返回顶部
顶部