20-Redis 事务处理实践,字节跳动历年校招Java面试真题解析

基本指令


redis进行事务控制时,通常是基于如下指令进行实现,例如:

  • multi 开启事务

  • exec 提交事务

  • discard 取消事务

  • watch 监控,如果监控的值发生变化,则提交事务时会失败

  • unwatch 去掉监控

Redis保证一个事务中的所有命令要么都执行,要么都不执行(原子性)。如果在发送EXEC命令前客户端断线了,则Redis会清空事务队列,事务中的所有命令都不会执行。而一旦客户端发送了EXEC命令,所有的命令就都会被执行,即使此后客户端断线也没关系,因为Redis中已经记录了所有要执行的命令。

Redis事务控制实践

=====================================================================

exec提交事务


例如:模拟转账,tony 500,jack 200,tony转给jack100。过程如下:

127.0.0.1:6379> set tony 500

OK

127.0.0.1:6379> set jack 200

OK

127.0.0.1:6379> mget tony jack

  1. “500”

  2. “200”

127.0.0.1:6379> multi #开启事务

OK

127.0.0.1:6379(TX)> decrby tony 100 #所有指令操作会进入到队列

QUEUED

127.0.0.1:6379(TX)> incrby jack 100

QUEUED

127.0.0.1:6379(TX)> mget tony jack

QUEUED

127.0.0.1:6379(TX)> exec #提交事务

  1. (integer) 400

  2. (integer) 300

    1. “400”
  3. “300”

127.0.0.1:6379> mget tony jack

  1. “400”

  2. “300”

127.0.0.1:6379>

discard取消事务


注意redis事务太简单,没有回滚,而只有取消。

127.0.0.1:6379> mget tony jack

  1. “400”

  2. “300”

127.0.0.1:6379> multi

OK

127.0.0.1:6379> incrby jack 100

QUEUED

127.0.0.1:6379> discard

OK

127.0.0.1:6379> get jack

“300”

127.0.0.1:6379> exec

(error) ERR EXEC without MULTI

当出现错误指令时,事务也会自动取消。

127.0.0.1:6379> mget tony jack

  1. “400”

  2. “300”

127.0.0.1:6379> multi

OK

127.0.0.1:6379(TX)> incrby jack 100

QUEUED

127.0.0.1:6379(TX)> abcd

(error) ERR unknown command abcd, with args beginning with:

127.0.0.1:6379(TX)> get jack

QUEUED

127.0.0.1:6379(TX)> exec

(error) EXECABORT Transaction discarded because of previous errors.

127.0.0.1:6379> get jack

“300”

127.0.0.1:6379>

秒杀抢票事务处理


基于一个秒杀,抢购案例,演示redis乐观锁方式,例如

第一步:打开客户端1,执行如下操作

127.0.0.1:6379> set ticket 1

OK

127.0.0.1:6379> set money 0

OK

127.0.0.1:6379> watch ticket #乐观锁,对值进行观察,改变则事务失败

OK

127.0.0.1:6379> multi #开启事务

OK

127.0.0.1:6379> decr ticket

QUEUED

127.0.0.1:6379> incrby money 100

QUEUED

第二步:打开客户端2,执行如下操作,演示还没等客户端1提交事务,此时客户端2把票买到了。

127.0.0.1:6379> get ticket

“1”

127.0.0.1:6379> decr ticket

(integer) 0

第三步,回到客户端1:提交事务,检查ticket的值

127.0.0.1:6379> exec

(nil) #执行事务,失败

127.0.0.1:6379> get ticket

“0”

127.0.0.1:6379> unwatch #取消监控

Jedis 客户端事务操作


基于Jedis进行事务测试,代码如下:

package com.jt;

import org.junit.Test;

import redis.clients.jedis.Jedis;

import redis.clients.jedis.Transaction;

public class JedisTransactionTests {

@Test

public void testTransaction(){

Jedis jedis=new Jedis(“192.168.126.130”,6379);

jedis.auth(“123456”);

jedis.set(“tony”,“300”);

jedis.set(“jack”,“500”);

//实现操作,tony转账100给jack

//开启事务

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

最后

这份《“java高分面试指南”-25分类227页1000+题50w+字解析》同样可分享给有需要的朋友,感兴趣的伙伴们可挑战一下自我,在不看答案解析的情况,测试测试自己的解题水平,这样也能达到事半功倍的效果!(好东西要大家一起看才香)

image

image

义、实战项目、讲解视频,并且后续会持续更新**

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-ZrrFzwZQ-1711895739513)]

最后

这份《“java高分面试指南”-25分类227页1000+题50w+字解析》同样可分享给有需要的朋友,感兴趣的伙伴们可挑战一下自我,在不看答案解析的情况,测试测试自己的解题水平,这样也能达到事半功倍的效果!(好东西要大家一起看才香)

[外链图片转存中…(img-6QKgHN6W-1711895739513)]

[外链图片转存中…(img-jmyFfAKc-1711895739513)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值