Redis——配置及应用

文章目录

  • 一、Redis 基本的事务操作
    • 1. 事务
    • 2. 事务操作举例
  • 二、Redis 实现乐观锁
    • 1. 乐观锁、悲观锁
    • 2. 锁操作举例
  • 三、通过 Jedis 操作 Redis
  • 四、SpringBoot 集成 Redis
    • 1. jedis 和 lettuce
    • 2. SpringBoot 整合
  • 五、自定义Redis Template


一、Redis 基本的事务操作

1. 事务

  • Redis 事物本质:一组命令的集合;
  • 一个事物中所有的命令都会被序列化,在事务执行过程中,会按照顺序执行;
  • 一次性、顺序性、排他性;
  • Redis 单条命令是保证原子性的,但是事务不保证原子性
  • Redis 事务没有隔离级别的概念
  • 所有命令在事务中,并没有直接被执行,只有发起执行命令的时候才会执行;
  • Redis 事务
    • 开启事务(multi)
    • 命令入队(…)
    • 执行事务(exec)
  • 锁:Redis 可以实现乐观锁

2. 事务操作举例

  • 正常执行事务
    Redis——配置及应用_第1张图片
  • 放弃事务
    Redis——配置及应用_第2张图片
  • 编译型异常(代码有问题,命令有错),事务中所有的命令都不会被执行;
    Redis——配置及应用_第3张图片
  • 运行时异常(1/0),如果事务队列中存在语法错误,那么执行命令时,其他命令可以正常执行,错误命令会抛出异常;
    Redis——配置及应用_第4张图片

二、Redis 实现乐观锁

1. 乐观锁、悲观锁

  • 悲观锁
    • 认为什么时候都会出问题,无论做什么都加锁;
  • 乐观锁
    • 认为什么时候都不会出问题,所以不上锁;更新的时候去判断一下,在此期间是否有人修改过数据;
    • 获取 version;
    • 更新的时候比较 version;

2. 锁操作举例

  • Redis 监视测试(正常执行成功)
    Redis——配置及应用_第5张图片
  • 测试多线程修改值,使用 watch 可以当做 redis 的乐观锁操作
    Redis——配置及应用_第6张图片
  • 如果修改失败,获取最新值即可
    Redis——配置及应用_第7张图片

三、通过 Jedis 操作 Redis

  • 导入 jedis 包
    Redis——配置及应用_第8张图片
  • 编码测试
    连接数据库、操作命令、断开连接
    Redis——配置及应用_第9张图片

四、SpringBoot 集成 Redis

1. jedis 和 lettuce

  • 说明:在SpringBoot2.x之后,原来使用的 jedis 被替换为了 lettuce
  • jedis:采用的直连,多线程操作的话,是不安全的,如果想要避免不安全的,使用 jedis pool 连接池;更像 BIO 模式;
  • lettuce:采用netty,实例可以在多个线程中进行共享,不存在不安全的情况,可以减少线程数据,更像 NIO 模式;

2. SpringBoot 整合

  • 导入依赖
    Redis——配置及应用_第10张图片
  • 配置连接
    在这里插入图片描述
  • 测试
    Redis——配置及应用_第11张图片

五、自定义Redis Template

  • (这个自定义模板可以直接放在项目中使用)
    Redis——配置及应用_第12张图片

你可能感兴趣的:(Java框架,redis)