go-redis 库提供了一个 redis.Nil 错误来表示 Key 不存在的错误。因此在使用 go-redis 时需要注意对返回错误的判断。在某些场景下我们应该区别处理 redis.Nil 和其他不为 nil 的错误。
// getValueFromRedis redis.Nil判断
func getValueFromRedis(key, defaultValue string) (string, error) {
ctx, cancel := context.WithTimeout(context.Background(), 500*time.Millisecond)
defer cancel()//这段代码创建了一个带有500毫秒超时的context对象。WithTimeout函数接收一个父context和超时时间,返回一个新的context对象。defer cancel()确保在函数执行完毕后,取消这个超时,释放资源。
val, err := rdb.Get(ctx, key).Result()//使用rdb.Get方法尝试从Redis中获取键key的值。Result()方法用于获取命令的输出结果。如果命令成功执行,val将包含键的值,err将为nil。如果发生错误,err将包含错误信息。
if err != nil {
// 如果返回的错误是key不存在
if errors.Is(err, redis.Nil) {
return defaultValue, nil
}
// 出其他错了
return "", err
}//如果Get方法返回了错误,代码首先检查这个错误是否是由于键不存在导致的。在go-redis库中,redis.Nil是一个特殊的错误类型,用于表示请求的键不存在。如果错误是redis.Nil,函数返回defaultValue作为默认值,并且没有错误。如果错误不是redis.Nil,说明发生了其他类型的错误,函数返回空字符串和一个错误。
return val, nil//如果Get方法成功执行,没有错误发生,函数返回键key的值和nil错误。
}