JAVA SpringBoot中使用redis的事务

文章介绍了如何在SpringBoot项目中,为使用事务和不使用事务的Redis操作创建单独的RedisTemplate实例,以及如何配置RedisConnectionFactory和事务完整执行流程。
摘要由CSDN通过智能技术生成

1、自定义redisConfig , 如果项目中要使用redis事务,最好将用事务和不用事务的redis分开。


@Configuration
public class RedisConfig {

    @Resource
    private RedisProperties redisProperties;


    @Bean("redisTemplate")
    public RedisTemplate<String, Object> redisTemplate() {
        RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(redis1ConnectionFactory());

        GenericJackson2JsonRedisSerializer genericJackson2JsonRedisSerializer = new GenericJackson2JsonRedisSerializer();
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setValueSerializer(genericJackson2JsonRedisSerializer);
        redisTemplate.setHashKeySerializer(genericJackson2JsonRedisSerializer);
        redisTemplate.setHashValueSerializer(genericJackson2JsonRedisSerializer);
        redisTemplate.afterPropertiesSet();

        return redisTemplate;
    }

    @Bean("redisTransactionTemplate")
    public RedisTemplate<String, Object> redisTransactionTemplate() {
        RedisTemplate<String, Object> redisTransactionTemplate = new RedisTemplate<>();
        redisTransactionTemplate.setConnectionFactory(redis2ConnectionFactory());

        GenericJackson2JsonRedisSerializer genericJackson2JsonRedisSerializer = new GenericJackson2JsonRedisSerializer();
        redisTransactionTemplate.setKeySerializer(new StringRedisSerializer());
        redisTransactionTemplate.setValueSerializer(genericJackson2JsonRedisSerializer);
        redisTransactionTemplate.setHashKeySerializer(genericJackson2JsonRedisSerializer);
        redisTransactionTemplate.setHashValueSerializer(genericJackson2JsonRedisSerializer);
        redisTransactionTemplate.afterPropertiesSet();
        //开启事务
        redisTransactionTemplate.setEnableTransactionSupport(true);

        return redisTransactionTemplate;
    }

    @Bean
    @Primary
    public RedisConnectionFactory redis1ConnectionFactory() {
        RedisStandaloneConfiguration localhost = new RedisStandaloneConfiguration(redisProperties.getHost(), redisProperties.getPort());
        if(StrUtil.isNotEmpty(redisProperties.getPassword())){
            localhost.setPassword(redisProperties.getPassword());
        }
        if(Objects.nonNull(redisProperties.getDatabase())){
            localhost.setDatabase(redisProperties.getDatabase());
        }

        JedisClientConfiguration.JedisPoolingClientConfigurationBuilder jpb =
                (JedisClientConfiguration.JedisPoolingClientConfigurationBuilder) JedisClientConfiguration.builder();
        JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
        jedisPoolConfig.setMaxIdle(redisProperties.getMaxIdle());
        jedisPoolConfig.setMinIdle(redisProperties.getMinIdle());
        jedisPoolConfig.setMaxTotal(redisProperties.getMaxActive());
        jedisPoolConfig.setMaxWaitMillis(redisProperties.getMaxWait());
        jedisPoolConfig.setEvictorShutdownTimeoutMillis(redisProperties.getTimeout());
        jpb.poolConfig(jedisPoolConfig);

        return new JedisConnectionFactory(localhost,jpb.build());
    }

    @Bean
    public RedisConnectionFactory redis2ConnectionFactory() {
        RedisStandaloneConfiguration localhost = new RedisStandaloneConfiguration(redisProperties.getHost(), redisProperties.getPort());
        if(StrUtil.isNotEmpty(redisProperties.getPassword())){
            localhost.setPassword(redisProperties.getPassword());
        }
        if(Objects.nonNull(redisProperties.getDatabase())){
            localhost.setDatabase(redisProperties.getDatabase());
        }

        JedisClientConfiguration.JedisPoolingClientConfigurationBuilder jpb =
                (JedisClientConfiguration.JedisPoolingClientConfigurationBuilder) JedisClientConfiguration.builder();
        JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
        jedisPoolConfig.setMaxIdle(redisProperties.getMaxIdle());
        jedisPoolConfig.setMinIdle(redisProperties.getMinIdle());
        jedisPoolConfig.setMaxTotal(redisProperties.getMaxActive());
        jedisPoolConfig.setMaxWaitMillis(redisProperties.getMaxWait());
        jedisPoolConfig.setEvictorShutdownTimeoutMillis(redisProperties.getTimeout());
        jpb.poolConfig(jedisPoolConfig);

        return new JedisConnectionFactory(localhost,jpb.build());
    }

}

@Order(value = 1)
@Data
@Component
public class RedisProperties {

    @Value("${spring.redis.host}")
    private String host;

    @Value("${spring.redis.port}")
    private Integer port;

    @Value("${spring.redis.password}")
    private String password;

    @Value("${spring.redis.database}")
    private Integer database;

    @Value("${spring.redis.timeout}")
    private Integer timeout;

    @Value("${spring.redis.lettuce.pool.max-idle}")
    public Integer maxIdle;

    @Value("${spring.redis.lettuce.pool.min-idle}")
    public Integer minIdle;

    @Value("${spring.redis.lettuce.pool.max-active}")
    public Integer maxActive;

    @Value("${spring.redis.lettuce.pool.max-wait}")
    public Integer maxWait;



}

需要事务的注入 

@Resource(name = "redisTransactionTemplate")

不需要事务的注入

@Resource(name = "redisTemplate")

事务完整执行流程

redisTransactionTemplate.multi();   //开启
redisTransactionTemplate.exec();  //执行
redisTransactionTemplate.discard();  //取消

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
你好!对于Spring BootRedis的整合,你可以按照以下步骤进行操作: 1. 添加Spring BootRedis的依赖:在你的项目的pom.xml文件添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 2. 配置Redis连接信息:在你的application.properties(或application.yml)文件添加以下配置: ```properties spring.redis.host=your_redis_host spring.redis.port=your_redis_port ``` 3. 创建Redis配置类:创建一个Redis的配置类,用于配置连接池和RedisTemplate等相关信息。可以参考以下示例: ```java @Configuration @EnableCaching public class RedisConfig { @Bean public RedisConnectionFactory redisConnectionFactory() { RedisStandaloneConfiguration config = new RedisStandaloneConfiguration(); config.setHostName("your_redis_host"); config.setPort(your_redis_port); return new LettuceConnectionFactory(config); } @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); template.setConnectionFactory(factory); template.setKeySerializer(new StringRedisSerializer()); template.setValueSerializer(new GenericJackson2JsonRedisSerializer()); return template; } } ``` 4. 使用Redis缓存数据:在需要使用Redis缓存数据的地方,可以使用`@Cacheable`、`@CachePut`等注解来实现。例如: ```java @Service public class MyService { @Autowired private RedisTemplate<String, Object> redisTemplate; @Cacheable(value = "myCache", key = "#id") public Object getDataFromCache(String id) { // 从其他数据源获取数据 // ... return data; } @CachePut(value = "myCache", key = "#id") public Object updateDataInCache(String id, Object newData) { // 更新数据到其他数据源 // ... return newData; } } ``` 这样就完成了Spring BootRedis的整合。你可以根据自己的需求,进一步使用Redis的其他功能,比如发布订阅、事务等。希望对你有帮助!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

运筹帷幄的梦想家Sir

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值