文章目录
一、Redis 基本的事务操作
1. 事务
- Redis 事物本质:一组命令的集合;
- 一个事物中所有的命令都会被序列化,在事务执行过程中,会按照顺序执行;
- 一次性、顺序性、排他性;
- Redis 单条命令是保证原子性的,但是事务不保证原子性;
- Redis 事务没有隔离级别的概念;
- 所有命令在事务中,并没有直接被执行,只有发起执行命令的时候才会执行;
- Redis 事务:
- 开启事务(multi)
- 命令入队(…)
- 执行事务(exec)
- 锁:Redis 可以实现乐观锁;
2. 事务操作举例
- 正常执行事务
- 放弃事务
- 编译型异常(代码有问题,命令有错),事务中所有的命令都不会被执行;
- 运行时异常(1/0),如果事务队列中存在语法错误,那么执行命令时,其他命令可以正常执行,错误命令会抛出异常;
二、Redis 实现乐观锁
1. 乐观锁、悲观锁
- 悲观锁
- 认为什么时候都会出问题,无论做什么都加锁;
- 乐观锁
- 认为什么时候都不会出问题,所以不上锁;更新的时候去判断一下,在此期间是否有人修改过数据;
- 获取 version;
- 更新的时候比较 version;
2. 锁操作举例
- Redis 监视测试(正常执行成功)
- 测试多线程修改值,使用
watch
可以当做 redis 的乐观锁操作;
- 如果修改失败,获取最新值即可;
三、通过 Jedis 操作 Redis
- 导入 jedis 包
- 编码测试
连接数据库、操作命令、断开连接
四、SpringBoot 集成 Redis
1. jedis 和 lettuce
- 说明:在SpringBoot2.x之后,原来使用的 jedis 被替换为了 lettuce;
- jedis:采用的直连,多线程操作的话,是不安全的,如果想要避免不安全的,使用 jedis pool 连接池;更像 BIO 模式;
- lettuce:采用netty,实例可以在多个线程中进行共享,不存在不安全的情况,可以减少线程数据,更像 NIO 模式;
2. SpringBoot 整合
- 导入依赖
- 配置连接
- 测试
五、自定义Redis Template
- (这个自定义模板可以直接放在项目中使用)