/*乐观锁(Optimistic Lock), 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会
上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。乐观锁适用
于多读的应用类型,这样可以提高吞吐量,像数据库如果提供类似于write_condition机制的其实都是提供的
乐观锁。*/
header('content-type:text/html;charset=utf-8');
$redis = new Redis();
$result = $redis->open('192.168.1.236', 6379 , 5 );
$redis -> auth('likang');
//var_dump($redis -> set( 'b' , 123 ));
//
//var_dump( $redis -> get('b') );
//
//var_dump( $result );exit;
//echo "<pre>";
echo "页面被访问了" . $redis->incr('ci'). '<br>';
echo '总共抢到了' . $redis->lLen('s_kill') . '<br>';
echo '剩余数量' . $redis->get('s_kill_number'). '<br>';
// 监视 s_kill_number 值
$redis -> watch('s_kill_number');
$num_ber = $redis -> get('s_kill_number');
//print_r( $redis->lGetRange('s_kill',0 , $redis ->lLen('s_kill')));
//var_dump($num_ber);exit;
if ( $num_ber > 0) {
// 开启事务
$redis -> multi();
$redis->decr('s_kill_number');
$redis->lPush('s_kill', rand(1000, 9999));
// 提交事务
$res = $redis->exec();
if($res){
exit('OK'. '<br>');
}else{
exit('抢光了'. '<br>');
}
} else {
$redis -> exec();
exit('抢光了'. '<br>');
}