## 高并发商品秒杀情况下,如何防止库存超支?
> 1. 使用MYSQL悲观锁(容易死锁)或者乐观锁。
> 2. 消息队列解决
> 3. REDIS分布式锁
### 1. REDIS分布式锁
> 分布式锁具有 **排他性**、**避免死锁** 等特性
> **SETNX (排他性)** :Not Exists (只有该key不存在,才能设置成功)
> **SETEX (避免死锁)** :EXPIRE(设置该KEY过期时间,防止死锁问题)
> 因为 SET 命令可以通过参数来实现和 SETNX 、 SETEX 结合命令效果
> SET mykey "value" NX EX 10
~~~
public function test()
{
$result = $this->checkManyCommitByRedis('test_commit'.$uid); //防止高并发
if ($result == false) {
exit('不要频繁操作哟');
}
// TODO....
// 成功后切勿不要释放该锁,不然会引发TODO...流程中执行过长时间(锁失效),下一个请求来了加锁后,上一个请求成功执行释放锁,就影响了下一个请求的正常逻辑
}
// 防止用户频繁提交
function checkManyCommitByRedis($key,$set_redis_time=3)
{
if (!\Yii::$app->redis->set($key,1,['NX', 'EX' => $set_redis_time])) {//key存在
return false;
}
return true;
}
~~~
- 重点知识预览
- 理解面向对象
- 魔术变量
- 魔法方法
- 面试题基础篇
- PSR标准
- class (单继承)
- trait (多继承)
- 匿名函数
- 日期处理
- 文件处理
- 字符串处理
- BC Math
- 数组处理
- HTTP的各个状态
- PHP环境变量
- session & cookie
- composer
- 变量的类型转换和判断类型方法
- PHP的错误和异常处理
- PHP的ob缓冲区
- PHP内存调试
- pcntl多进程
- PHP yield (生成器):节约内存
- Nginx负载均衡
- 同一台服务器如何测试负载均衡
- 安全方面
- HTTPS实现
- PHP性能分析(xhprof)
- 高并发雪崩解决方法
- 接口加密设计(安全性)
- 数据库(重要数据操作)日志记录规范
- APP发版操作
- 缓存使用
- Memcache
- MYSQL缓存
- Redis
- 安装与使用
- redis过期策略和内存淘汰机制
- Redis分布式锁
- Redis雪崩、穿透、击穿问题
- redis主从
- redis哨兵
- opcache
- 消息队列
- Redis消息队列
- Beanstalkd
- 数据库汇总
- MYSQL哪些情况下会忽略索引
- MYSQL常用命令
- SQL高级运用
- MYSQL分布式集群使用
- 主从复制
- 同一台服务器如何测试主从同步
- MYSQL索引类型
- MYSQL分区
- 锁机制
- 事务隔离级别(脏读、幻读、不可重复读)
- 分布式事务
- MYSQL性能优化
- swoole
- 安装以及升级
- swoole进程初识
- TCP相关教程
- TCP数据传输DEMO(含同步、异步、长连接)
- Server异步投递task任务
- TCP粘包问题
- websocket相关教程
- websocket初体验DEMO
- websocket核心功能(心跳检测、用户校验、重连机制)
- websocket用户之间通信DEMO
- 定时器的使用
- 常驻内存以及如何避免内存泄漏
- max_request使用实例
- 守护进程、信号和平滑重启
- 全文检索工具
- MYSQL全文索引
- ElasticSearch全文检索
- ES基础知识
- Mapping及增删改查
- DSL查询语法
- 搜索建议 (completion)
- mysql转dsl工具
- ES的安装与PHP测试
- kibana可视化工具
- ELK日志管理系统
- PHP设计模式
- 创建型模式
- 工厂模式
- 单例模式
- 注册器模式
- 工厂模式于策略模式的区别
- 结构型模式
- 适配器模式
- 桥接模式
- 装饰器模式
- 行为型模式
- 观察者模式
- 策略模式
- 高并发设计