首先,我们要弄明白两个要点:最近浏览的商品肯定是一个存和取的两个操作.好了目前摆在我们面前的有以下几个问题:
1,最近浏览的记录肯定是需要失效时间的
确定使用缓存,缓存可以设置失效时间(最大设置为一个月,但是这已经足够了),如果使用mysql等数据库,还需要定时任务清除,很明显是不切合实际的,
2,最近浏览的记录肯定是有个数限制的,不可能记录所有的浏览记录
目前使用的主流缓存有 memached和redis两种(原谅无知的我并不清楚其他的),redis有LTRM来修剪,保证存储的浏览的条数;
3,我们需要在哪里添加保存浏览商品的方法
用户最近浏览的商品,肯定是再用户最近打开商品详情页的时候才算浏览,这点毋庸置疑;
4,怎么保证每次添加的浏览的商品列表按着浏览的先后顺序排序?
每次用户的浏览商品的ID,可以以用户的ID作为key,以List作为value,储存在redis中,而List是有序的,而且,在使用LRANGE的时候能保证先进后出,后进先出的原则,已达到排列在最前面的商品始终是里当前最近浏览的那个商品;
5,怎么保证用户在连续浏览同一个商品的时候,不会重复保存商品?
可以使用redis中LREM来移除列表中与参数 value(该商品ID) 相等的元素。同时在使用Lpush重新再List插入最新的浏览商品;
6,读取缓存的时候,又该如何保证分页?
redis中的LRANGE可以指定获取指定长度的元素,能够满足需要;
下面是简单的实现思路:
1,储存用户浏览的商品:
用户在打开详情页的时候,以用户ID作key,商品的ID做值,以List存入redi缓存中;
在加入添加缓存之前,为了保证浏览商品的 唯一性,每次添加前,使用lrem将缓存的list中该商品ID去掉,在加入,以保证其浏览的最新的商品在最前面;
在lpush到redis的List中之后,根据产品需求还需要将该list的前60个数据之外的缓存修剪掉;
最后添加缓存失效时间30天;
2.获取用户最近浏览的商品列表:
根据用户的ID及当前的页数和每页的个数,来获取商品缓存;