高并发解决方案_laravel高并发之抽奖秒杀解决方案

0c432edf28f06fb1081deb654dbc1260.png

php中文网最新课程

每日17点准时技术干货分享

e8e8f0248f0d65086825ac13b0556d21.png

3d2053ee9bb8e05a49ef480c731e6699.gif

测试

1.8核16G的服务器Jmeter并发2000

注意:

不要在一台机子上测,因为网络的原因,本机上测并发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

45db65fc993d71a26153a6fd6c8602af.png

4b9895f0d03fc67100024b468dcf6d8c.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值