bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

如何解決laravel高并發之抽獎秒殺

這篇文章主要介紹了如何解決laravel高并發之抽獎秒殺,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創新互聯公司專注于山陽企業網站建設,成都響應式網站建設公司,成都做商城網站。山陽網站建設公司,為山陽等地區提供建站服務。全流程按需策劃,專業設計,全程項目跟蹤,成都創新互聯公司專業和態度為您提供的服務

測試

注意

不要在一臺機子上測,因為網絡的原因,本機上測并發1000不用鎖也是正常的。可以在阿里云買臺測試機

1.MySQL共享鎖版

sql加共享鎖,stock字段減1。返回成功表示成功,返回失敗表示自減失敗。stock字段是無符號的

遷移文件

<?php

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateStockTestTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('stock_test', function (Blueprint $table) {
            $table->increments('id');
            $table->integer('stock')->default(0)->comment('庫存1');
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('stock_test');
    }
}

代碼

$model = new \App\Models\StockTest();
$id = $request->input('id',1);

try {
    // 手動開始事務
    DB::beginTransaction();
    // sql加共享鎖,stock字段減1。返回成功表示成功,返回失敗表示自減失敗。stock字段是無符號的
    $is = DB::table('stock_test')->lockForUpdate()->increment('stock',-1);
    if($is)
    {
        log_info('id='.$id.'庫存減1');
        // 提交事務
        DB::commit();
        return response('成功',200);
    }
    else
    {
        return response('失敗',201);
    }
} catch (\Exception $exception) {
    // 回滾事務
    DB::rollBack();
    return response('失敗',201);
}

2.reids隊列

  • 1.lpush加入隊列

  • 2.lpop彈窗隊列,成功返回對應值,不存在返回null

感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何解決laravel高并發之抽獎秒殺”這篇文章對大家有幫助,同時也希望大家多多支持創新互聯,關注創新互聯行業資訊頻道,更多相關知識等著你來學習!

本文名稱:如何解決laravel高并發之抽獎秒殺
標題路徑:http://vcdvsql.cn/article42/pdiihc.html

成都網站建設公司_創新互聯,為您提供定制網站電子商務面包屑導航網站維護用戶體驗

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網站建設公司