思路:
优化方案1:将库存字段number字段设为unsigned,当库存为0时,因为字段不能为负数,将会返回false(商品库存)
优化方案2:使用MySQL的事务,锁住操作的行
优化方案3:使用redis队列,push库存进去,因为列表的pop操作是原子的,即使有很多用户同时到达,也是依次执行的。
``
举例1:php同时跑16个进程,如何保证这16个进程不重复数据?
解决:openid,md5加密后为32位的字符串,其中第一位为0-9,a-f。共16个不同的数字。把16个字符整成数组[0,1,2,3,4,5……],逐一push进redis队列。再pop出数据进行查询,处理,并把处理过的数据做一个标识。
补充:锁处理、同时请求300个不同的id,id in(1,2,3……)
并发处理(持续更新)
最新推荐文章于 2021-02-05 06:06:57 发布