Releases: nats-io/nats.go
Releases · nats-io/nats.go
Release v1.9.1
Changelog
Fixed
- In preparation for JetStream and support of subject rewriting, a bug was introduced that would cause multiple deliveries when before the delivery should have been only one per response. This affects only v1.9.0 (#528)
Complete Changes
Release v1.9.0
Changelog
With the release of Go 1.13.3, the go get github.com/nats-io/nats.go
is now working!
Added
- Notes in README on using
go get
and Go modules (#481) NoCallbacksAfterClientClose()
connection option to prevent invocation of connection callback on explicit Close() (#514)
Updated
- Examples (log error, use Drain(), etc..)
- Replaced use of
DisconnectHandler
withDisconnectErrHandler
in our examples. Thanks to @kaxap for the contribution (#504)
Improved
- When creating a subscription, error will now be reported if using a bad subject or queue name (#500)
- Support for
~
when providing the user credentials file(s) (#512)
Fixed
- Document issues. Thanks to @JensRantil for the report.
- Some errors in code examples in the README. Thanks to @thylong for the contribution (#507)
- Allow synchronous subscriptions to use
msg.Respond()
when `AutoUnsubscribe() is used (#489) - Wrong error returned in
NextMsg()
andNextMsgWithContext()
. Thanks to @ekle for the report (#492) - Handling of expiration and auth errors on reconnect (#499, #506)
- Data race between
processMsg()
andStats()
. Thanks to @Will2817 for the report (#521)
Complete Changes
Release v1.8.1
Release v1.8.0
Changelog
Some of you may have noticed that there was temporarily a v2.0.0 tag.
We wanted to align the client version to the upcoming NATS Server 2.0 release.
However, there was no backward compatibility breaking changes in the client and
the go.mod rules for a v2 would have force us, and users, to add v2
to the import paths.
This would not be justified since, again, there are no breaking changes.
So we have removed the tag and instead released v1.8.0. We are deeply sorry for the
inconvenience but we hope that you will understand why we did this.
Changed
- The repository has been renamed to
nats.go
. When doing ago get github.com/nats-io/nats.go/
, make sure to include the trailing/
to avoid such error:stat github.com/nats-io/nats.go: no such file or directory
. - The default URL (
nats.DefaultURL
) has been changed fromnats://localhost:4222
tonats://127.0.0.1:4222
(#460)
Added
ConnErrHandler
: handler which can be invoked when a disconnect event occurs. Unlike ConnHandler, you can get the error that caused the disconnect event. Thanks to @mkorolyov for the contribution (#462, #464)Message.Respond()
to be able to conveniently reply to a request message from the message handler (#472)
Deprecated
Improved
- Some cleanup with use of RWMutex, removal of un-needed defer, etc... Thanks to @MaruHyl for the contributions (#434, #437, #438)
- Refactor some of the examples. Thanks to @andyxning for the contribution (#440)
Fixed
- Proper randomization of IPs resolved from a hostname prior to dial (#445)
- Misleading TLS error report due to credential file errors (#446)
- Race on synchronous subscription type setting (#447)
- Examples would not exit after printing usage, possibly causing panic (#456, #465)
- Some typos. Thanks to @0xflotus for the contribution (#471)
Complete Changes
Release v1.7.2
Changelog
Added
- Ability to set MaxPingsOutstanding as an Option (#414)
- Conn.ConnectedAddr() (#426)
- FlushWithContext() (#433)
Updated
- Handle host names that resolve to more than one IP (#417)
- Disable automatic TLS skip verify (#420)
- Examples and Benchmarks can use new credentials based authentication and authorization (#419)
- Smarter kickFlusher behavior (#429)
- Smarter processing on NextMsg() when a message already available (#432)
Improved
- Better handling of TLS errors. Thanks to @brianshannan for the contribution (#418)
- Updates to samples in docs (#422, #421)
- Uses staticcheck now vs megacheck
Fixed
- Maintain string case for async errors from the server (#415)
Complete Changes
Release v1.7.0
Changelog
Added
- Ability to retrieve CID from server the client is currently connected to (#395)
- NKey support (#399)
- TokenHandler option. Thanks to @nicholaslam for the contribution (#405)
- Support for User JWTs (#408)
- FlusherTimeout option to allow all writes to honor the deadline. Thanks to @gwik for the contribution (#393)
Updated
- Examples moved to separate directories so they can be "go install"'ed (#406)
- Allow expressed url parameters to influence implicit servers (#409, #410)
- Some updates for NGS support (#400)
Improved
- Faster and smaller reply subjects (#402)
Fixed
- Set connection's last error if async error occurs during Drain (#392)
Complete Changes
Release v1.6.0
Changelog
Added
PingInterval()
option. Thanks to @karpovicham for the contribution (#361)- Ability to suppress receiving messages published by own connection, aka
NoEcho()
option. Requires server 1.2.0+ (#375) - Ability to drain subscriptions and/or connections (#378, #380)
Improved
- Simpler URLs. It is now possible to simply pass hostname without scheme nor port (which defaults to 4222). That is,
nats.Connect("myhost")
is now equivalent tonats.Connect("nats://myhost:4222")
. Also switches automatically to secure connection (TLS) if server requests it (#381)
Fixed
- Possible deadlock in asynchronous connection callbacks. Thanks to @teh-cmc for the contribution (#365, #369)
Close()
may not release resources immediately. Thanks to @mjgarton for the report (#370)- Benchmark tool (
nats-bench
) now starts subscriber's timer when getting the first message (#379) - API Documentation related to creation of various subscription types. Thanks to @nussjustin for the report (#383)
- Panic if passing a nil option to
nats.Connect()
. They will now be ignored (#385) - RequestWithContext or NextMsgWithContext could return a message although the context was canceled or timed-out (#387)
Complete Changes
Release v1.5.0
Changelog
Added
Conn.Barrier()
API. This is an advance API that can be useful in some specific situations. Thanks to @nussjustin for reporting an issue during development of this feature (#338, #346)ReconnectBufSize()
option setter. Thanks to @ripienaar (#340)
Improved
- Reduce memory usage during reconnect. Thanks to @charlievieth (#341)
- No need for regex in Connect(). Thanks to @charlievieth (#342)
- List of servers is now updated when the cluster topology changes. Will require server at version 1.0.7+ (#344, #352)
Fixed
- Protocol(s) received right after initial PONG may be missed. This would manifest with the handling of cluster topology state on connect with server 1.0.7+ (#348)
Changed
- Moved to Apache 2.0 License as part of the move to CNCF (#354)
Complete Changes
Release v1.4.0
Changelog
Added
- CustomDialer interface and SetCustomDialer option setter. Thanks to @joyhope and @mdevan for the report (#334)
Improved
- Reduce memory allocations for subscription protocol. Thanks to @nussjustin (#319)
Fixed
- Possible repeated timeout of Flush/FlushTimeout and inability to dispatch (#322)
- Some typos and unnecessary type conversion. Thanks to @marmotini (#324)
- ErrorHandler not always reporting proper error (#326)
- TLSConfig cloning for Go 1.8+. Thanks to @johanbrandhorst (#336)
Deprecated
- Dialer option/setter, which deals with a *net.Dialer. Use CustomDialer instead (#334)
Complete Changes
Release v1.3.0
Changelog
Added
FlusherTimeout
option to limit the time the flusher can block (#252)DiscoveredServersCB
connection handler invoked when a server joins the cluster (#282)- context.Context support with new APIs:
RequestWithContext
,NextMsgWithContext
(#275) GetDefaultOptions()
produces new default Options. Should be used instead of DefaultOptions. Thanks to @nogoegst (#308)
Improved
- Performance when connection publishes to itself and reduces risk of getting slow consumer (#285)
- Less chatty request protocol (#295, #299)
- Use of pool for timers in Request/NextMsg/FlushTimeout calls (#297)
Changed
- Repo name (now go-nats) (#239)
- Authorization errors now trigger the async error callback and do not close the connection (#300)
Fixed
- Server pool shuffling when adding new URLs when servers join the cluster (#260)
- Very rare panic in WaitGroup.Wait() (#268)
- Locking in handling permission violation error from server (#289)
Deprecated
DefaultOptions
. You should useGetDefaultOptions()
instead. See #308