redis+延遲執行 秒殺低端處理方式

public function test(){
        $microseconds = rand(1000000,3000000);
        usleep($microseconds);//延遲隨機毫秒數繼續執行
        $redis = new Redis();
        $count_num =$redis ->get( "count_num");
        if($count_num > 0){
            if($count_num >= 100){//數量大於100直接返回秒殺失敗
                return $count_num;
            }
            $redis->inc('count_num');//增加成功秒殺數量
        }else{
            $redis ->set( "count_num" , 1);//設置秒殺數
        }
        //業務代碼
        $test['time'] = time();
    	$test['add_time'] = date('Y-m-d H:i:s');
    	Db::table('cmf_test')->insert($test);
        return $redis ->get( "count_num");
    }

代碼基於tp5編寫,使用阿里雲服務器1核2G1M服務器,測試10000併發,未添加實際業務邏輯,未出現多餘數據,代碼僅供娛樂,大佬輕噴
在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章