9.0.0-rc.2 (2022-11-26)
- capture error correctly in withConn (d1bfaba)
- fixes ring.SetAddrs and rebalance race (#2283) (d83436b)
- read in route_randomly query param correctly (f236053)
- reduce
SetAddrs
shards lock contention (6c05a9f), closes /github.com/go-redis/redis/pull/2190#discussion_r953040289 #2077 - wrap cmds in Conn.TxPipeline (5053db2)
- Added support for RESP3 protocol. Contributed by @monkey92t who has done a lot of work recently.
- Added
ContextTimeoutEnabled
option that controls whether the client respects context timeouts and deadlines. See Redis Timeouts for details. - Added
ParseClusterURL
to parse URLs intoClusterOptions
, for example,redis://user:password@localhost:6789?dial_timeout=3&read_timeout=6s&addr=localhost:6790&addr=localhost:6791
. - Added metrics instrumentation using
redisotel.IstrumentMetrics
. See documentation
- Removed asynchronous cancellation based on the context timeout. It was racy in v8 and is completely gone in v9.
- Reworked hook interface and added
DialHook
. - Replaced
redisotel.NewTracingHook
withredisotel.InstrumentTracing
. See example and documentation. - Replaced
*redis.Z
withredis.Z
since it is small enough to be passed as value without making an allocation. - Renamed the option
MaxConnAge
toConnMaxLifetime
. - Renamed the option
IdleTimeout
toConnMaxIdleTime
. - Removed connection reaper in favor of
MaxIdleConns
. - Removed
WithContext
sincecontext.Context
can be passed directly as an arg. - Removed
Pipeline.Close
since there is no real need to explicitly manage pipeline resources and it can be safely reused viasync.Pool
etc.Pipeline.Discard
is still available if you want to reset commands for some reason.
- Improved and fixed pipeline retries.
- As usual, added more commands and fixed some bugs.