使用Redis实现抢购的一种思路
抢购是如今很常见的一个应用场景,主要需要解决的问题有两个: 1 高并发对数据库产生的压力 2 竞争状态下如何解决库存的正确减少(“超卖”问题) 对于第一个问题,已经很容易想到用缓存来处理抢购,避免直接操作数据库,例如使用Redis。重点在于第二个问题,我们看看下面一种常规的实现代码: <?php require('predis/src/Autoloader.php'); $redis = new Predis\Client(array( 'scheme' => 'tcp', 'host' => '127.0.0.1', 'port' => '6379' )); //redis 登录 $redis->auth('123456'); //库存 $num = 10; //用户id $user_id = $_SESSION['user_id']; //检查库存 $len = $redis->llen('order:1'); if($len >= $num){ exit('已经抢光了'); } //把抢到的用户存入到列表中 $result = $redis->lpush('order:1',$user_id); if($result){ echo '抢到了'; } ?> 如果代码正常运行,列表order:1中最多只能存储10个用户的id,因为库存只有10个。 然而,在使用Apache