转载

SpringBoot中RedisTemplate的RedisScript解析

在RedisTemplate执行lua脚本如果做呢? 查看下面方法代码,这是引入lua内容脚本到 RedisScript 的子类 DefaultRedisScript 类中,这是redis提供支持的脚本支持类,更多内容可参考=>redis脚本参考

protected RedisScript<Long> getRedisLockScript() {
        String script = "local key = ARGV[1];local expiration = ARGV[2];local value = 1;";
        script += "if redis.call('EXISTS', key) == 1 then return -1 else redis.call('SET', key, value);redis.call('EXPIRE', key, expiration);return 1;end";
        return new DefaultRedisScript<>(script, Long.class);
    }
复制代码

这里可以通过查看execute方法查看执行的源码流程:

SpringBoot中RedisTemplate的RedisScript解析
首先进入到 RedisTemplate.java 中的 execute()

方法中

SpringBoot中RedisTemplate的RedisScript解析

通过方法重载,找到具体的执行类方法,主要有以下4步:

  1. execute() 三个参数的方法
  2. execute() 五个参数的方法
  3. execute() 五个参数的方法体
  4. 最后 eval() 方法执行redis脚本命令
    SpringBoot中RedisTemplate的RedisScript解析
    接下来进入到 eval() 方法的对应实现类 DefaultScriptExecute 中: 首先直接传sha值,如果在Redis中找不到预加载的lua脚本导致报错,则catch住该错误,把整个脚本序列化后传入Redis进行执行:
    SpringBoot中RedisTemplate的RedisScript解析

我们查看以下脚本序列化的执行代码 scriptBytes() ,其对应的执行类为 StringRedisSerializer

SpringBoot中RedisTemplate的RedisScript解析
进入到 StringRedisSerializer

类,可以看出该序列化操作其实就是字符串String序列化操作

SpringBoot中RedisTemplate的RedisScript解析

至此,关于SpringBoot中RedisTemplate的RedisScript源码分析结束~

原文  https://juejin.im/post/5d849dfce51d4561fc620b0e
正文到此结束
Loading...