SpringBoot 2X 整合redis json序列化

SpringBoot 2X 整合redis json序列化

环境搭建

pringboot 2x+redis 2.8.9

导入依赖(pom.xml)
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>


        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.lmh</groupId>
    <artifactId>spring-boot-07</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>spring-boot-07</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-cache</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.3</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

其中mybatis的starter和mysql依赖为了测试
导入redis的starter后

  1. 启动Redis
    在这里插入图片描述
  2. 启动redis可视化工具 Redis Desktop Manager (可以去下载,熟悉命令可以不用,可视化工具方便操作)连接redis
  3. 配置全局配置文件application.properties或application.yaml
spring:
  datasource:
    username: root
    password: xxxxx
    url: jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8&serverTimezone=GMT%2B8&useSSL=false
    driver-class-name: com.mysql.cj.jdbc.Driver
  redis:
    host: 127.0.0.1

上配置mysql数据源,redis host 的值取决于你连接的Redis服务器ip地址,可自定义修改

4.根据需要自定义redisConfig配置类

自定义配置类修改序列化

阅读RedisAutoConfiguration源码
/*
 * Copyright 2012-2019 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.boot.autoconfigure.data.redis;

import java.net.UnknownHostException;

import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisOperations;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.StringRedisTemplate;

/**
 * {@link EnableAutoConfiguration Auto-configuration} for Spring Data's Redis support.
 *
 * @author Dave Syer
 * @author Andy Wilkinson
 * @author Christian Dupuis
 * @author Christoph Strobl
 * @author Phillip Webb
 * @author Eddú Meléndez
 * @author Stephane Nicoll
 * @author Marco Aust
 * @author Mark Paluch
 * @since 1.0.0
 */
@Configuration(proxyBeanMethods = false)
@ConditionalOnClass(RedisOperations.class)
@EnableConfigurationProperties(RedisProperties.class)
@Import({ LettuceConnectionConfiguration.class, JedisConnectionConfiguration.class })
public class RedisAutoConfiguration {

	@Bean
	@ConditionalOnMissingBean(name = "redisTemplate")
	public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory)
			throws UnknownHostException {
		RedisTemplate<Object, Object> template = new RedisTemplate<>();
		template.setConnectionFactory(redisConnectionFactory);
		//redisConnectionFactory里默认的序列化为jdk
		return template;
	}

	@Bean
	@ConditionalOnMissingBean
	public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory)
			throws UnknownHostException {
		StringRedisTemplate template = new StringRedisTemplate();
		template.setConnectionFactory(redisConnectionFactory);
		return template;
	}

}

提供了RedisTemplate操作数据,redisConnectionFactory提供set方法可以修改序列化机制,springboot starter导入了json则可配置

json序列化配置类
@Configuration
public class RedisConfig {
    /**
     * 可根据自己的需要改其泛型,和序列化器,使数据可以json形式序列化保存到javabean,javabean中要继承接口Serializable 
     *
     * @param redisConnectionFactory
     * @return
     * @throws UnknownHostException
     */
    @Bean
    public RedisTemplate<Object, Object> myRedisTemplate(RedisConnectionFactory redisConnectionFactory)
            throws UnknownHostException {
        RedisTemplate<Object, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(redisConnectionFactory);
        Jackson2JsonRedisSerializer<Object> objectJackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class);
       template.setDefaultSerializer(objectJackson2JsonRedisSerializer);//修改默认setDefaultSerializer序列化工具
        return template;
    }

    /**
     * 将数据写入redis中转为json,解决序列化问题的配置
     * 作用有可以在可视化redis中以json数据格式存储,解决了序列化乱码的问题
     *可以自定义序列化,将其fromSerializer(jackson2JsonRedisSerializer)改成想要的序列化类
     * @param redisConnectionFactory
     * @return
     */
    @Bean
    RedisCacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);

        //解决查询缓存转换异常的问题
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);

        //配置序列化(解决乱码的问题)
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ZERO)
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                .disableCachingNullValues();

        RedisCacheManager cacheManager = RedisCacheManager.builder(redisConnectionFactory)
                .cacheDefaults(config)
                .build();
        return cacheManager;

    }
}

原理:CacheManager==Cache 缓存组件来实际缓存中存取数据

  •      1.引入redis的starter,容器中保存的是RedisCacheManager
    
  •      2.RedisCacheManager创建RedisCache来作为缓存组件,RedisCache操作redis数据库
    
  •      3.默认保存数据k-v都是Object,利用序列化保存;如何保存json
    
  •              引入redis的Starter,CacheManager变为RedisCacheManager
    
  •              默认创建的RedisCacheManager操作redis时利用的是RedisTemplate<Object,Object>默认为jdk序列化机制
    
  •              自己配置RedisCacheManager,让系统使用自己写的,关键配置见上面配置类`
    

整合测试

@SpringBootTest
class SpringBoot07ApplicationTests {
    @Autowired
    private StudentMapper studentMapper;//自定义操作数据库得Mapper参与测试
    @Autowired
    private RedisTemplate redisTemplate;//操作k-v是对象的
    @Autowired
    private StringRedisTemplate stringRedisTemplate;//操作k-v是字符串的

    @Autowired
    private RedisTemplate<Object, Object> myRedisTemplate;
    /**
     * Redis常见的五大数据类型
     * String,List,Set(集合),Hash(散列表),ZSet(有序集合)
     * 操作示例:
     * stringRedisTemplate.opsForValue().append("msg","hello");
     * redisTemplate.opsForValue().append("msg","hello");
     * 其中后面命令都是redis的命令
     * opsForValue()(操作字符串)
     * opsForSet()(操作集合)
     * 。。。。等等
     * 保存对象时
     * redisTemplate.opsForValue().set("key值","对象名");
     * 其中序列化,可以自己改,默认为JdkSerializationRedisSerializer,有需要可以改,改配置件config包类
     *
     * @throws Exception
     */
    @Test
    void testRedis() throws Exception {
        stringRedisTemplate.opsForValue().append("msg", "hello");
        stringRedisTemplate.opsForValue().append("msg", "world");
        System.out.println(stringRedisTemplate.opsForValue().get("msg"));
    }

    /**
     * 测试保存对象
     * @throws Exception
     */
    @Test
    void testRedis1()throws Exception{
        Student student = studentMapper.findById(1);
        myRedisTemplate.opsForValue().set("student",student);
    }//测试代码块和注释
缓存使用

当导入redis starter 系统将会使用redis作为缓存工具
相关缓存使用文章见 springboot缓存使用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring Boot可以很方便地与Redis集成,使用RedisTemplate可以实现对Redis的操作。在使用RedisTemplate时,需要对数据进行序列化和反序列化,以便存储和读取数据。Spring Boot提供了多种序列化方式,包括JdkSerializationRedisSerializer、Jackson2JsonRedisSerializer、GenericJackson2JsonRedisSerializer等。其中,JdkSerializationRedisSerializer是默认的序列化方式,但由于其效率较低,一般不建议使用。Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer则可以将数据序列化JSON格式,效率较高,推荐使用。在使用Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer时,需要注意对象的类必须有默认的构造函数。 ### 回答2: Spring Boot 是一个快速开发框架,而 Redis 是一款高效 NoSQL 数据库,二者结合在一起可以提供更加高效的开发和运行效率。在实际应用中,往往需要使用RedisSpringBoot序列化功能来存储和读取数据。 Spring Boot 提供了一种比较友好的整合 Redis 的方式,也提供了对于 Redis 序列化功能的支持。在 SpringBoot 中,我们可以通过引入 Jedis 或 Lettuce 作为 Redis 客户端来实现对 Redis 服务的访问。 在默认情况下,SpringBoot 使用的是 JDK 序列化器来序列化数据。但是 JDK 序列化器的效率并不高,而且在某些情况下可能会出现序列化和反序列化的数据不一致问题,因此建议我们自定义 Redis 序列化器来提高效率。 SpringBoot 提供了一个 RedisTemplate 实现来进行 Redis 数据操作,同时通过配置 RedisTemplate 的 ValueSerializer 和 KeySerializer 实现自定义的序列化和反序列化功能。以下是自定义 Redis 序列化器的实现步骤: - 首先,需要定义一个实现 RedisSerializer 接口的 Redis 序列化器; - 然后,通过配置 RedisTemplate 的 ValueSerializer 和 KeySerializer 来设置 Redis 序列化器; - 最后,在代码中使用 RedisTemplate 进行 Redis 数据操作即可。 以下是一个 Redis 序列化器的简单示例: public class RedisObjectSerializer implements RedisSerializer<Object> { private Converter<Object, byte[]> serializer = new SerializingConverter(); private Converter<byte[], Object> deserializer = new DeserializingConverter(); @Override public byte[] serialize(Object obj) throws SerializationException { if (obj == null) { return new byte[0]; } return serializer.convert(obj); } @Override public Object deserialize(byte[] bytes) throws SerializationException { if (bytes == null || bytes.length == 0) { return null; } return deserializer.convert(bytes); } } 以下是一个自定义 RedisTemplate 的简单示例: @Configuration public class RedisConfig { @Bean public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory connectionFactory) { RedisTemplate<Object, Object> template = new RedisTemplate<>(); template.setConnectionFactory(connectionFactory); template.setKeySerializer(new StringRedisSerializer()); template.setValueSerializer(new RedisObjectSerializer()); return template; } } 在进行 Redis 数据操作时,我们可以使用 RedisTemplate 对象来进行操作,如下所示: @Autowired private RedisTemplate<Object, Object> redisTemplate; public void setData(String key, Object value) { redisTemplate.opsForValue().set(key, value); } public Object getData(String key) { return redisTemplate.opsForValue().get(key); } 总之,自定义 Redis 序列化器是为了提高 Redis 的运行效率和数据传输速率,也能够避免出现数据不一致问题。在 SpringBoot 中,只需要通过配置 RedisTemplate 的 ValueSerializer 和 KeySerializer 即可完成 Redis 序列化器的自定义配置。 ### 回答3: SpringBoot 是一款非常方便的框架,可以简化企业级应用程序的开发。它已经集成了大量常用的组件,Redis 是其中一个非常常用的缓存组件。本文将介绍如何在 SpringBoot整合 Redis 缓存,并且使用序列化进行存储。 Redis 是一款基于 key-value 存储的 NoSQL 数据库,它是一个开源的高性能 Key-Value 数据库。在 Redis 中,key 和 value 都是一个二进制的字符串。因此,在存取数据时,可以通过序列化和反序列化将对象转换成字符串类型然后进行存储和读取。 使用 Redis 缓存时,我们可以使用 SpringBoot 的自动配置来集成 Redis 缓存。SpringBoot 提供了一个 starter,也就是 Redis Starter,集成了 jedis 和 lettuce 两种 Redis 客户端,可以轻松实现对 Redis 的自动配置和启动。 在使用 Redis 缓存时,需要使用序列化将需要缓存的对象转换为字符串,然后将其存入 Redis 中。SpringBoot 支持多种序列化方式,包括 JDK 序列化、gson、Jackson、fastjson 等。其中,JSON 序列化是最常用的一种方式,因为它具有良好的可读性和可扩展性。 SpringBoot 提供了一个 RedisTemplate 类,使我们可以轻松地访问 Redis 的 API。在使用 RedisTemplate 时,需要指定序列化方式,如果我们要使用 JSON 序列化,可以在 RedisTemplate 的配置中添加以下内容: ``` @Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(redisConnectionFactory); template.setKeySerializer(new StringRedisSerializer()); template.setValueSerializer(new GenericJackson2JsonRedisSerializer()); template.setHashKeySerializer(new StringRedisSerializer()); template.setHashValueSerializer(new GenericJackson2JsonRedisSerializer()); template.afterPropertiesSet(); return template; } } ``` 在上面的配置中,我们首先定义了一个 RedisTemplate bean,它将使用 String 作为 key,Object 作为 value。然后,我们将 RedisConnectionFactory 注入 RedisTemplate 中,并设置了默认的序列化器为 GenericJackson2JsonRedisSerializer。 以上就是整合 Redis 序列化的步骤。在对需要缓存的数据进行序列化的时候,需要注意序列化的时效性和数据的更新策略。如果数据量过大,需要考虑 Redis 的缓存清理机制以及缓存命中率等问题。希望本文对大家有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值