20-Redis 事务处理实践

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

//开启事务

Transaction multi = jedis.multi();

//执行业务操作

try {

multi.decrBy(“tony”, 100);

multi.incrBy(“jack”, 100);

int n=100/0;//模拟异常

//提交事务

multi.exec();

}catch(Exception e) {

//出现异常取消事务

multi.discard();

}

String tonyMoney=jedis.get(“tony”);

String jackMoney=jedis.get(“jack”);

System.out.println(“tonyMoney=”+tonyMoney);

System.out.println(“jackMoney=”+jackMoney);

jedis.close();

}

}

Jedis 客户端秒杀操作实践


package com.jt.demos;

import redis.clients.jedis.Jedis;

import redis.clients.jedis.Response;

import redis.clients.jedis.Transaction;

Ending

Tip:由于文章篇幅有限制,下面还有20个关于MySQL的问题,我都复盘整理成一份pdf文档了,后面的内容我就把剩下的问题的目录展示给大家看一下

如果觉得有帮助不妨【转发+点赞+关注】支持我,后续会为大家带来更多的技术类文章以及学习类文章!(阿里对MySQL底层实现以及索引实现问的很多)

吃透后这份pdf,你同样可以跟面试官侃侃而谈MySQL。其实像阿里p7岗位的需求也没那么难(但也不简单),扎实的Java基础+无短板知识面+对某几个开源技术有深度学习+阅读过源码+算法刷题,这一套下来p7岗差不多没什么问题,还是希望大家都能拿到高薪offer吧。

剩下的问题的目录展示给大家看一下**

如果觉得有帮助不妨【转发+点赞+关注】支持我,后续会为大家带来更多的技术类文章以及学习类文章!(阿里对MySQL底层实现以及索引实现问的很多)

[外链图片转存中…(img-6ZRiz9Vb-1719150251921)]

[外链图片转存中…(img-XTQa7sB5-1719150251922)]

吃透后这份pdf,你同样可以跟面试官侃侃而谈MySQL。其实像阿里p7岗位的需求也没那么难(但也不简单),扎实的Java基础+无短板知识面+对某几个开源技术有深度学习+阅读过源码+算法刷题,这一套下来p7岗差不多没什么问题,还是希望大家都能拿到高薪offer吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值