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

进行反序列化

相关推荐
weixin_704266054 小时前
SpringBoot全注解开发指南
java·spring boot·mybatis
Rsun045514 小时前
Redis中实现访问量计数
数据库·redis·缓存
想打游戏的程序猿5 小时前
核心概念层——深入理解 Agent 是什么
后端·ai编程
woniu_maggie6 小时前
SAP Web Service日志监控:如何用SRT_UTIL快速定位接口问题
后端
一线大码6 小时前
Java 使用国密算法实现数据加密传输
java·spring boot·后端
Rust语言中文社区6 小时前
【Rust日报】用 Rust 重写的 Turso 是一个更好的 SQLite 吗?
开发语言·数据库·后端·rust·sqlite
在屏幕前出油7 小时前
06. FastAPI——中间件
后端·python·中间件·pycharm·fastapi
摇滚侠8 小时前
限流的方法,Redis 计算器限流算法、滑动时间窗口限流算法、漏漏桶限流算法、令牌桶限流算法,Java 开发
java·数据库·redis
wuqingshun3141598 小时前
说一下spring的bean的作用域
java·后端·spring