redis在微博与微信等互联网应用笔记
Redis实战redis在微博与微信等互联网应用实例讲解全集
1. 对象缓存
| id | user | balance | 
|---|---|---|
| 1 | john | 1200 | 
| 2 | tom | 3000 | 
对于这种存储,redis可以使用mset or hmset实现
    mset user:{userId}:name john user:{userId}:balance:1200
    mget user:{userId}:name user:{userId}:balance
    mset user:1:name john user:1:balance:1200
    mget user:1:name user:1:balance
    hmset user {userId}:name john {userId}:balance 1888
    hmget user {userId}:name {userId}:balance
    hmset user 1:name john 1:balance 1888
    hmget user 1:name 1:balance
2. 计数器
    incr article:readcount:{文章id}    
    get article:readcount:{文章id}
3. web集群session共享
spring session + redis实现session共享   
4. 分布式系统全局序列号
分库分表情况下,自行生成主键id,高并发情况下,每次批量取出1000个id存入内存中供使用,用完再取
    INCRBY orderId 1000   //redis批量生成序列号提升性能
5. redis实现电商购物车


电商购物车
- 以用户id为key
- 商品id为field
- 商品数量为value
    //向购物车添加商品
    hset cart:1001 10099 1
    hset cart:1001 20088 1
    hset cart:1001 30088 1
    //往存在购物车中的商品增加数量
    hincrby cart:1001 10099 1
    //获取购物车中商品的数目
    hget cart:1001 10099
    //获取购物车中存在的不同商品总数
    hlen cart:1001
    //删除商品
    hdel cart:1001 10099
    //获取所有商品
    hgetall cart:1001
Hash结构优缺点
优点
1. 同类数据归类整合存储,方便数据管理
2. 相比string操作消耗内存与cpu更小
3. 相比string存储更节省空间
缺点
1. 过期功能不能使用在field,只能用在key上
2. redis集群架构下不适合大规模使用
队列的使用




set的使用










 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号