配置SpringBoot

  • 创建SpringBoot项目时勾选Redis起步依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
  • 在程序中主要使用RedisTemplate类的方法操作redis数据。实际就是调用lettuce客户端库中的方法

  • 在application.properties文件中配置Redis服务的信息
#配置springboot服务信息
server.port=9090
server.servlet.context-path=/myredis #springboot中redis相关配置
spring.redis.host=127.0.0.1
spring.redis.port=6379

StringRedisTemplate 和 RedisTemplate

两者对比

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

  • RedisTemplate:把k,v 经过了序列化存到redis。 k,v 是序列化的内容,不能直接识别。默认使用的jdk序列化,可以修改为其他的序列化方式

序列化

为什么要序列化

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

序列化和反序列化

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

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

何时需要序列化

  • 凡是需要进行“跨平台存储”和”网络传输”的数据,都需要进行序列化

  • 本质上存储和网络传输都需要经过把一个对象状态保存成一种跨平台识别的字节格式,然后其他的平台才可以通过字节信息解析还原对象信息

序列化方式

  • 序列化只是一种拆装组装对象的规则

  • 现在常见的序列化方式有:JDK(不支持跨语言)、JSON、XML、Hessian、Kryo(不支持跨语言)、Thrift、Protofbuff

  • 简单的序列化示例:

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

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

代码演示

  • 创建实体类
package com.example.model;

import java.io.Serializable;

public class Food implements Serializable {
//private static final long serialVersionUID = 6071454104230624820L;
private String name;
private double price; @Override
public String toString() {
return "Food{" +
"name='" + name + '\'' +
", price=" + price +
'}';
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public double getPrice() {
return price;
} public void setPrice(double price) {
this.price = price;
} public Food(String name, double price) {
this.name = name;
this.price = price;
} public Food() {
}
}
  • 可以为实体类添加序列化版本号:将那个勾挑上

  • 光标放在实体类上,按alt + 回车,选择为实体类添加序列号

  • controller层。 演示StringRedisTemplate和RedisTemplate,以及json格式的序列化
package com.example.redis;

import com.example.model.Food;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController; import javax.annotation.Resource; @RestController
public class RedisController { @Resource
StringRedisTemplate stringRedisTemplate; @Resource
RedisTemplate redisTemplate; //使用stringRedisTemplate
@PostMapping("/student/addStu")
public String addStu(String key, String value){
stringRedisTemplate.opsForValue().set(key, value);
return "addStu,使用stringRedisTemplate操作字符串数据 key: " + key + ", value: " + value;
} @GetMapping("/student/getStu")
public String getStu(String key){
String value = stringRedisTemplate.opsForValue().get(key);
return "getStu,使用stringRedisTemplate操作字符串数据, 获取到的value: " + value;
} //使用redisTemplate
@PostMapping("/fruit/addFru")
public String addFru(String key, String value){
//设置序列化方式
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new StringRedisSerializer());
redisTemplate.opsForValue().set(key, value);
return "addFru,使用redisTemplate操作字符串数据, key: " + key + ", value: " + value;
} @GetMapping("/fruit/getFru")
public String getFru(String key){
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new StringRedisSerializer());
String value = (String) redisTemplate.opsForValue().get(key);
return "getFru,使用redisTemplate操作字符串数据, 获取到的value: " + value;
} //使用redisTemplate序列化成json格式
@PostMapping("/food/addFood")
public String addFood(String name, Double price){
Food food = new Food();
food.setName(name);
food.setPrice(price);
redisTemplate.setKeySerializer(new StringRedisSerializer());
//将value序列化成json格式
redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer(Food.class));
redisTemplate.opsForValue().set("food", food);
return "addFood,使用redisTemplate序列化成json格式";
} @GetMapping("/food/getFood")
public String getFood(String name){
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer(Food.class));
//反序列化
Food food = (Food) redisTemplate.opsForValue().get(name);
return "getFood,获取到的value: " + food;
}
}

SpringBoot 06: springboot中使用redis的更多相关文章

  1. springboot(七).springboot整合jedis实现redis缓存

    我们在使用springboot搭建微服务的时候,在很多时候还是需要redis的高速缓存来缓存一些数据,存储一些高频率访问的数据,如果直接使用redis的话又比较麻烦,在这里,我们使用jedis来实现r ...

  2. 由浅入深学习springboot中使用redis

    很多时候,我们会在springboot中配置redis,但是就那么几个配置就配好了,没办法知道为什么,这里就详细的讲解一下 这里假设已经成功创建了一个springboot项目. redis连接工厂类 ...

  3. 在SpringBoot中引入Redis

    前言 之前我们只是在Spring中加入Redis用于session的存放,并没有对redis进行主动的存放,这次我们需要加入redis工具类来方便我们在实际使用过程中操作redis 已经加入我的git ...

  4. spring-boot的spring-cache中的扩展redis缓存的ttl和key名

    原文地址:spring-boot的spring-cache中的扩展redis缓存的ttl和key名 前提 spring-cache大家都用过,其中使用redis-cache大家也用过,至于如何使用怎么 ...

  5. SpringBoot中集成redis

    转载:https://www.cnblogs.com/zeng1994/p/03303c805731afc9aa9c60dbbd32a323.html 不是使用注解而是代码调用 需要在springbo ...

  6. 在SpringBoot中添加Redis

    前言 在实际的开发中,会有这样的场景.有一个微服务需要提供一个查询的服务,但是需要查询的数据库表的数据量十分庞大,查询所需要的时间很长. 此时就可以考虑在项目中加入缓存. 引入依赖 在maven项目中 ...

  7. (一)由浅入深学习springboot中使用redis

    很多时候,我们会在springboot中配置redis,但是就那么几个配置就配好了,没办法知道为什么,这里就详细的讲解一下 这里假设已经成功创建了一个springboot项目. redis连接工厂类 ...

  8. SpringBoot中使用Redis

    在SpringBoot中使用Redis,思路如下: 查询时先查Redis缓存,如果缓存中存在信息,就直接从缓存中获取. 如果缓存中没有相关信息,就去数据库中查找,查完顺便将信息存放进缓存里,以便下一次 ...

  9. 在springboot中使用redis缓存,将缓存序列化为json格式的数据

    背景 在springboot中使用redis缓存结合spring缓存注解,当缓存成功后使用gui界面查看redis中的数据 原因 springboot缓存默认的序列化是jdk提供的 Serializa ...

  10. Spring-Boot项目中配置redis注解缓存

    Spring-Boot项目中配置redis注解缓存 在pom中添加redis缓存支持依赖 <dependency> <groupId>org.springframework.b ...

随机推荐

  1. 第十篇:vue.js for循环语句(大作业进行时)

    Vue.js 循环语句 <div id="app"> <ol> <li v-for="site in sites"> /*f ...

  2. Mysql 实现 向上递归查找父节点并返回树结构

    需求:通过mysql 8.0以下版本实现,一个人多角色id,一个角色对应某个节点menu_id,根节点的父节点存储为NULL, 向上递归查找父节点并返回树结构. 如果只有叶子,剔除掉; 如果只有根,只 ...

  3. 《Java基础——方法的调用》

    Java基础--方法的调用     总结: 1. 在同一个类中-- 对于静态方法,其它的静态和非静态方法都可以直接通过"方法名"或者"类名.方法名"调用它. 对 ...

  4. maxHBLT的合并&初始化&时间复杂度分析

    1. 定义 [extened binary tree] 扩充二叉树是有 external node (用来代替空子树, 也就是 nullptr) 的 binary tree. 对应地, 其他 node ...

  5. es,logstash各版本对应要求的JDK版本,操作系统对应示意图

    官网地址:https://www.elastic.co/cn/support/matrix

  6. 使用shell做http web接口,可以传递参数--废弃

    此文章废弃,参考另一篇 参考网址: https://me.jinchuang.org/archives/114.html https://www.cnblogs.com/jinchuang/p/142 ...

  7. Nginx缓存了DNS解析造成后端不通--代理

    文章转载自:https://segmentfault.com/a/1190000022365954 1 问题现象 我们使用 Nginx 的时候,经常会用到 Proxy 功能,为了方便管理,后端站点或者 ...

  8. CentOS8本地安装Redash中文版,并且配置为生产环境

    Centos8内置的Python为3.6.8版本,以下是在内置Python3.6.8基础上的安装步骤.由于安装多版本Python会导致系统底层库需要下载源码重新编译,比较麻烦,不建议在多版本Pytho ...

  9. Ant Design槽位失效

    保证数据结构中有scopedSlots: { title: 'title' }, 即包含scopedSlots属性 使用时名字应保证一致 例如: 数据结构: treeData: [  {    key ...

  10. python-数据描述与分析(1)

    数据描述与分析 在进行数据分析之前,我们需要做的事情是对数据有初步的了解,这个了解就涉及对行业的了解和对数据本身的敏感程度,通俗来说就是对数据的分布有大概的理解,此时我们需要工具进行数据的描述,观测数 ...