站长资讯网
最全最丰富的资讯网站

解析redis的incr和hash应用

incr

比如北京车牌采取先抢到后审批资质的流程。车牌池子中有N多号码,页面呈现以一页十条的方式展示,每个号码后有一个抢的按钮,且一个人只能抢一个车牌,同样一个车牌只能被一个人抢到。业务模型参考(http://num.10010.com/NumApp/chseNumList/init?num=186)

<!– more –>

 if ($this->redis_db->incr("bj_".$car_no) != 1) {       让别人先下手了,点别的去~   }else{        //抢到竞态条件,如果不复核资质要求退出,并清除incr        if(抢到了但是没资质等){          释放对此id的竟态权,别占茅坑          $this->yredis_db->del("bj_".$id);        }else{          其他业务A          抱得号码归...          其他业务B      } }

另外,incrstring类型,hash类型,sortedSet类型都可以进行操作

blpop

blpop相对于lpop有一个好处,可以对多个队列进行优先级操作。
blpop会按照key的排列顺序依次弹出,返回值为key的listname及具体元素值,而且可以设置block时间,原则是先阻塞先服务.

        $date = date('Ymd', time());         //左进左出 ,优先分配一般的车牌号码,然后在分配非常好的连号号码,设置一个阻塞时间         return $this->redis->blpop(self::$_config['dispatch_normal_list'] . $date, self::$_config['dispatch_better_list'] . $date, self::$_config['redis_block_l_pop_time_out']);

hsetnx

设置hash中一个field为指定value,前提是field不存在。如果存在,返回0。
这样能保证在一个人只能抢一个车牌,但是抢到车牌执行付款或者其他业务操作过程中,其他人无法对此操作,(即不能将此车牌绑定到其他人身上)。根据具体业务情况,可设置基于car_no的hash field和基于 people 的hash field。

hash_base_people {"zhangsan":"京A888","lisi":"京A999"} hash_base_car_no {"京A888":"zhangsan","京A999":"lisi"}

基于这两个hash 可以做

赞(0)
分享到: 更多 (0)
网站地图   沪ICP备18035694号-2    沪公网安备31011702889846号