码迷,mamicode.com
首页 > 其他好文 > 详细

微服务-使用Redis实现分布式缓存

时间:2018-05-08 20:08:57      阅读:272      评论:0      收藏:0      [点我收藏+]

标签:strong   数据库   ssi   isnull   private   分布式   redist   管理   file   

在单体中对于key信息和用户信息是放在内存中放的,通过session进行管理。

微服务是要放在分布式缓存中,以实现服务的无状态化

技术分享图片

  @Autowired
  private StringRedisTemplate redisTemplate;

  @Value("${file.prefix}")
  private String imgPrefix;
  
  /**
   * 1.首先通过缓存获取
   * 2.不存在将从通过数据库获取用户对象
   * 3.将用户对象写入缓存,设置缓存时间5分钟
   * 4.返回对象
   * @param id
   * @return
   */
  public User getUserById(Long id) {
    String key = "user:"+id;
    String json =  redisTemplate.opsForValue().get(key);
    User user = null;
    //如果为空则从数据库中查找
    if (Strings.isNullOrEmpty(json)) {
      user =  userMapper.selectById(id);
      user.setAvatar(imgPrefix + user.getAvatar());
      //反序列化成json存入缓存
      String string  = JSON.toJSONString(user);
      redisTemplate.opsForValue().set(key, string);
      redisTemplate.expire(key, 5, TimeUnit.MINUTES);
    }else {
    //不为空则将缓存中的json对象反序列化成user对象
      user = JSON.parseObject(json,User.class);
    }
    return user;
  }

 

微服务-使用Redis实现分布式缓存

标签:strong   数据库   ssi   isnull   private   分布式   redist   管理   file   

原文地址:https://www.cnblogs.com/xiangkejin/p/9010572.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!