溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何解決laravel高并發(fā)之抽獎(jiǎng)秒殺

發(fā)布時(shí)間:2021-01-18 14:02:31 來(lái)源:億速云 閱讀:254 作者:小新 欄目:編程語(yǔ)言

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

測(cè)試

注意

不要在一臺(tái)機(jī)子上測(cè),因?yàn)榫W(wǎng)絡(luò)的原因,本機(jī)上測(cè)并發(fā)1000不用鎖也是正常的。可以在阿里云買臺(tái)測(cè)試機(jī)

1.mysql共享鎖版

sql加共享鎖,stock字段減1。返回成功表示成功,返回失敗表示自減失敗。stock字段是無(wú)符號(hào)的

遷移文件

<?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('庫(kù)存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 {
    // 手動(dòng)開(kāi)始事務(wù)
    DB::beginTransaction();
    // sql加共享鎖,stock字段減1。返回成功表示成功,返回失敗表示自減失敗。stock字段是無(wú)符號(hào)的
    $is = DB::table('stock_test')->lockForUpdate()->increment('stock',-1);
    if($is)
    {
        log_info('id='.$id.'庫(kù)存減1');
        // 提交事務(wù)
        DB::commit();
        return response('成功',200);
    }
    else
    {
        return response('失敗',201);
    }
} catch (\Exception $exception) {
    // 回滾事務(wù)
    DB::rollBack();
    return response('失敗',201);
}

2.reids隊(duì)列

  • 1.lpush加入隊(duì)列

  • 2.lpop彈窗隊(duì)列,成功返回對(duì)應(yīng)值,不存在返回null

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何解決laravel高并發(fā)之抽獎(jiǎng)秒殺”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI