当前位置: 首页 > article >正文

【Spring连载】使用Spring Data访问Redis(十一)----Redis事务 Transactions

【Spring连载】使用Spring Data访问Redis(十一)----Redis事务 Transactions

  • @Transactional 支持

Redis通过multi, exec 和 discard命令为事务提供支持。RedisTemplate上提供了这些操作。但是,RedisTemplate不能保证使用相同的连接运行事务中的所有操作。
Spring Data Redis提供了SessionCallback接口,以便在需要使用同一连接执行多个操作时使用,例如在使用Redis事务时。以下示例使用multi方法:

//execute a transaction
List<Object> txResults = redisOperations.execute(new SessionCallback<List<Object>>() {
  public List<Object> execute(RedisOperations operations) throws DataAccessException {
    operations.multi();
    operations.opsForSet().add("key", "value1");

    // This will contain the results of all operations in the transaction
    return operations.exec();
  }
});
System.out.println("Number of items added to set: " + txResults.get(0));

RedisTemplate使用它的value、hash key和hash value序列化器在返回之前对exec的所有结果进行反序列化。还有一个额外的exec方法,它允许你为事务结果传递自定义序列化器。

@Transactional 支持

默认情况下,RedisTemplate不参与Spring事务。如果你希望RedisTemplate在使用@Transactional或TransactionTemplate时使用Redis事务,则需要通过设置setEnableTransactionSupport(true)来显式启用对每个RedisTemplate的事务支持。启用事务支持将RedisConnection绑定到ThreadLocal支持的当前事务。如果事务完成时没有出现错误,Redis事务将使用EXEC提交,否则将使用DISCARD回滚。Redis事务是面向批(batch-oriented)的。在正在进行的事务期间发出的命令将排队,并且仅在提交事务时应用。
Spring Data Redis区分正在进行的事务中的只读命令和写入命令。只读命令,如KEYS,通过管道传输到新的(非线程绑定的)RedisConnection以允许读取。写入命令由RedisTemplate排队,并在提交时应用。
以下示例显示了如何配置事务管理:
例1: 启用事务管理的配置

@Configuration
@EnableTransactionManagement   --------1                      
public class RedisTxContextConfiguration {

  @Bean
  public StringRedisTemplate redisTemplate() {
    StringRedisTemplate template = new StringRedisTemplate(redisConnectionFactory());
    // explicitly enable transaction support
    template.setEnableTransactionSupport(true);   --------2           
    return template;
  }

  @Bean
  public RedisConnectionFactory redisConnectionFactory() {
    // jedis || Lettuce
  }

  @Bean
  public PlatformTransactionManager transactionManager() throws SQLException {
    return new DataSourceTransactionManager(dataSource());   ---------3
  }

  @Bean
  public DataSource dataSource() throws SQLException {
    // ...
  }
}
1. 配置Spring上下文以启用声明性事务管理。
2.RedisTemplate配置为通过将连接绑定到当前线程来参与事务。
3. 事务管理需要PlatformTransactionManagerSpring Data Redis未附带PlatformTransactionManager实现。假设你的应用程序使用JDBCSpring Data Redis可以通过使用现有的事务管理器来参与事务。

下面的例子分别演示了一个用法约束:
例2: 使用约束

// must be performed on thread-bound connection
template.opsForValue().set("thing1", "thing2");

// read operation must be run on a free (not transaction-aware) connection
template.keys("*");

// returns null as values set within a transaction are not visible
template.opsForValue().get("thing1");

http://www.kler.cn/a/228841.html

相关文章:

  • OA-CNN:用于 3D 语义分割的全自适应稀疏 CNN
  • 深入探索 Vue.js 组件开发中的最新技术:Teleport 和 Suspense 的使用
  • 【青蛙过河——思维】
  • protobuf: 通讯录3.1
  • cuda + cudnn安装
  • 图数据库 | 19、高可用分布式设计(下)
  • 关于可变类型和不可变类型的探究
  • MacOS系统电脑远程桌面控制windows系统电脑【内网穿透】
  • AI监控+智能充电桩系统如何缓解新能源汽车充电难问题
  • nginx去掉前端配置的路径前缀
  • C++ 动态规划 最长上升子序列2 朴素做法的优化
  • MySQL核心查询语句详解
  • Unity类银河恶魔城学习记录1-11 PlayerPrimaryAttack P38
  • RK3588开发板Ubuntu与开发板使用U盘互传
  • 【Linux】生产者消费者模型
  • 静态库和动态库
  • vue全屏,退出全屏、监听ESC退出全屏
  • 01背包问题 动态规划
  • CAN通信----(创芯科技)CAN分析仪----转CANTest使用
  • 2024年2月CCF-全国精英算法大赛题目
  • 前端面试题——Vue的双向绑定
  • <网络安全>《16 网络安全隔离与信息单向导入系统》
  • 计算机视觉实战项目3(图像分类+目标检测+目标跟踪+姿态识别+车道线识别+车牌识别+无人机检测+A*路径规划+单目测距与测速+行人车辆计数等)
  • 【HarmonyOS应用开发】Web组件的使用(十三)
  • 壹[1],Xamarin开发环境配置
  • linux的nginx安装