使用redis的pipeline,批量獲取redis中的key值時,報錯,分析發現,批量獲取時,exec後,會返回兩種值:nil 及 redis.Nil,git
這種狀況下,使用常規的 if err!=nil 的判斷方法判斷錯誤,是會報錯的。github
測試代碼:redis
package main import ( "github.com/go-redis/redis" "log" "strconv" ) func main() { client := redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", // no password set DB: 0, // use default DB Network: "tcp", PoolSize: 50, }) if _, err := client.Ping().Result(); err != nil { panic(err) } pipe := client.Pipeline() log.Println("全部的key都存在:") for i := 0; i < 4; i++ { key := "n:" + strconv.FormatInt(int64(i), 10) pipe.Get(key) } result, err := pipe.Exec() log.Println(result) log.Println(err == nil) log.Println(err == redis.Nil) log.Println("有不存在的key:") for i := 0; i < 5; i++ { key := "n:" + strconv.FormatInt(int64(i), 10) pipe.Get(key) } result, err = pipe.Exec() log.Println(result) log.Println(err == nil) log.Println(err == redis.Nil) defer client.Close() }
運行結果:tcp
能夠看到,若是批量獲取的key中,有不存在的key,返回的會是redis.Nil,不然返回的是nil。測試