Compare commits
	
		
			6 Commits
		
	
	
		
			v3.10.20
			...
			b2d89018b8
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b2d89018b8 | |||
| 0981f89f60 | |||
| 332fe5f4d4 | |||
| 757fe0245b | |||
| 27eccc1ed2 | |||
| 7c641fa8ac | 
							
								
								
									
										8
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								go.mod
									
									
									
									
									
								
							| @@ -5,9 +5,9 @@ go 1.22 | ||||
| toolchain go1.22.4 | ||||
|  | ||||
| require ( | ||||
| 	github.com/redis/go-redis/extra/rediscmd/v9 v9.0.5 | ||||
| 	github.com/redis/go-redis/v9 v9.6.1 | ||||
| 	go.unistack.org/micro/v3 v3.10.96 | ||||
| 	github.com/redis/go-redis/extra/rediscmd/v9 v9.7.0 | ||||
| 	github.com/redis/go-redis/v9 v9.7.0 | ||||
| 	go.unistack.org/micro/v3 v3.10.105 | ||||
| ) | ||||
|  | ||||
| require ( | ||||
| @@ -15,5 +15,5 @@ require ( | ||||
| 	github.com/dgryski/go-rendezvous v0.0.0-20200823014737-9f7001d12a5f // indirect | ||||
| 	github.com/google/go-cmp v0.6.0 // indirect | ||||
| 	go.unistack.org/micro-proto/v3 v3.4.1 // indirect | ||||
| 	google.golang.org/protobuf v1.35.1 // indirect | ||||
| 	google.golang.org/protobuf v1.35.2 // indirect | ||||
| ) | ||||
|   | ||||
							
								
								
									
										20
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								go.sum
									
									
									
									
									
								
							| @@ -1,24 +1,20 @@ | ||||
| github.com/bsm/ginkgo/v2 v2.7.0/go.mod h1:AiKlXPm7ItEHNc/2+OkrNG4E0ITzojb9/xWzvQ9XZ9w= | ||||
| github.com/bsm/ginkgo/v2 v2.12.0 h1:Ny8MWAHyOepLGlLKYmXG4IEkioBysk6GpaRTLC8zwWs= | ||||
| github.com/bsm/ginkgo/v2 v2.12.0/go.mod h1:SwYbGRRDovPVboqFv0tPTcG1sN61LM1Z4ARdbAV9g4c= | ||||
| github.com/bsm/gomega v1.26.0/go.mod h1:JyEr/xRbxbtgWNi8tIEVPUYZ5Dzef52k01W3YH0H+O0= | ||||
| github.com/bsm/gomega v1.27.10 h1:yeMWxP2pV2fG3FgAODIY8EiRE3dy0aeFYt4l7wh6yKA= | ||||
| github.com/bsm/gomega v1.27.10/go.mod h1:JyEr/xRbxbtgWNi8tIEVPUYZ5Dzef52k01W3YH0H+O0= | ||||
| github.com/cespare/xxhash/v2 v2.2.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= | ||||
| github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UFvs= | ||||
| github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= | ||||
| github.com/dgryski/go-rendezvous v0.0.0-20200823014737-9f7001d12a5f h1:lO4WD4F/rVNCu3HqELle0jiPLLBs70cWOduZpkS1E78= | ||||
| github.com/dgryski/go-rendezvous v0.0.0-20200823014737-9f7001d12a5f/go.mod h1:cuUVRXasLTGF7a8hSLbxyZXjz+1KgoB3wDUb6vlszIc= | ||||
| github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= | ||||
| github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= | ||||
| github.com/redis/go-redis/extra/rediscmd/v9 v9.0.5 h1:EaDatTxkdHG+U3Bk4EUr+DZ7fOGwTfezUiUJMaIcaho= | ||||
| github.com/redis/go-redis/extra/rediscmd/v9 v9.0.5/go.mod h1:fyalQWdtzDBECAQFBJuQe5bzQ02jGd5Qcbgb97Flm7U= | ||||
| github.com/redis/go-redis/v9 v9.0.5/go.mod h1:WqMKv5vnQbRuZstUwxQI195wHy+t4PuXDOjzMvcuQHk= | ||||
| github.com/redis/go-redis/v9 v9.6.1 h1:HHDteefn6ZkTtY5fGUE8tj8uy85AHk6zP7CpzIAM0y4= | ||||
| github.com/redis/go-redis/v9 v9.6.1/go.mod h1:0C0c6ycQsdpVNQpxb1njEQIqkx5UcsM8FJCQLgE9+RA= | ||||
| github.com/redis/go-redis/extra/rediscmd/v9 v9.7.0 h1:BIx9TNZH/Jsr4l1i7VVxnV0JPiwYj8qyrHyuL0fGZrk= | ||||
| github.com/redis/go-redis/extra/rediscmd/v9 v9.7.0/go.mod h1:eTg/YQtGYAZD5r3DlGlJptJ45AHA+/G+2NPn30PKzik= | ||||
| github.com/redis/go-redis/v9 v9.7.0 h1:HhLSs+B6O021gwzl+locl0zEDnyNkxMtf/Z3NNBMa9E= | ||||
| github.com/redis/go-redis/v9 v9.7.0/go.mod h1:f6zhXITC7JUJIlPEiBOTXxJgPLdZcA93GewI7inzyWw= | ||||
| go.unistack.org/micro-proto/v3 v3.4.1 h1:UTjLSRz2YZuaHk9iSlVqqsA50JQNAEK2ZFboGqtEa9Q= | ||||
| go.unistack.org/micro-proto/v3 v3.4.1/go.mod h1:okx/cnOhzuCX0ggl/vToatbCupi0O44diiiLLsZ93Zo= | ||||
| go.unistack.org/micro/v3 v3.10.96 h1:njukb0DlXOJspX5mLSwcP7+cVSg/8Fy+6++mYkOpY2A= | ||||
| go.unistack.org/micro/v3 v3.10.96/go.mod h1:YzMldzHN9Ei+zy5t/Psu7RUWDZwUfrNYiStSQtTz90g= | ||||
| google.golang.org/protobuf v1.35.1 h1:m3LfL6/Ca+fqnjnlqQXNpFPABW1UD7mjh8KO2mKFytA= | ||||
| google.golang.org/protobuf v1.35.1/go.mod h1:9fA7Ob0pmnwhb644+1+CVWFRbNajQ6iRojtC/QF5bRE= | ||||
| go.unistack.org/micro/v3 v3.10.105 h1:JYNV0d+fnR7Hy8d4/sjr+25DbSNqq1Z7IPeDDdB+f1I= | ||||
| go.unistack.org/micro/v3 v3.10.105/go.mod h1:YzMldzHN9Ei+zy5t/Psu7RUWDZwUfrNYiStSQtTz90g= | ||||
| google.golang.org/protobuf v1.35.2 h1:8Ar7bF+apOIoThw1EdZl0p1oWvMqTHmpA2fRTyZO8io= | ||||
| google.golang.org/protobuf v1.35.2/go.mod h1:9fA7Ob0pmnwhb644+1+CVWFRbNajQ6iRojtC/QF5bRE= | ||||
|   | ||||
| @@ -61,7 +61,7 @@ func NewOptions(opts ...Option) Options { | ||||
| 			labelName, options.RedisName), | ||||
| 	) | ||||
|  | ||||
| 	options.Logger = options.Logger.Clone(logger.WithCallerSkipCount(1)) | ||||
| 	options.Logger = options.Logger.Clone(logger.WithAddCallerSkipCount(1)) | ||||
|  | ||||
| 	return options | ||||
| } | ||||
|   | ||||
							
								
								
									
										73
									
								
								redis.go
									
									
									
									
									
								
							
							
						
						
									
										73
									
								
								redis.go
									
									
									
									
									
								
							| @@ -4,6 +4,7 @@ import ( | ||||
| 	"context" | ||||
| 	"reflect" | ||||
| 	"strings" | ||||
| 	"sync/atomic" | ||||
| 	"time" | ||||
|  | ||||
| 	goredis "github.com/redis/go-redis/v9" | ||||
| @@ -54,19 +55,22 @@ var ( | ||||
| ) | ||||
|  | ||||
| type Store struct { | ||||
| 	opts store.Options | ||||
| 	cli  goredis.UniversalClient | ||||
| 	done chan struct{} | ||||
| 	pool *pool.StringsPool | ||||
| 	opts        store.Options | ||||
| 	cli         goredis.UniversalClient | ||||
| 	done        chan struct{} | ||||
| 	pool        *pool.StringsPool | ||||
| 	isConnected atomic.Int32 | ||||
| } | ||||
|  | ||||
| func (r *Store) Connect(ctx context.Context) error { | ||||
| 	if r.cli == nil { | ||||
| 		return store.ErrNotConnected | ||||
| 	} | ||||
| 	err := r.cli.Ping(ctx).Err() | ||||
| 	setSpanError(ctx, err) | ||||
| 	return err | ||||
| 	if r.opts.LazyConnect { | ||||
| 		return nil | ||||
| 	} | ||||
| 	return r.connect(ctx) | ||||
|  | ||||
| } | ||||
|  | ||||
| func (r *Store) Init(opts ...store.Option) error { | ||||
| @@ -107,7 +111,9 @@ func (r *Store) Disconnect(ctx context.Context) error { | ||||
| 		return err | ||||
| 	default: | ||||
| 		if r.cli != nil { | ||||
| 			err = r.cli.Close() | ||||
| 			if err = r.cli.Close(); err != nil { | ||||
| 				r.isConnected.Store(0) | ||||
| 			} | ||||
| 		} | ||||
| 		close(r.done) | ||||
| 		return err | ||||
| @@ -115,6 +121,10 @@ func (r *Store) Disconnect(ctx context.Context) error { | ||||
| } | ||||
|  | ||||
| func (r *Store) Exists(ctx context.Context, key string, opts ...store.ExistsOption) error { | ||||
| 	if err := r.connect(ctx); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	b := r.pool.Get() | ||||
| 	defer r.pool.Put(b) | ||||
| 	options := store.NewExistsOptions(opts...) | ||||
| @@ -154,6 +164,10 @@ func (r *Store) Exists(ctx context.Context, key string, opts ...store.ExistsOpti | ||||
| } | ||||
|  | ||||
| func (r *Store) Read(ctx context.Context, key string, val interface{}, opts ...store.ReadOption) error { | ||||
| 	if err := r.connect(ctx); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	b := r.pool.Get() | ||||
| 	defer r.pool.Put(b) | ||||
|  | ||||
| @@ -205,6 +219,10 @@ func (r *Store) Read(ctx context.Context, key string, val interface{}, opts ...s | ||||
| } | ||||
|  | ||||
| func (r *Store) MRead(ctx context.Context, keys []string, vals interface{}, opts ...store.ReadOption) error { | ||||
| 	if err := r.connect(ctx); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	options := store.NewReadOptions(opts...) | ||||
|  | ||||
| 	timeout := r.opts.Timeout | ||||
| @@ -304,6 +322,10 @@ func (r *Store) MRead(ctx context.Context, keys []string, vals interface{}, opts | ||||
| } | ||||
|  | ||||
| func (r *Store) MDelete(ctx context.Context, keys []string, opts ...store.DeleteOption) error { | ||||
| 	if err := r.connect(ctx); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	options := store.NewDeleteOptions(opts...) | ||||
|  | ||||
| 	timeout := r.opts.Timeout | ||||
| @@ -359,6 +381,10 @@ func (r *Store) MDelete(ctx context.Context, keys []string, opts ...store.Delete | ||||
| } | ||||
|  | ||||
| func (r *Store) Delete(ctx context.Context, key string, opts ...store.DeleteOption) error { | ||||
| 	if err := r.connect(ctx); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	b := r.pool.Get() | ||||
| 	defer r.pool.Put(b) | ||||
|  | ||||
| @@ -397,6 +423,10 @@ func (r *Store) Delete(ctx context.Context, key string, opts ...store.DeleteOpti | ||||
| } | ||||
|  | ||||
| func (r *Store) MWrite(ctx context.Context, keys []string, vals []interface{}, opts ...store.WriteOption) error { | ||||
| 	if err := r.connect(ctx); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	options := store.NewWriteOptions(opts...) | ||||
|  | ||||
| 	timeout := r.opts.Timeout | ||||
| @@ -480,6 +510,10 @@ func (r *Store) MWrite(ctx context.Context, keys []string, vals []interface{}, o | ||||
| } | ||||
|  | ||||
| func (r *Store) Write(ctx context.Context, key string, val interface{}, opts ...store.WriteOption) error { | ||||
| 	if err := r.connect(ctx); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	b := r.pool.Get() | ||||
| 	defer r.pool.Put(b) | ||||
|  | ||||
| @@ -535,6 +569,10 @@ func (r *Store) Write(ctx context.Context, key string, val interface{}, opts ... | ||||
| } | ||||
|  | ||||
| func (r *Store) List(ctx context.Context, opts ...store.ListOption) ([]string, error) { | ||||
| 	if err := r.connect(ctx); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	b := r.pool.Get() | ||||
| 	defer r.pool.Put(b) | ||||
|  | ||||
| @@ -625,12 +663,12 @@ func NewStore(opts ...store.Option) *Store { | ||||
| } | ||||
|  | ||||
| func (r *Store) configure() error { | ||||
| 	var universalOptions *goredis.UniversalOptions | ||||
|  | ||||
| 	if r.cli != nil && r.opts.Context == nil { | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
| 	universalOptions := DefaultUniversalOptions | ||||
|  | ||||
| 	if r.opts.Context != nil { | ||||
| 		if o, ok := r.opts.Context.Value(configKey{}).(*goredis.Options); ok { | ||||
| 			universalOptions.Addrs = []string{o.Addr} | ||||
| @@ -704,10 +742,6 @@ func (r *Store) configure() error { | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if universalOptions == nil { | ||||
| 		universalOptions = DefaultUniversalOptions | ||||
| 	} | ||||
|  | ||||
| 	if len(r.opts.Addrs) > 0 { | ||||
| 		universalOptions.Addrs = r.opts.Addrs | ||||
| 	} else { | ||||
| @@ -735,3 +769,14 @@ func (r *Store) getKey(b *strings.Builder, mainNamespace string, opNamespace str | ||||
| 	b.WriteString(key) | ||||
| 	return b.String() | ||||
| } | ||||
|  | ||||
| func (r *Store) connect(ctx context.Context) (err error) { | ||||
| 	if r.isConnected.Load() == 0 { | ||||
| 		if err = r.cli.Ping(ctx).Err(); err != nil { | ||||
| 			setSpanError(ctx, err) | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	r.isConnected.Store(1) | ||||
| 	return nil | ||||
| } | ||||
|   | ||||
							
								
								
									
										23
									
								
								stats.go
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								stats.go
									
									
									
									
									
								
							| @@ -33,20 +33,17 @@ func (r *Store) statsMeter() { | ||||
| 		ticker := time.NewTicker(meter.DefaultMeterStatsInterval) | ||||
| 		defer ticker.Stop() | ||||
|  | ||||
| 		for { | ||||
| 			select { | ||||
| 			case <-ticker.C: | ||||
| 				if st == nil { | ||||
| 					return | ||||
| 				} | ||||
| 				stats := st.PoolStats() | ||||
| 				r.opts.Meter.Counter(PoolHitsTotal).Set(uint64(stats.Hits)) | ||||
| 				r.opts.Meter.Counter(PoolMissesTotal).Set(uint64(stats.Misses)) | ||||
| 				r.opts.Meter.Counter(PoolTimeoutTotal).Set(uint64(stats.Timeouts)) | ||||
| 				r.opts.Meter.Counter(PoolConnTotalCurrent).Set(uint64(stats.TotalConns)) | ||||
| 				r.opts.Meter.Counter(PoolConnIdleCurrent).Set(uint64(stats.IdleConns)) | ||||
| 				r.opts.Meter.Counter(PoolConnStaleTotal).Set(uint64(stats.StaleConns)) | ||||
| 		for _ = range ticker.C { | ||||
| 			if st == nil { | ||||
| 				return | ||||
| 			} | ||||
| 			stats := st.PoolStats() | ||||
| 			r.opts.Meter.Counter(PoolHitsTotal).Set(uint64(stats.Hits)) | ||||
| 			r.opts.Meter.Counter(PoolMissesTotal).Set(uint64(stats.Misses)) | ||||
| 			r.opts.Meter.Counter(PoolTimeoutTotal).Set(uint64(stats.Timeouts)) | ||||
| 			r.opts.Meter.Counter(PoolConnTotalCurrent).Set(uint64(stats.TotalConns)) | ||||
| 			r.opts.Meter.Counter(PoolConnIdleCurrent).Set(uint64(stats.IdleConns)) | ||||
| 			r.opts.Meter.Counter(PoolConnStaleTotal).Set(uint64(stats.StaleConns)) | ||||
| 		} | ||||
| 	}() | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user