0

0

Laravel怎么处理并发请求_Laravel在高并发下的数据库锁优化【方案】

冰火之心

冰火之心

发布时间:2026-02-05 14:19:20

|

325人浏览过

|

来源于php中文网

原创

DB::transaction() 高并发卡住主因是默认隔离级别下更新同行触发行锁且锁持续至提交,导致阻塞或死锁;应精简事务、显式加锁、原子更新、合理设超时,并按场景选悲观/乐观锁。

laravel怎么处理并发请求_laravel在高并发下的数据库锁优化【方案】

为什么 DB::transaction() 在高并发下会卡住甚至超时

不是事务本身慢,而是默认的数据库隔离级别(如 MySQL 的 REPEATABLE READ)在更新同一行时会触发行级锁,并且锁会持续到事务提交。如果多个请求同时执行 DB::transaction() 并试图更新同一条记录(比如库存扣减),后到的请求就会被阻塞,直到前一个事务释放锁——这直接导致响应延迟甚至 Illuminate\Database\QueryException: SQLSTATE[HY000]: General error: 1205 Deadlock found

实操建议:

  • 避免在事务中做耗时操作(如 HTTP 请求、文件读写、循环计算),只保留必要 DB 操作
  • SELECT ... FOR UPDATE 放在事务最开始,且尽量缩小 WHERE 条件范围(比如用主键而非模糊查询)
  • 设置合理事务超时:MySQL 可调 innodb_lock_wait_timeout(默认 50 秒),Laravel 中可通过 DB::connection()->getPdo()->setAttribute(PDO::ATTR_TIMEOUT, 5) 控制连接级超时(注意这不是锁等待超时)
  • DB::select('SELECT * FROM products WHERE id = ? FOR UPDATE', [$id]) 显式加锁比 Product::lockForUpdate()->find($id) 更可控,后者可能因 Eloquent 的 lazy loading 触发额外查询而延长锁持有时间

DB::update() 原生更新代替 Model->save() 避免 N+1 锁竞争

当多个请求并发更新同一商品库存,若都走 $product = Product::find($id); $product->stock--; $product->save();,每个请求都会先 SELECT 再 UPDATE,中间有时间窗口,且 Eloquent 会加载整行再改——这不仅放大锁范围,还可能因模型事件、访问器等引入不可控延迟。

更安全的做法是原子性更新:

DB::update('UPDATE products SET stock = stock - 1 WHERE id = ? AND stock >= 1', [$id]);

这个语句自带条件检查和原子扣减,失败时返回 0 行影响,无需加锁也无竞态。适用场景:简单字段变更、带前置条件的更新(如“余额足够才扣款”)。

注意点:

  • 不能触发 Eloquent 的 updatingupdated 事件,需自行处理日志或通知
  • 无法自动填充 updated_at,得显式写入:SET updated_at = NOW(), stock = stock - 1
  • 若需返回影响行数做业务判断,用 DB::affectingStatement() 替代 DB::update()(后者不抛异常但也不返回值)

乐观锁方案:用 version 字段 + WHERE version = ? 实现无阻塞重试

适合读多写少、冲突概率低的场景(如文章阅读量、用户积分)。核心思路是不锁行,靠版本号检测并发修改,失败后由应用层决定是否重试。

示例结构:

讯飞智作-讯飞配音
讯飞智作-讯飞配音

讯飞智作是一款集AI配音、虚拟人视频生成、PPT生成视频、虚拟人定制等多功能的AI音视频生产平台。已广泛应用于媒体、教育、短视频等领域。

下载
Schema::table('users', function (Blueprint $table) {
    $table->integer('version')->default(0);
});

更新逻辑:

$user = User::where('id', $id)->first();
$affected = DB::update(
    'UPDATE users SET points = points + ?, version = version + 1 WHERE id = ? AND version = ?',
    [$amount, $id, $user->version]
);
if ($affected === 0) {
    // 版本已变,有人抢先更新了,可重试或返回错误
}

优势明显:无数据库锁、响应快、扩展性好;但要注意:

  • 每次更新必须包含 version = version + 1WHERE version = ? 成对出现
  • 重试逻辑不能无限循环,建议加最大重试次数(如 3 次)和指数退避
  • 不适用于强一致性要求极高的场景(如银行转账),此时仍需悲观锁兜底

Laravel 自带的 Cache::lock() 不适合数据库行锁场景

很多人第一反应是用 Laravel 的分布式锁(Cache::lock('stock_'.$id)->get(...)),但它解决的是「应用层协调」,不是「数据库一致性」。它能防止两个请求同时进入扣库存逻辑,但一旦锁释放、SQL 执行前发生主从延迟或缓存穿透,依然可能双写。

真正该用它的场合是:

  • 防止重复提交(如支付回调幂等校验)
  • 控制后台命令并发(php artisan schedule:run 多实例防重复)
  • 配合数据库操作做二次保险,例如:先抢锁 → 再查库存 → 再扣减 → 最后释放锁

但别把它当成数据库锁的替代品。它不感知事务状态,也不保证 SQL 执行顺序,单纯依赖缓存服务(Redis)的可靠性。

真正难的从来不是加锁,而是判断哪条数据值得锁、锁多久、谁来承担锁失败后的业务补偿。这些没法靠框架自动解决,得结合业务语义一层层压测验证。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

324

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

283

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

456

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

375

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

106

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

73

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

834

2023.10.12

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

7

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.1万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 823人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号