您好,登錄后才能下訂單哦!
這篇文章主要介紹了如何解決laravel高并發(fā)之抽獎(jiǎng)秒殺,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
測(cè)試
1.8核16G
的服務(wù)器Jmeter
并發(fā)2000
不要在一臺(tái)機(jī)子上測(cè),因?yàn)榫W(wǎng)絡(luò)的原因,本機(jī)上測(cè)并發(fā)
1000
不用鎖也是正常的。可以在阿里云買臺(tái)測(cè)試機(jī)
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); }
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í)!
免責(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)容。