>데이터 베이스 >Redis >Redis의 증가분 및 해시 애플리케이션 구문 분석

Redis의 증가분 및 해시 애플리케이션 구문 분석

藏色散人
藏色散人앞으로
2021-09-18 16:46:202899검색

incr

예를 들어 베이징 번호판은 먼저 잡아서 자격을 승인하는 프로세스를 채택합니다. 번호판 풀에는 N개의 번호가 있으며, 페이지당 10개의 항목으로 페이지가 표시됩니다. 각 번호 뒤에는 잡기 버튼이 있으며, 한 사람이 번호판 1개만 잡을 수 있으며, 동일한 번호판은 본인만 잡을 수 있습니다. 한 사람. 비즈니스 모델 참조 (http://num.10010.com/NumApp/chseNumList/init?num=186)

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

또한 incr string 유형, hash 유형 및 sortedSet 유형이 모두 작동할 수 있습니다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 可以做更多关于业务的操作,比如通过hget等查看具体的绑定关系。

hdel

有了通过hsetnx的绑定模型,当某个人对某个车牌交付了订金等一系列之后,就代表可以永远的将其消除,这样会用到hdel。另外如果在指定时间内没有做比如交付订金之类的操作,这个车牌号码会回炉到原始列表中。

 //删除以people_id为key的hash
 $base_people_id_del = $this->redis->hdel(self::$_config['hash_base_people'], $people_id);

 //删除以car_no为key的hash
 $base_car_no_del = $this->redis->hdel(self::$_config['hash_base_car_no'], $clue_id);

lpush

如果有入口将北京可以抢拍的车牌放入到一个list里

$lpush_res = $redisObj->lpush($list_name, $car_no);

其中list_name的值可以根据car_no的具体值来确定,比如有6和8的我就放入到better_car_no列表里,其他的放入到normal_car_no列表里,最后可以用blpop来指定一个先后优先级。

rpoplpush

安全的队列弹出模式,比如N多人对一个入口按钮进行操作,如果list结构中有足够的数据,每个人有且只有一条数据会被领取,领取之后再做其他的业务操作。
但是问题是,如果用lpop之后,原队列中已被弹出,如果中途客户端在取得该pop的元素后,且完成处理此元素前,客户端发生崩溃。这时候此条消息就凭空消失了。如果没有其他补助措施(比如通过绑定或者记录此弹出的元素)需要严谨要求,可以用rpoplpush可以解决此问题。在客户端真正处理完此pop的元素之后,通过lrem

blpop

blpop은 lpop과 다른 점은 여러 대기열의 우선순위를 지정할 수 있다는 것입니다. blpopkey의 순서에 따라 순서대로 팝업됩니다. 반환 값은 key의 목록 이름과 특정 요소 값이며 block은 Time으로 설정할 수 있으며, 먼저 차단하고 먼저 제공하는 것이 원칙입니다. rrreee
hsetnx

🎜해시필드를 지정된 값으로 설정합니다. , 전제 예 필드가 존재하지 않습니다. 존재하는 경우 0을 반환합니다. 🎜이렇게 하면 한 사람이 하나의 번호판만 가져올 수 있지만, 결제나 기타 비즈니스 작업을 수행하기 위해 번호판을 잡는 과정에서는 다른 사람이 이를 수행할 수 없습니다(즉, 이 번호판은 다른 사람에게 바인딩될 수 없습니다). 구체적인 비즈니스 상황에 따라 car_no 기반의 해시 필드와 사람 기반의 해시 필드를 설정할 수 있습니다. 🎜rrreee🎜 이 두 해시를 기반으로 hget을 통한 구체적인 바인딩 관계 확인 등 더 많은 비즈니스 관련 작업을 수행할 수 있습니다. 🎜🎜hdel🎜🎜hsetnx를 통한 바인딩 모델에서는 누군가가 특정 번호판 등에 대한 보증금을 지불하면 영원히 제거될 수 있다는 의미이므로 hdel이 사용됩니다. 또한, 지정된 시간 내에 보증금 납부 등의 작업이 이루어지지 않을 경우, 차량번호는 원래 목록으로 복귀됩니다. 🎜rrreee🎜lpush🎜🎜입구가 있으면 베이징에서 찍을 수 있는 번호판을 목록에 넣어보세요🎜rrreee🎜car_no의 특정 값에 따라 list_name의 값이 결정될 수 있습니다. 예를 들어 6개가 있는 경우입니다. 8, better_car_no 목록에 넣고 나머지는 normal_car_no 목록에 넣은 다음 마지막으로 blpop를 사용하여 우선순위를 지정할 수 있습니다. . 🎜🎜rpoplpush🎜🎜안전 대기열 팝업 모드 예를 들어 N여러 명이 입장 버튼을 조작하는 경우 목록 구조에 충분한 데이터가 있으면 각 사람은 하나의 데이터만 수신하게 되며 다른 사업 운영은 그것을 받은 후에 완료될 것입니다. 🎜하지만 문제는 lpop을 사용한 후 원래 대기열이 팝되었다는 것입니다. 클라이언트가 중간에 pop 요소를 획득하고 이 요소 처리를 완료하기 전에 클라이언트는 추락했다. 이때 메시지가 허공에서 사라졌습니다. 엄격한 요구 사항을 요구하는 다른 보완 조치(예: 팝업 요소 바인딩 또는 기록)가 없는 경우 rpoplpush를 사용하여 이 문제를 해결할 수 있습니다. 클라이언트가 실제로 pop 요소를 처리한 후 lrem을 통해 메시지가 안전하게 삭제됩니다. 🎜🎜🎜추천 학습: "🎜redis 비디오 튜토리얼🎜"🎜🎜

위 내용은 Redis의 증가분 및 해시 애플리케이션 구문 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제