概述:本系列博文所涉及的相关内容来源于debug亲自录制的实战课程:缓存中间件Redis技术入门与应用场景实战(SpringBoot2.x + 抢红包系统设计与实战),感兴趣的小伙伴能够点击自行前往学习(毕竟以视频的形式来掌握技术 会更快!) ,文章所属专栏:缓存中间件Redis技术入门与实战html
摘要:在Redis众多数据结构当中,字符串String能够说是其中比较常见、应用比较频繁的一种了,本文咱们将介绍数据类型~字符串String 在命令行的简单使用及其在实际业务场景中的应用与代码实战,其中应用场景为“存储前端门户网站的商品详情信息”,从而减小数据库DB的访问频率,提升接口的响应速率!
前端
内容:缓存中间件Redis拥有多种丰富的数据结构,字符串String就是其中比较常见并且应用至关普遍的一种,下面咱们将基于前文整合搭建的SpringBoot2.0+Redis的项目为奠定,从两个方面进行介绍,即简单的命令行、实际的应用场景+代码实战!java
(一)Redis命令行界面实操“数据类型String”linux
(1)因为debug本地机子是windows系统,故而为了能够在本地windows操做系统的机子使用Redis命令行,咱们须要前往github下载一个windows版的redis绿色安装工具包(若是是mac或者linux,则直接跳过此步骤),为了方便你们下载,我就直接提供地址给你们下载了(连接:https://pan.baidu.com/s/1o30jZZ9Rb5ZzR2iulQF9JA 提取码:isj0) 下载完成以后,解压到没有中文名称的磁盘目录下,以下图所示:git
其中,最主要的文件当属redis-server.exe、redis-cli.exe以及另外两个用于数据持久化的rdb和aof文件,双击redis-server.exe,成功出现以下的界面即表明redis已经成功在你本地运行起来了:github
(2)下面,咱们写两个简单的命令(即如何往Redis存入一个Key,以及如何从Redis中获取该Key对应的值),简单的感觉一下字符串String在Redis命令行界面下的操做,以下图所示:web
是否是感受很简单???哈哈,原本就是如此!除此以外,还能够在RedisDesktopManager工具查看该Key的具体值!下面我进入重头戏,即如何将Redis的这些特性应用到实际的项目、实际的业务场景中去呢!redis
(二)String典型应用场景代码实战数据库
(1)业务场景介绍:下面咱们以“访问前端门户网站商品信息”为业务场景,在后端管理平台添加“热门商品信息”时也顺便将其塞入缓存Redis中,以后前端门户网站在获取该商品详情时直接走缓存Redis查询,而不走数据库DB查询,在某种状况下(好比双十一、双12的热销商品),能够缓解数据库的访问压力,下降DB的负载!windows
(2)咱们首先开发一个Controller,用于添加热门商品信息、并将其塞入缓存Redis中,除此以外,还开发了前端门户网站访问该热门商品详情信息的请求方法,其完整的源码以下所示:
/** * 字符串String实战-商品详情存储 * @Author:debug (SteadyJack) * @Date: 2019/10/29 20:58 **/ @RestController @RequestMapping("string") public class StringController { private static final Logger log= LoggerFactory.getLogger(StringController.class); @Autowired private StringService stringService; //添加热门商品 @RequestMapping(value = "put",method = RequestMethod.POST,consumes = MediaType.APPLICATION_JSON_UTF8_VALUE) public BaseResponse put(@RequestBody @Validated Item item, BindingResult result){ if (result.hasErrors()){ return new BaseResponse(StatusCode.InvalidParams); } BaseResponse response=new BaseResponse(StatusCode.Success); try { log.info("--商品信息:{}",item); stringService.addItem(item); }catch (Exception e){ log.error("--字符串String实战-商品详情存储-添加-发生异常:",e.fillInStackTrace()); response=new BaseResponse(StatusCode.Fail.getCode(),e.getMessage()); } return response; } //获取热门商品详情 @RequestMapping(value = "get",method = RequestMethod.GET) public BaseResponse get(@RequestParam Integer id){ BaseResponse response=new BaseResponse(StatusCode.Success); try { response.setData(stringService.getItem(id)); }catch (Exception e){ log.error("--字符串String实战-商品详情存储-添加-发生异常:",e.fillInStackTrace()); response=new BaseResponse(StatusCode.Fail.getCode(),e.getMessage()); } return response; } }
(3)其中,stringService 顾名思义,即为实现业务逻辑的真正实现类!其完整源代码以下所示:
/** * @Author:debug (SteadyJack) * @Date: 2019/10/29 21:05 **/ @Service public class StringService { private static final Logger log= LoggerFactory.getLogger(StringService.class); @Autowired private ItemMapper itemMapper; @Autowired private StringRedisService redisService; @Autowired private ObjectMapper objectMapper; //添加商品 @Transactional(rollbackFor = Exception.class) public Integer addItem(Item item) throws Exception{ item.setCreateTime(new Date()); item.setId(null); itemMapper.insertSelective(item); Integer id=item.getId(); //保证缓存-数据库双写的一致性 if (id>0){ redisService.put(id.toString(),objectMapper.writeValueAsString(item)); } return id; } //获取商品 public Item getItem(Integer id) throws Exception{ Item item=null; if (id!=null){ if (redisService.exist(id.toString())){ String result=redisService.get(id.toString()).toString(); log.info("---string数据类型,从缓存中取出来的value:{}",result); if (StrUtil.isNotBlank(result)){ item=objectMapper.readValue(result,Item.class); } }else{ log.info("---string数据类型,从数据库查询:id={}",id); item=itemMapper.selectByPrimaryKey(id); if (item!=null){ redisService.put(id.toString(),objectMapper.writeValueAsString(item)); } } } return item; } }
值得一提的是:
A.咱们在 “将热门商品添加进数据库后 也往缓存中间件Redis塞了一份”,为了保证“双写一致性”,咱们的作法是:“先保证成功数据库,以后再往缓存Redis塞一份!”
B.“商品信息”是一个实体对象,为了能将该实体对象信息塞入Redis的String类型中,咱们须要将其“序列化”,采用的Jackson的序列化机制,将该实体对象序列化为“Json格式的字符串”!
C. 在“获取热门商品详情”时,咱们固然是根据Key直接进行获取,但因为其结果是String类型的Json格式字符串常量值,故而咱们须要将其“反序列化”,即一样也是采用Jackson的反序列化机制,将其映射到一个Item实体对象中便可
(4)至此,咱们的撸码环节就所有完成了,最后,咱们基于Postman进行自测吧:
A.首先固然是添加一个热销商品,商品信息为:
{ "code": "book50010", "name": "分布式中间件实战(Java版)"}
发起Http请求以及获得的响应信息以下图所示:
采用Navicat查看数据库中相应表的信息记录,以下图所示:
B.最后,固然在Postman是模拟“前端门户网站”发起“获取热销商品详情”的请求啦,以下图所示:
除此以外,还能够在RedisDesktopManager中查看该商品存储在缓存中间件Redis的详情:
好了,本篇文章咱们就介绍到这里了,建议各位小伙伴必定要照着文章提供的样例代码撸一撸,只有撸过才能知道这玩意是咋用的,不然就成了“空谈者”!对Redis相关技术栈以及实际应用场景实战感兴趣的小伙伴能够我们51cto学院 debug亲自录制的课程进行学习:缓存中间件Redis技术入门与应用场景实战(SpringBoot2.x + 抢红包系统设计与实战)
补充:
一、本文涉及到的相关的源代码能够到此地址,check出来进行查看学习:https://gitee.com/steadyjack/SpringBootRedis
二、目前debug已将本文所涉及的内容整理录制成视频教程,感兴趣的小伙伴能够前往观看学习:https://edu.51cto.com/course/20384.html