当前位置: 首页 > 图文教程 > 网络编程 > PHP > phplock(php进程锁) v1.0 beta1

PHP
工作笔记:配置MySQL为高可用集群 (1)
MySQL (C API)VC实例及代码下载 (1)(5)
MySQL (C API)VC实例及代码下载 (1)(4)
MySQL (C API)VC实例及代码下载 (1)(3)
MySQL (C API)VC实例及代码下载 (1)(2)
MySQL (C API)VC实例及代码下载 (1)
用JSP连接mysql数据库的方法 (1)(2)
用JSP连接mysql数据库的方法 (1)
MySQL数据库账户授权的相关管理解析 (1)(2)
MySQL数据库账户授权的相关管理解析 (1)
SAP MaxDB MySQL修补数据库严重漏洞
MySQL研发中心成立发布会会后访问整理 (1)(2)
MySQL研发中心成立发布会会后访问整理 (1)
MySQL中SQL-TEXT、DATE和SET数据类型
MySQL存在权限提升及安全限制绕过漏洞
MySQL 卸载的问题
windows下安装、卸载mysql服务
如何正确卸载MySQL
MySQL手册版本 5.0.20-MySQL优化(四) (1)(5)
MySQL手册版本 5.0.20-MySQL优化(四) (1)(4)

PHP 中的 phplock(php进程锁) v1.0 beta1


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-10   浏览: 90 ::
收藏到网摘: n/a

PHP在多进程模式下(并发的web访问)由于没有内置的锁支持,在处理一些资源的之后,很容易出现并发性问题。 在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 进程锁定问题分析研究