12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- package internal
- import (
- "io"
- "net"
- "strings"
- "github.com/go-redis/redis/internal/proto"
- )
- func IsRetryableError(err error, retryNetError bool) bool {
- if IsNetworkError(err) {
- return retryNetError
- }
- s := err.Error()
- if s == "ERR max number of clients reached" {
- return true
- }
- if strings.HasPrefix(s, "LOADING ") {
- return true
- }
- if strings.HasPrefix(s, "CLUSTERDOWN ") {
- return true
- }
- return false
- }
- func IsRedisError(err error) bool {
- _, ok := err.(proto.RedisError)
- return ok
- }
- func IsNetworkError(err error) bool {
- if err == io.EOF {
- return true
- }
- _, ok := err.(net.Error)
- return ok
- }
- func IsReadOnlyError(err error) bool {
- return strings.HasPrefix(err.Error(), "READONLY ")
- }
- func IsBadConn(err error, allowTimeout bool) bool {
- if err == nil {
- return false
- }
- if IsRedisError(err) {
- return false
- }
- if allowTimeout {
- if netErr, ok := err.(net.Error); ok && netErr.Timeout() {
- return false
- }
- }
- return true
- }
- func IsMovedError(err error) (moved bool, ask bool, addr string) {
- if !IsRedisError(err) {
- return
- }
- s := err.Error()
- if strings.HasPrefix(s, "MOVED ") {
- moved = true
- } else if strings.HasPrefix(s, "ASK ") {
- ask = true
- } else {
- return
- }
- ind := strings.LastIndex(s, " ")
- if ind == -1 {
- return false, false, ""
- }
- addr = s[ind+1:]
- return
- }
- func IsLoadingError(err error) bool {
- return strings.HasPrefix(err.Error(), "LOADING ")
- }
|