SpringBoot 集成 Redis

一: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配置

Redis使用是lettuce客户端

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

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

打开redis.conf修改配置

编写Controller

StringRedisTemplate 和 RedisTemplate

(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的序列化,也可以同时设置。

package com.zl.controller;

import org.springframework.data.redis.core.RedisTemplate;

import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;

import org.springframework.data.redis.serializer.StringRedisSerializer;

import org.springframework.web.bind.annotation.PostMapping;

import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

@RestController

public class RedisController {

@Resource

private RedisTemplate redisTemplate;

@PostMapping("/redis/addrstr")

public String addString(String key,String value){

// 修改序列化方式

// 设置key,value为String的序列化

redisTemplate.setKeySerializer(new StringRedisSerializer());

redisTemplate.setValueSerializer(new StringRedisSerializer());

// 存数据

redisTemplate.opsForValue().set(key,value);

return "定义RedisTemplate对象的key,value的序列化";

}

}

调用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即可自动生成序列版本号!

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

进行反序列化

相关推荐
bagadesu13 小时前
使用Docker构建Node.js应用的详细指南
java·后端
没有bug.的程序员13 小时前
Spring Cloud Gateway 性能优化与限流设计
java·spring boot·spring·nacos·性能优化·gateway·springcloud
q***718516 小时前
海康威视摄像头ISUP(原EHOME协议) 摄像头实时预览springboot 版本java实现,并可以在浏览器vue前端播放(附带源码)
java·前端·spring boot
oneslide16 小时前
Kubernetes环境部署Redis集群
redis·容器·kubernetes
勇哥java实战分享16 小时前
第一次用 Ollama 跑视觉模型:Qwen2.5-VL 7B 给了我一个意外惊喜
后端
码事漫谈17 小时前
从后端开发者到Agent工程师:一份系统性的学习指南
后端
码事漫谈18 小时前
后端开发如何将创新转化为专利?案例、流程与实操指南
后端
是垚不是土18 小时前
构建高可用Redis:哨兵模式深度解析与Nacos微服务适配实践
redis·微服务·bootstrap
KYumii18 小时前
智慧判官-分布式编程评测平台
vue.js·spring boot·分布式·spring cloud·java-rabbitmq
user_admin_god18 小时前
企业级管理系统的站内信怎么轻量级优雅实现
java·大数据·数据库·spring boot