Redis的事务管理

redis也支持事务,但与MySQL等关系型数据库相比,redis的事务比较简单。

一、redis事务的特点
1、redis的事务是一组命令集合

    可以把redis的事务看成一个命令的缓存,把一组要执行的命令添加到集合中,然后按顺序一起执行。

2、redis事务没有隔离级别

    由于redis是单线程的,下一个命令必须在上一个命令完成后才会执行。因此不会有多个事务同时执行的情况,因此也就不需要定义隔离级别。

3、redis事务不保证原子性

    redis的单条命令是保证原子性的,但是事务不保证原子性,即事务中某个命令的失败不会影响其它命令的执行和结果。

二、事务的实现步骤
1、开启事务

multi命令用于开启一个事务,此命令没有参数

2、添加命令

    编写要执行的数据库操作命令

3、执行事务或取消事务

1)使用exec命令执行事务

示例

multi
set str1   '字符串1'
set str2 '字符串2'
exec

2)使用discard命令取消事务

multi
set str1 '字符串1'
set str2 '字符串2'
discard

三、事务监听
    事务监听可以用于做为事务锁(乐观锁)使用,当另一个程序修改了某个key的值时,当前事务会被中断执行。

1、开启监听

    在事务创建之前使用watch命令可以监听key的变化,当使用exec开始执行事务时,会检查被监听的key是否有变化,如果有变化,则中断事务的执行。

语法

watch key [key...]

2、取消监听

    当事务已开始执行或是取消,则会自动取消监听,也可以使用unwatch命令手动结束监听。

示例

watch str1

multi

set str1 '字符串1'
unwatch //取消监听,后面必须还有语句,否则无效
set str2 '字符串2'
exec       //因在执行前修改了str1的值,执行会被中断

//在另一个命令行窗口执行以下命令,此命令需要在exec之前执行
set str1 '字符串11'
 

 文章来源于哔站《Redis的事务管理

更多学习视频和专栏文章请到哔站个人空间: 布道师学院的个人空间-布道师学院个人主页-哔哩哔哩视频

更多资源和项目下载请到:”开源吧(找实战项目和毕设项目的好网站)“ ​ :开源吧

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Redis事务和Java事务进行绑定,需要使用Spring的声明式事务管理。下面是一个简单的示例: 首先,需要在Spring的配置文件中定义RedisTemplate对象,并配置事务管理器: ```xml <!-- 配置 RedisTemplate --> <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"> <property name="connectionFactory" ref="jedisConnectionFactory"/> <property name="keySerializer" ref="stringRedisSerializer"/> <property name="valueSerializer" ref="jackson2JsonRedisSerializer"/> </bean> <!-- 配置 Redis 事务管理器 --> <bean id="redisTransactionManager" class="org.springframework.data.redis.transaction.RedisTransactionManager"> <constructor-arg ref="jedisConnectionFactory"/> </bean> ``` 然后,在需要执行事务的方法上添加@Transactional注解,告诉Spring该方法需要在事务中执行,并指定事务管理器: ```java @Service public class UserServiceImpl implements UserService { @Autowired private RedisTemplate<String, Object> redisTemplate; @Transactional(value = "redisTransactionManager") @Override public void updateUser(User user) { // 在 Redis 事务中执行命令 redisTemplate.opsForValue().set("user:" + user.getId(), user); // 在 Java 事务中执行命令 userDao.updateUser(user); } } ``` 在上述代码中,@Transactional注解指定了事务管理器为redisTransactionManager,表示该方法需要在Redis事务中执行。在方法执行过程中,如果出现异常,Spring会自动回滚Java事务,并根据Redis事务的执行状态来决定是否回滚Redis事务。 需要注意的是,为了确保Redis事务和Java事务的一致性,我们需要在同一线程中执行它们。因此,在方法执行过程中,我们需要使用TransactionSynchronizationManager将当前线程和事务进行绑定。另外,为了避免事务的嵌套,我们需要将Redis事务和Java事务都设置为PROPAGATION_REQUIRES_NEW级别。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

爱分享的代码君

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

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

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

打赏作者

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

抵扣说明:

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

余额充值