Redis 在Golang中使用遇到的坑

1、从lua脚本传回到go那边的数字是string类型

2、hincrby 返回当前值的计算结果(即存放到redis中的值)

3、hset 一个不存在的key,返回什么呢?即设置失败返回什么错误?(会创建出这个key来,并返回1,如果这个已key存在,则返回0[设值仍然会成功] 

4、hget 一个空的值,会返回nil?还是0?(在lua里面返回false,直接返回到go中会报err错:“redis:nil”)

      hgetall 一个不存在key,会返回空的map{},不会返回error

5、hmset 返回的始终是 ok:OK(不论key是否已存在)

6、reids的key区分大小写(一样的key,大小写不同,代表的是两个key)

7、zscore,在lua中得到的值是string类型,后端go得到的也是string类型

8、zscore,在lua中取一个不存在的key,在lua中得到的结果是 false(boolean)

     如:local r = redis.call('zscore','lt_mobile_package','test') return r; 

     key:lt_mobile_package,不存在时,lua中得到的r为false(boolean类型),后端go得到的是err(redis: nil),冒号后面有个空格

9、zscore,在lua中取一个不存在的member时,结果和上一条一样

10、eval执行lua脚本的格式:eval script numkeys key [key ...] arg [arg ...](参数依次为:脚本字符串、key的数量、key、带入的参数)

       坑:A、后面的key必须传,B、确保和lua script里面要操作的key在同一个redis节点上,否则报错:

  ERR Error running script (call to f_c7be025ded1da0247b48d3acfe266ecf67957030): @user_script:1: @user_script: 1: Lua script attempted to access a non local key in a cluster node

  因hydra的key是可选参数,被我忽略了之后,测试代码间歇报错(不会一直报,一直以为是配置问题。纠结了很久,最终还是同事发现的)。

  

原文地址:https://www.cnblogs.com/Denny_Yang/p/8600927.html