storm实现基于物品的推荐

一.Spout

输入数据

  1. List存储

    • 入库
jedis.lpush("recom","1:1:5");
  • 出库,从列表的头部取出数据并删除该数据
jedis.rpop("recom")
  • 查看数据
lrange recom 0 12

输出数据

  1. set存储

    • 入库

用户id 物品id:评分

sadd 1 2:4.5
  • 查询用户5对所有物品的评分
SMEMBERS 5
1) "1:4"
2) "2:3"
3) "5:3.5"
4) "4:4"
5) "3:2"
6) "6:4"

二.WeightMBolt

计算用户的对物品的同现矩阵

  1. hash存储
    weight:用户id 下标1:下标2 矩阵值
    weight:5 1:2 2

    • 入库
jedis.hmset("weight:"+userId, weightCount);

查询用户的同现矩阵:

hgetAll weight:5
1) "1:1"
2) "1"

WeightCountBolt

计算整个同现矩阵

  1. 存储

    • 入库
    jedis.hmset("weight",mapTemp);
    • 查询
HGETALL weight

RecommendBolt

推荐

  1. set

    • 入库
 jedis.sadd("userScore:" + userId, String.valueOf(result[i]));
  • 查询
SMEMBERS userScore:1
1) "0.0"
2) "15.5"
3) "10.5"
4) "23.5"
5) "5.0"

问题

  1. 同现矩阵计算不正确
下标错误值-正确值
3 43 4
4 43-4
3 33-4
2 32-3
1 33-4
3 13-4
4 13-4
1 43-4
2 22-3

2. Error:java: 找不到目录: /Users/xiaoxiyun/IdeaProjects/examples-ch06-real-life-app/target/generated-sources/annotations

  1. ERROR util - Async loop died!

多线程 同步

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值