在工作项目中,会遇到一些php并发访问去修改一个数据问题,如果这个数据不加锁,就会造成数据的错误。下面我将分析一个财务支付锁的问题。希望对大家有所帮助。
1 没有应用锁机制
1.1 财务支付简化版本代码
<!--"select account form user_account where userid = ${userId}"; //$mysql = new mysql();//mysql数据库 return $mysql->query($sql); } //更新用户余额 function setUserLeftMoney($userId,$money) { if(false == is_int($userId) || false == is_int($money)) { return false; } $sql = "update user_account set account = ${money} where userid = ${userId}"; //$mysql = new mysql();//mysql数据库 return $mysql->execute($sql); } "text-align: left;">2.1 类图设计如下2.2 php源码设计如下
LockSystem.php
<!--"not support lock of ${type}"); } $this->_lock = new $type($options); } public function getLock($key, $timeout = ILock::EXPIRE) { if (false == $this->_lock instanceof ILock) { throw new Exception('false == $this->_lock instanceof ILock'); } $this->_lock->getLock($key, $timeout); } public function releaseLock($key) { if (false == $this->_lock instanceof ILock) { throw new Exception('false == $this->_lock instanceof ILock'); } $this->_lock->releaseLock($key); } } interface ILock { const EXPIRE = 5; public function getLock($key, $timeout=self::EXPIRE); public function releaseLock($key); } class FileLock implements ILock { private $_fp; private $_single; public function __construct($options) { if (isset($options['path']) && is_dir($options['path'])) { $this->_lockPath = $options['path'].'/'; } else { $this->_lockPath = '/tmp/'; } $this->_single = isset($options['single'])"w+"); if (true || $this->_single) { $op = LOCK_EX + LOCK_NB; } else { $op = LOCK_EX; } if (false == flock($this->fp, $op, $a)) { throw new Exception('failed'); } return true; } public function releaseLock($key) { flock($this->fp, LOCK_UN); fclose($this->fp); } } class SQLLock implements ILock { public function __construct($options) { $this->_db = new mysql(); } public function getLock($key, $timeout=self::EXPIRE) { $sql = "SELECT GET_LOCK('".$key."', '".$timeout."')"; $res = $this->_db->query($sql); return $res; } public function releaseLock($key) { $sql = "SELECT RELEASE_LOCK('".$key."')"; return $this->_db->query($sql); } } class MemcacheLock implements ILock { public function __construct($options) { $this->memcache = new Memcache(); } public function getLock($key, $timeout=self::EXPIRE) { $waitime = 20000; $totalWaitime = 0; $time = $timeout*1000000; while ($totalWaitime < $time && false == $this->memcache->add($key, 1, $timeout)) { usleep($waitime); $totalWaitime += $waitime; } if ($totalWaitime >= $time) throw new Exception('can not get lock for waiting '.$timeout.'s.'); } public function releaseLock($key) { $this->memcache->delete($key); } }3 应用锁机制
3.1 支付系统应用锁
<!--"select account form user_account where userid = ${userId}"; //$mysql = new mysql();//mysql数据库 return $mysql->query($sql); } //更新用户余额 function setUserLeftMoney($userId,$money) { if(false == is_int($userId) || false == is_int($money)) { return false; } $sql = "update user_account set account = ${money} where userid = ${userId}"; //$mysql = new mysql();//mysql数据库 return $mysql->execute($sql); } ?>3.2 锁分析
p操作人:
获取锁:pay100
取出用户的余额1000。
支付后剩余 800 = 1000 - 200。
更新后账户余额800。
释放锁:pay100m操作人:
1、等待锁:pay100
2、获取锁:pay100
3、获取余额:800
3、支付后剩余500 = 800 - 300。
5、支付后账户余额500。
6、释放锁:pay100两次支付后,余额500。非常完美了解决了并发造成的临界区资源的访问问题。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
金钱帮资源网 Copyright www.kbjia.com
暂无“php并发加锁问题分析与设计代码实例讲解”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年10月31日
2024年10月31日
- 【原神】V5.1攻略 | 纳西妲一图流攻略
- 群星.2003-重遇80·感动今天的都市人2CD【SONY】【WAV+CUE】
- 希文.2024-沉溺【StreetVoice】【FLAC分轨】
- 韩红.2005-精丫麒麟童】【WAV+CUE】
- 2D像素风日式美学动作游戏《雨魂》将登陆Xbox Series
- 《龙腾世纪4》评分造假?仅将评测代码给好评媒体!
- 《怪猎荒野》推出蜘蛛恐惧症设定 蜘蛛秒变史莱姆
- 《张韶涵单8CD+无损单曲合集》[WAV/FLAC][6.5G]
- 自然声带《大自然 雨声 白噪音》[320K/MP3][135.32MB]
- 自然声带《大自然 雨声 白噪音》[FLAC/分轨][416.27MB]
- 2024年度计划曝光!《暗黑破坏神:不朽》X《魔兽世界》11月开启联动
- 逆流而上!成都Wolves后发制人韧性十足!——《第五人格》2024秋季赛第四周赛报
- 复归之刻,七烛庆典,狼人杀七周年掌门表演赛活动来袭!
- 炉石传说野兽流最终阵容推荐 酒馆战棋野兽流最终阵容图文一览
- 炉石传说野猪人流最终阵容推荐 酒馆战棋野猪人流最终阵容图文一览