• 【SpringBoot】| SpringBoot 集成 Redis


    目录

    一:SpringBoot 集成 Redis 

    二:对比 StringRedisTemplate 和 RedisTemplate  

    图书推荐:《MySQL 8查询性能优化》


    tips:前些天突然发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家,感兴趣的同学可以点击网站进行学习人工智能学习网站

    一:SpringBoot 集成 Redis 

    Redis是一个 NoSQL(not only)数据库, 常作用缓存 Cache 使用。

    Redis是一个中间件、是一个独立的服务器;常用的数据类型: string , hash ,set ,zset , list

    ③通过Redis客户端可以使用多种语言在程序中,访问 Redis 数据;java 语言中使用的客户端库有 Jedis,lettuce,  Redisson 等。

    SpringBoot中使用 RedisTemplate(和StringRedisTemplate) 模版类操作 Redis 数据

    ⑤Redis只要是运用在Linux服务器上,其中有两个重要的二进制文件

    redis-server:服务端:src目录下,执行./redis-server启动服务器端,不要关闭。

    redis-cli:客户端: 在src目录下,执行./redis-cli启动客户端,访问redis中的数据。

    第一步:创建SpingBoot项目,选择Web、Redis模块

     pom.xml配置

    1. "1.0" encoding="UTF-8"?>
    2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    4. <modelVersion>4.0.0modelVersion>
    5. <parent>
    6. <groupId>org.springframework.bootgroupId>
    7. <artifactId>spring-boot-starter-parentartifactId>
    8. <version>2.7.9version>
    9. <relativePath/>
    10. parent>
    11. <groupId>com.zlgroupId>
    12. <artifactId>study-springboot-redisartifactId>
    13. <version>0.0.1-SNAPSHOTversion>
    14. <properties>
    15. <java.version>1.8java.version>
    16. properties>
    17. <dependencies>
    18. <dependency>
    19. <groupId>org.springframework.bootgroupId>
    20. <artifactId>spring-boot-starter-data-redisartifactId>
    21. dependency>
    22. <dependency>
    23. <groupId>org.springframework.bootgroupId>
    24. <artifactId>spring-boot-starter-webartifactId>
    25. dependency>
    26. <dependency>
    27. <groupId>org.springframework.bootgroupId>
    28. <artifactId>spring-boot-starter-testartifactId>
    29. <scope>testscope>
    30. dependency>
    31. dependencies>
    32. <build>
    33. <plugins>
    34. <plugin>
    35. <groupId>org.springframework.bootgroupId>
    36. <artifactId>spring-boot-maven-pluginartifactId>
    37. plugin>
    38. plugins>
    39. build>
    40. project>

    Redis使用是lettuce客户端

    在程序中使用RedisTemplate类的方法去操作redis数据, 实际就是调用的lettuce客户端的中的方法!

    第二步:配置核心配置文件 application.properties

    主要配置三个部分:host(ip地址)、port(端口号)、password(密码)

    1. server.port=8082
    2. server.servlet.context-path=/myredis
    3. #指定redis(host/port/password)
    4. spring.redis.host=192.168.2.129 #windows系统就使用localhost,Linux就适应虚拟地址的IP
    5. spring.redis.port=6379
    6. #spring.redis.password=123456 没有密码就不用设置

    第三步:Linux中进行处理

    ①首先关闭防火墙

    1. systemctl status firewalld.service #查看关闭防火墙
    2. systemctl disable firewalld.service #永久关闭防火墙

    ②打开redis.conf修改配置

    1. bind中的#去掉,并改为bind 0.0.0.0
    2. protected-mode yes改为no

    ③杀死已经开启的redis

    1. ps -ef | grep redis #查出进程
    2. kiil -9 进程id #根据进程强制杀死已经开启的redis

    ④重启服务,让修改的配置生效,重新开启redis服务

    src/redis-server ./redis.conf #在redis目录下执行该命令,开启redis服务即可

    具体更加详细的redis配置与启动可以参考这篇博客:http://t.csdn.cn/P71zi

    第四步:编写Controller

    在controller中执行两个操作:添加数据到redis、从redis获取数据!

    1. package com.zl.controller;
    2. import org.springframework.data.redis.core.RedisTemplate;
    3. import org.springframework.data.redis.core.ValueOperations;
    4. import org.springframework.web.bind.annotation.GetMapping;
    5. import org.springframework.web.bind.annotation.PostMapping;
    6. import org.springframework.web.bind.annotation.RestController;
    7. import javax.annotation.Resource;
    8. @RestController
    9. public class RedisController {
    10. // 使用RedisTemplate模板,泛型有三种形式:全是Object、全是String、不写
    11. @Resource
    12. private RedisTemplate redisTemplate;
    13. // 添加数据到redis
    14. @PostMapping("/redis/add")
    15. public String addToRedis(String name,String value){
    16. // 获取ValueOperations对象,这个对象是用来处理String类型的对象添加和取出
    17. ValueOperations valueOperations = redisTemplate.opsForValue();
    18. // 添加数据到redis
    19. valueOperations.set("myname",name);
    20. return "向redis添加数据";
    21. }
    22. // 从redis取出数据
    23. @GetMapping("/redis/get")
    24. public String getToRedis(String key){
    25. ValueOperations valueOperations = redisTemplate.opsForValue();
    26. Object value = valueOperations.get(key);
    27. return "向redis获取数据:"+key+"=="+value;
    28. }
    29. }

    添加数据

    取出数据

    查看客户端的数据(查出的是key)

    通过key获取value

    二:对比 StringRedisTemplate 和 RedisTemplate  

    通过Restful风格编写例子直观感受StringRedisTemplate 和 RedisTemplate存储数据的区别!

    第一种:使用RedisTemplate存储数据

    1. package com.zl.controller;
    2. import org.springframework.data.redis.core.RedisTemplate;
    3. import org.springframework.web.bind.annotation.PathVariable;
    4. import org.springframework.web.bind.annotation.PostMapping;
    5. import org.springframework.web.bind.annotation.RestController;
    6. import javax.annotation.Resource;
    7. @RestController
    8. public class ControllerRedis {
    9. @Resource
    10. private RedisTemplate redisTemplate;
    11. // restful风格
    12. @PostMapping("/redis/template/{key}/{value}")
    13. public String addByRedisTemplate(@PathVariable String key, @PathVariable String value){
    14. // 使用使用RedisTemplate添加数据
    15. redisTemplate.opsForValue().set(key,value);
    16. return "使用RedisTemplate添加数据";
    17. }
    18. }

    发送请求,进行数据的存储 

     通过key取出value数据;无论是key还是value可读性都很差!

    第二种:使用StringRedisTemplate存储数据

    1. package com.zl.controller;
    2. import org.springframework.data.redis.core.StringRedisTemplate;
    3. import org.springframework.web.bind.annotation.PathVariable;
    4. import org.springframework.web.bind.annotation.PostMapping;
    5. import org.springframework.web.bind.annotation.RestController;
    6. import javax.annotation.Resource;
    7. @RestController
    8. public class ControllerRedis {
    9. @Resource
    10. private StringRedisTemplate stringRedisTemplate;
    11. @PostMapping("/redis/template/{key}/{value}")
    12. public String addByStringRedisTemplate(@PathVariable String key, @PathVariable String value){
    13. // 使用使用stringRedisTemplate添加数据
    14. stringRedisTemplate.opsForValue().set(key,value);
    15. return "使用stringRedisTemplate添加数据";
    16. }
    17. }

    发送请求,进行数据的存储

      通过key取出value数据;无论是key还是value都很直观,可读性好

    对比 StringRedisTemplate 和 RedisTemplate

    StringRedisTemplate:把k,v 都是作为String类型处理,使用的是String的序列化 ,可读性好。

    RedisTemplate: 把k,v 经过了序列化存到redis;k,v 是序列化后的内容, 不能直接识别,可读性差。

    (1)序列化定义

    序列化:把对象转化为可传输的字节序列过程称为序列化。

    反序列化:把字节序列还原为对象的过程称为反序列化。

    注:默认使用的jdk序列化, 可以修改为其它的序列化!

    (2)为什么需要序列化?

    序列化最终的目的是为了对象可以跨平台存储,和进行网络传输!而我们进行跨平台存储和网络传输的方式就是IO,而我们的IO支持的数据格式就是字节数组。我们必须在把对象转成字节数组的时候就制定一种规则(序列化),那么我们从IO流里面读出数据的时候再以这种规则把对象还原回来(反序列化)。

    (3)序列化的方式

    序列化只是一种拆装组装对象的规则,那么这种规则肯定也可能有多种多样,比如现在常见的序列化方式有:JDK(不支持跨语言)、JSON(常用)、XML、Hessian、Kryo(高性能)、Thrift、Protofbuff。

    java的序列化:把java对象转为byte[], 二进制数据。

    json序列化:json序列化功能将对象转换为 JSON 格式或从 JSON 格式转换对象。例如把一个Student对象转换为JSON字符串{"name":"李四", "age":29} ),反序列化(将JSON字符串 {"name":"李四", "age":29} 转换为Student对象)

    (4)设置RedisTemplate或者StringRedisTemplate的序列化方式

    注:默认采用的是JDK的序列化机制,引入spring-boot-starter-data-redis依赖后由SpringBoot创建RedisTemplate或者StringRedisTemplate对象!可以设置Key的序列化,可以设置value的序列化,也可以同时设置。

    1. package com.zl.controller;
    2. import org.springframework.data.redis.core.RedisTemplate;
    3. import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
    4. import org.springframework.data.redis.serializer.StringRedisSerializer;
    5. import org.springframework.web.bind.annotation.PostMapping;
    6. import org.springframework.web.bind.annotation.RestController;
    7. import javax.annotation.Resource;
    8. @RestController
    9. public class RedisController {
    10. @Resource
    11. private RedisTemplate redisTemplate;
    12. @PostMapping("/redis/addrstr")
    13. public String addString(String key,String value){
    14. // 修改序列化方式
    15. // 设置key,value为String的序列化
    16. redisTemplate.setKeySerializer(new StringRedisSerializer());
    17. redisTemplate.setValueSerializer(new StringRedisSerializer());
    18. // 存数据
    19. redisTemplate.opsForValue().set(key,value);
    20. return "定义RedisTemplate对象的key,value的序列化";
    21. }
    22. }

    调用setKeySerializer设置key的序列化,参数是RedisSerializer接口对象

    这个接口有很多实现类,其中一个就是默认采用的JDK序列化。

    总结:实际上RedisTemplate使用范围比StringRedisTemplate要大。后者采用的就是String的序列化,专门用来处理字符串的。前者比较通用比如当前是一个Java对象,就需要使用RedisTemplate,然后修改序列化的方式即可!

    (5) json序列化

    第一步:准备一个可序列化的Java类,设置IDEA自动生成

    如果我们不想手动输入序列化版本号,想让IDEA自动给我们生成一个怎们办呢?需要进行设置:File--->Settings--->Editor--->Code Style--->Inspections--->JVM languages--->把下面这个打上对勾--->Apply--->OK最终回到我们继承Serializable接口的类名上,alt+Enter即可自动生成序列版本号!

    1. package com.zl.pojo;
    2. import java.io.Serializable;
    3. public class Student implements Serializable {
    4. private static final long serialVersionUID = -8589050940385007834L;
    5. private Integer id;
    6. private String name;
    7. private Integer age;
    8. public Student() {
    9. }
    10. public Student(Integer id, String name, Integer age) {
    11. this.id = id;
    12. this.name = name;
    13. this.age = age;
    14. }
    15. public Integer getId() {
    16. return id;
    17. }
    18. public void setId(Integer id) {
    19. this.id = id;
    20. }
    21. public String getName() {
    22. return name;
    23. }
    24. public void setName(String name) {
    25. this.name = name;
    26. }
    27. public Integer getAge() {
    28. return age;
    29. }
    30. public void setAge(Integer age) {
    31. this.age = age;
    32. }
    33. }

    第二步:把Java对象以json格式存储到redis

    1. package com.zl.controller;
    2. import com.zl.pojo.Student;
    3. import org.springframework.data.redis.core.RedisTemplate;
    4. import org.springframework.data.redis.core.ValueOperations;
    5. import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
    6. import org.springframework.data.redis.serializer.StringRedisSerializer;
    7. import org.springframework.web.bind.annotation.PostMapping;
    8. import org.springframework.web.bind.annotation.RestController;
    9. import javax.annotation.Resource;
    10. @RestController
    11. public class RedisController {
    12. @Resource
    13. private RedisTemplate redisTemplate;
    14. // Java对象序列化为json格式
    15. @PostMapping("/redis/addjson")
    16. public String javaBeanToJson(){
    17. Student student = new Student(100,"zhangsan",20);
    18. // key使用String的序列化
    19. redisTemplate.setKeySerializer(new StringRedisSerializer());
    20. // value使用json的序列化
    21. redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer(Student.class));
    22. // 存储到redis当中
    23. ValueOperations valueOperations = redisTemplate.opsForValue();
    24. valueOperations.set("mystudent",student);
    25. return "json序列化";
    26. }
    27. }

    第三步:postman进行访问

    成功存储后,使用redis的图形化界面进行查看

    第四步:进行反序列化

    1. // 反序列化
    2. @PostMapping("/redis/getjson")
    3. public String JsonTojavaBean(){
    4. // key使用String的序列化
    5. redisTemplate.setKeySerializer(new StringRedisSerializer());
    6. // value使用json的序列化
    7. redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer(Student.class));
    8. // 进行反序列化
    9. Object obj = redisTemplate.opsForValue().get("mystudent");
    10. return "json反序列化="+obj;
    11. }

    成功反序列化为Java对象

    图书推荐:《MySQL 8查询性能优化》

    参与方式:

    本次送书 2 本! 
    活动时间:截止到 2023-09-21 00:00:00。

    抽奖方式:利用程序进行抽奖。

    参与方式:关注博主(只限粉丝福利哦)、点赞、收藏,评论区随机抽取,最多三条评论!

    推荐理由

            性能不佳的查询将影响用户的体验,导致业务收入下降;本书将帮助你在日常工作中更好地识别、分析和改进此类查询。本书详述涉及多个步骤的处理过程,包括监控查询执行时间、识别需要优化的查询、分析当前的性能表现以及进行优化等,还介绍相关的数据源和工具,帮助你更快地提交结果,降低系统开销。

      《MySQL 8查询性能优化》描述多种可提升查询性能的策略,讲述如何使用传统的EXPLAIN命令以及新的EXPLAIN ANALYZE工具来分析查询、如何使用Visual Explain功能来获得执行计划的可视化视图、如何用直方图获得关于“桶”数据的分布信息。此外,将介绍锁以及解决锁问题的相关知识;讨论MySQL优化器的工作原理,包括新的哈希联接算法,以及在必要时改变优化器行为来缩短查询的执行时间。通过本书,你将掌握必备技术,能用合适工具提高用户满意度,从公司的计算资源中获取更大价值。

    内容简介:

    主要内容
    ● 监控性能,找出效果不佳的查询;
    ● 选取要优化的查询,**限度地提高收益;
    ● 使用EXPLAIN ANALYZE和Visual Explain等工具来分析查询;
    ● 借助多种策略改进慢查询;
    ● 正确使用索引和直方图,创建快速的执行计划;
    ● 了解并分析锁,从而解决争用问题,提升系统吞吐量; 

    京东购买链接MySQL 8查询性能优化【图片 价格 品牌 评论】-京东 

  • 相关阅读:
    2023-09-10力扣每日一题
    【Spring Cloud】教你十分钟学会Gateway~
    Integrator积分器测试(Simulink仿真)
    vscode使用code runner乱码
    最优化方法——QR分解
    绿盟科技阮博男:从开源靶场看云原生安全
    CUDA编程1--GPU内存模型
    什么是微服务架构
    【第一阶段:java基础】第8章:面向对象编程高级-2(P394-P423)final、抽象类、接口、内部类
    【rust】| 06——语言特性 | 所有权
  • 原文地址:https://blog.csdn.net/m0_61933976/article/details/129385457