项目要点
spring本地tomcat的war包与war exploded包的区别:
war包是个压缩包,war exploded包是解压后的文件夹。
购物车设计:
redis使用hashmap结构(不是用json格式的hashmap,而是redis的hashmap),可以使用原子操作改变产品数量,并拆分购物信息到另一个hashmap,减少冗余也提高并发。
(String:HashMap)=(用户名:(产品id:产品数量))
(String:String)=(产品id,产品信息)
订单重复处理设计:
正确:同一个用户重复调用生成订单的接口,在redis存放一个2s的键值对(key,value),key可以是(用户名,value)可以设置0。可以做一下加锁的操作,用setnx(setIfAbsent)实现单体锁。
错误:同一个用户重复调用生成订单的接口,在redis存放一个2s内过期的键值对(key,value),key可以是(用户名,value)可以设置1(随便设置),在redis里有这个键值对的情况,该用户不可以提交订单。该方案未考虑并发情况,并发情况下出现两个请求生成订单到redis同时发现没有键值对。

本文探讨了Spring框架中使用Redis实现购物车功能的方法,包括采用hashmap结构存储购物信息及利用原子操作更新商品数量。此外,还介绍了如何通过Redis进行订单重复提交的预防措施。

被折叠的 条评论
为什么被折叠?



