红色魔法:Redis豆瓣推荐系统
10年的宝山网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。营销型网站的优势是能够根据用户设备显示端的尺寸不同,自动调整宝山建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联公司从事“宝山网站设计”,“宝山网站推广”以来,每个客户项目都认真落实执行。
Redis是一个开源的高性能key-value数据库,它支持完全的关键字交换协议,提供数据持久化、高可用性、集群化等优秀特性。在本文中,我们将介绍如何使用Redis搭建一个豆瓣推荐系统。
1. 数据库设计
豆瓣推荐系统需要存储用户和用户行为数据,以及物品和物品特征数据。我们可以使用Redis的HASH数据结构存储这些信息,其中键是用户id或物品ID,值是一个HashMap。
创建用户行为数据:
HSET user:1 activity:book 1
HSET user:1 activity:movie 3
HSET user:1 activity:music 5
HSET user:2 activity:book 4
HSET user:2 activity:movie 2
HSET user:2 activity:music 2
...
创建物品特征数据:
HSET item:1 Tag:action 1
HSET item:1 tag:adventure 1
HSET item:1 tag:sci-fi 1
HSET item:2 tag:drama 1
HSET item:2 tag:romance 1
HSET item:2 tag:classic 1
...
2. 构建推荐列表
基于用户历史查询行为和物品特征,我们可以使用Redis的ZSET结构构建推荐列表。我们首先需要计算一个物品与用户查询行为之间的相似度分值,这可以使用协同过滤技术来完成。在本文中,我们将使用余弦相似度算法。
计算用户和物品的相似度:
def cosine_similarity(user, item):
user_tags = [tag for tag, count in redis.hgetall('user:%s' % user).items()]
item_tags = [tag for tag, count in redis.hgetall('item:%s' % item).items()]
common_tags = set(user_tags) & set(item_tags)
numerator = sum([redis.hget('user:%s' % user, tag) * redis.hget('item:%s' % item, tag) for tag in common_tags])
denominator = math.sqrt(sum([pow(redis.hget('user:%s' % user, tag), 2) for tag in user_tags])) * math.sqrt(sum([pow(redis.hget('item:%s' % item, tag), 2) for tag in item_tags]))
if not denominator:
return 0.0
else:
return float(numerator) / denominator
使用相似度分值来构建推荐列表:
def get_recommendations(user_id, num_items = 10):
ZKEY = 'user:%s:recs' % user_id
user_items = redis.hkeys('user:%s' % user_id)
for item_id in redis.keys('item:*'):
if item_id not in user_items:
score = cosine_similarity(user_id, item_id)
if score > 0.0:
redis.zadd(ZKEY, score, item_id)
return redis.zrevrange(ZKEY, 0, num_items-1, withscores=True)
3. 缓存推荐列表
由于计算相似度分值需要耗费时间,我们可以对用户的推荐列表进行缓存,以提升性能。我们可以使用Redis的LIST结构缓存推荐列表,当用户的查询行为发生变化时,我们可以轻松地更新这个列表。
def cache_recommendations(user_id, num_items = 10):
LKEY = 'user:%s:recs' % user_id
recommendations = get_recommendations(user_id, num_items)
redis.delete(LKEY)
for item_id, score in recommendations:
redis.lpush(LKEY, item_id)
redis.expire(LKEY, 60*60*24)
4. 基于实时查询更新推荐列表
为了让用户获得最新的推荐,我们可以随时检测用户的行为,当用户查询一个物品时,我们可以基于用户的实时行为更新推荐列表。
def query_item(user_id, item_id, num_items = 10):
redis.hincrby('user:%s' % user_id, 'activity:%s' % item_id, 1)
cache_recommendations(user_id, num_items)
完整代码请参见以下链接:
https://github.com/linanqiu/redis-recommendations
成都服务器托管选创新互联,先上架开通再付费。
创新互联(www.cdcxhl.com)专业-网站建设,软件开发老牌服务商!微信小程序开发,APP开发,网站制作,网站营销推广服务众多企业。电话:028-86922220
网页名称:红色魔法Redis豆瓣推荐系统(redis豆瓣推荐)
分享路径:http://www.shufengxianlan.com/qtweb/news14/35864.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联