All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- tchannel: add option to accept native tchannel handlers.
- Bump minimum version of go.uber.org/thriftrw to v1.29.2.
- Default to thriftrw NoWire for both client and server.
- Bump minimum version of go.uber.org/thriftrw to v1.29.1.
- thrift: add server and client encoding implementations to use ThriftRW's streaming. ThriftRW's streaming is an optimized way of encoding/decoding thrift payloads.
- thrift: add an option,
NoWire(enabled bool)
to enable thriftrw's streaming.
- Bump minimum version of go.uber.org/thriftrw to v1.29.0.
- http: remove HTTP/2 pseudo headers for HTTP/2 requests propagated to HTTP/1 service through YARPC transport middleware.
- http: allow multiple interception options and execute in order at runtime.
- peer/direct: peer connections were closed even if they were still in use.
- configuration: clarify error message for the special case of attempting to use a peer list updater when none have been registered.
- protoplugin: generated golang code from the yarpc plugin follows same GoType conventions as gogo/protobuf.
- Downgrade github.com/apache/thrift to the previously-compatible version (0.10)
- go.uber.org/yarpc@v1.54.1 points to v1.54.0 instead of v1.54.1. This release unblocks go.uber.org/yarpc to serve v1.54.1 through v1.54.2.
- protobuf error: a protobuf error created with an invalid code returns a unknown error.
- protobuf error details: protobuf.GetErrorDetails returns nil instead of an empty array if there is no details in the given error.
- observability: extend response, and request payload size histogram buckets up to 256MB.
- introspection: wrong display of proto procedure name.
- error details: propagation of protobuf error details did not work if the any message was not registered in the gogo proto registry.
- Disable
rpc-caller-procedure
header temporarily by stopping theCallerProcedure
propagation.
- gRPC: log header values upon validation error
- v1.53.1 is v1.52.0. v1.53.0 has a backward compatible issue with the new header
rpc-caller-procedure
added in v1.53.0.
- gRPC: accept keepalive parameters for gRPC outbound configuration.
- observability: deprecation of logging levels
applicationError
andserverError
in favor ofserverError
andclientError
. - The
transport.Request
provides a new fieldCallerProcedure
. A headerrpc-caller-procedure
is also propagated for outbound calls. This field represents the origin procedure where the requests was sent.
- peer: concurrency issue when using
rand
for the peer strategiesrandpeer
andtworandomchoices
- gRPC: accept keepalive parameters for the outbound gRPC connection.
- observability: panic metrics are now also reported for these type of requests:
- inbound oneway
- outbound stream
- outbound oneway
- outbound unary
- observability: Add metric tags blocklist configuration. Allows to stub high cardinality tags emitted in the observability middleware
- gRPC: accept dialer options in gRPC transportSpec config
- Http: fix memory and connection leak in http outbound call handler
- Observability: error code CodeUnimplemented will be marked as an
application_error
- peer: the peer implementations provided by yarpc (hashring32, pendingheap, randpeer, roundrobin, tworandomchoices) are thread-safe now
- proto: pass protobuf error details in gRPC streams
- proto: pass error details on proto-error to yarpcerror conversion
- observability: Add request and response payload size histogram
- api: expose
BodySize
field in the transport request/response, middleware can use this field to get or update the request/response body size - hashring32: new option OffsetGeneratorValue
- yarpc: service name can contain
_
now.
- peer/hashring32: Support using an application header as the shard key, instead
of
transport.Request#ShardKey
- peer/hashring32: options NumReplicas and NumPeersEstimate are not private anymore and can be used by consumer of the pkg.
- observability: Add caller request TTL histogram in inbound middleware
- errors returned by
yarpcerrors.FromError
now behave properly when usingerrors.Is
anderrors.Unwrap
. - thrift plugin:
types_yarpc.go
file, which contains exception annotations is always generated. - thrift plugin:
types_yarpc.go
recognizes case-sensitive Thrift file names for generating correct Go package name.
- Reverted
go.mod
Go version from 1.14 to 1.13.
- gRPC Streaming: Added the ability to send and read stream response headers.
- thrift: Using the
rpc.code
annotation, services may specify an associated error code for Thrift exceptions. Metrics will classify the exception as a client or server failure like ayarpcerrors
error. If a Thrift exception is not annotated with a code, it will continue to be classified as a client failure. - logging: Errors and annotated Thrift exceptions are logged with their error
code under the
errorCode
field. Errors created outside ofprotobuf.NewError
andyarpcerrors
will yieldCodeUnknown
. - logging: Thrift exceptions and Protobuf error details are logged under the
errorDetails
field. - grpc: Enabled outbound introspection for debug pages.
- experimental: Added
tchannel.GetResponseErrorMeta
API for retrieving native TChannel error response codes.
- tchannel: middleware may modify the outbound
transport.Request#Caller
field, similar to gRPC and HTTP outbounds. - Added
github.com/dgryski/go-farm
dependency toglide.yaml
for legacy projects.
- Removed
yarpcproto
package that enabled "oneway" Protobuf signatures.
- peer lists accepts a
DefaultChooseTimeout
configuration for applying tocontext
s without deadlines. - gRPC-go version is added to debug pages.
- observability: if a context deadline exceeded (timeout) or context cancelled
error is observed, handler responses (success and errors) are replaced by the
context error. Dropped responses are logged under the
dropped
field. - Introspection APIs are added to
api/x/introspection
. This enabling custom outbounds, inbounds and peer lists to use YARPC's existingx/debug
page. - Introduced
api/x/restriction
for preventing unwanted transport-encoding combinations. This may cause panics for existing Fx services on start-up.
- yarpcerrors:
fmt
verbs are ignored when no args are passed to error constructors. - Fix gRPC streaming when used with the direct peer chooser.
- Streaming calls do not require contexts with deadlines. Users should use cancelable contexts for long-lived streams instead of timeouts.
- Outbound status on debug pages is ordered by outbound name.
- The
x/yarpcmeta
package is completely removed. - tchannel: dropped "handler failed" log. Context error override change makes this log redundant as richer information exists in observability logs.
- tchannel: when callers time out, TChannel servers will not log "SendSystemError failed" and "responseWriter failed to close" messages, since they are unactionable.
- gRPC inbound supports introspection, suitable for debug pages.
- yarpctest: Add
ContextWithCall
function to ease testing of functions that useyarpc.CallFromContext
. yarpcerrors
are aligned with theerrors
API introduced in Go 1.13 (https://blog.golang.org/go1.13-errors).yarpcerrors.IsStatus
,yarpcerrors.FromError
, support wrapped errors, andyarpcerrors.Status
implementsUnwrap() error
.
- Inbound Thrift requests that fail during
wire.Value#FromWire
are returned asyarpcerrors.CodeInvalidArgument
, to indicate a client error. - Dropped library dependency on development tools.
- gRPC inbounds correctly convert all YARPC error codes to gRPC error codes,
outside of handler errors. Previously, well-defined YARPC errors were wrapped
with an
Unknown
gRPC code for unimplemented procedures. - Fixes
idleConnTimeout
not propgated to the underlying http transport. - HTTP does not hold onto connections forever by default.
IdleConnTimeout
now defaults to 15 minutes. protobuf.GetErrorDetails
can extract error details from wrapped errors.- observability: errors returned from Protobuf handlers are logged with their
error message instead of
application_error
. encoding/protobuf
error details (yarpcerrors.Status
with details) are logged at application error log level. This matches behavior with Thrift exceptions.
- The TChannel Transport now supports a custom dialer function option.
- gRPC now supports compression.
The packages
compressor/gzip
andcompressor/snappy
provide compressors accepted by the gRPCCompressor
dialer option. - The
peer/hashring32
package now provides support for consistent hashing that is compatible with RingPop hash ring topologies. This peer selection strategy uses theShardKey
call option to pin traffic to an arbitrary peer that is relatively stable as the peer list membership changes. - Observability middleware now emits metrics for panics that occur on the stack of an inbound call handler.
- The
transporttest
package now provides aPipe
constructor, which creates a bound pair of transport layer streams, for testing streaming protocols like gRPC. - The
yarpctest.FakeOutbound
can now send requests to atransport.Router
. This allows end to end testing with a client and server in memory. TheOutboundCallOverride
,OutboundCallOnewayOverride
(new), andOutboundCallStreamOverride
(new) are now a complete set that allow tests to hook any of the call behaviors. - All outbounds now implement
TransportName
and a newtransport.Namer
interface. This will allow outbound observability middleware to carry the transport name in metrics properly.
- This change reduces the API surface of the peer list implementations to remove a previously public embedded type and replace it with implementations of the underlying interfaces. The new type does not provide all of the public interface of the previous concrete types. However, we expect that in practice, peer lists are used as either peer.List, peer.Chooser, or for the private introspection interface.
- Peer list peer unavailability errors now provide additional context including the number of assigned peers and whether fail-fast is enabled.
- Fixed Streaming Protobuf-flavored-JSON nil pointer panic.
- Log entries for EOF stream messages are now considered successes to avoid setting off false alarms. The successful log entries still carry the "error" field, which will reflect the EOF error.
- Simplified the flow of status change notifications for the gRPC and TChannel transports to reduce the liklihood of deadlocks.
- Increase default HTTP timeout to avoid stop timeout errors when the server has a new idle connection.
- Close idle connections when the transport is closed.
- Added fail-fast option to peer lists. With this option enabled, a peer list will return an error if no peers are connected at the time of a call, instead of waiting for an available peer or the context to time out.
- Previously, every peer list reported itself as a "single" peer list for purposes of debugging, instead of its own name.
- Metrics emit
CodeResourceExhausted
as a client error andCodeUnimplemented
as a server error. - Simplified the flow of status change notifications for the HTTP transport to reduce the liklihood of deadlocks.
- Removed a bug from the gRPC transport that would cause a very rare deadlock during production deploys and restarts. The gRPC peer release method would synchronize with the connection status change monitor loop, waiting for it to exit. This would wait forever since retain was called while holding a lock on the list.
- Fixed TChannel memory pressure that would occur during server-side errors.
- Added improved logging and metrics for streams and streaming messages.
- Log level configuration can now be expressed specifically for every combination of inbound and outbound, for success, failure, and application error.
- A peer list and transport stress tester is now in the
yarpctest
package. - Added
direct
peer chooser to enable directly addressable peers. - Added custom dialer option for outbound HTTP requests.
- Added custom dialer option for outbound gRPC requests.
- call.HeaderNames() now specifies a capacity when creating a slice, which should improve the call.HeaderNames()'s performance.
- Observability middleware will always emit an error code if the returned error
is from the
yarpcerrors
package.
- Added error details support in protobuf over gRPC and HTTP.
- Protobuf JSON encoding can take a custom gogo/protobuf/jsonpb.AnyResolver with Fx.
- The Thrift encoding attempts to close the request body immediately after reading the request bytes. This significantly reduces TChannel/Thrift memory usage in some scenarios.
- Fixed duplicated tracing headers being set with gRPC.
- Fixed pending heap deadlock that occured when attempting to remove a peer that was already removed.
- Revert: Use separate context for grpc streams once dial has been completed.
- Fix fewest pending heap panic that occurs when calling a peer and removing it simultaneously.
- Use separate context for grpc streams once dial has been completed.
- Removed error name validation.
- Updated dependency on ThriftRW.
- The log level for application errors is now configurable with yarpcconfig and with yarpc.NewDispatcher.
- Upgrade a read-lock to a read-write lock around peer selection. This addresses a data race observed in production that results in broken peer list invariants.
- Reverted HTTP transport marking peers as unavailable when the remote side closes the connection due to a deadlock.
- Fixed a deadlock issue when the HTTP transport detects a connection failure and attempts to lock once to obtain the peer, then again to send notifications.
- Added
encoding/protobuf/reflection
for exposing server reflection related information through codegeneration. For docs related to server reflection read https://github.com/grpc/grpc/blob/master/doc/server-reflection.md. protoc-gen-yarpc-go
now generatesyarpcfx
fx groups containing information required for building server reflection API's.
- Using a
http.Outbound
previously leaked implementation details that it was using a*http.Client
underneath, when attempting to cast ahttp.Outbound
into ahttp.RoundTripper
- Adds
thrift.Named
option for appropriately labelling procedures inherited from other thrift services. - The HTTP protocol now marks peers as unavailable immediately when the remote side closes the connection.
- Calling extended Thrift service procedures previously called the base service's procedures.
- x/yarpctest: Add a retry option to HTTP/TChannel/GRPCRequest.
- Added
peer/tworandomchoices
, an implementation of the Two Random Choices load balancer algorithm. - Reintroduce Transport field matching for
transporttest.RequestMatcher
.
- HTTP inbounds gracefully shutdown with an optional timeout, defaulting to 5 seconds.
- Address data races in yarpctest.FakeTransport
- Revert Transport field match from RequestMatcher
- CHANGELOG.md and version.go changes were still incorrect for v1.32.1
- CHANGELOG.md and version.go changes were incorrect for v1.32.0
- Adds inbound and outbound TLS support for gRPC. See
gprc.InboundCredentials
,grpc.DialerCredentials
, andgrpc.Transport.NewDialer
for usage. - Added
peer/peerlist/v2
which differs from the originalpeer/peerlist
by replacing the use ofapi/peer.ListImplementation
withpeer/peerlist/v2.Implementation
, which threads the peer separately from the peer identifier. This allows us to thread shard information from the peer list updater to a sharding peer list. - Added connection/disconnection simulation to the
yarpctest
fake transport and peers. - x/yarpctest: Added support for specifying outbound middleware.
- yarpctest: Changed
FakePeer
id to use "go.uber.org/yarpc/api/peer".Identifier interface instead of the concrete "go.uber.org/peer/hostport".Identifier type.
- The HTTP protocol now mitigates peers that are unavailable due to a half-open
TCP connection.
Previously, if a peer shut down unexpectedly, it might fail to send a TCP FIN
packet, leaving the sender unaware that the peer is unavailable.
The symptom is that requests sent down this connection will time out.
This change introduces a suspicion window for peers that time out.
Once per suspicion window, the HTTP transport's peer manager will attempt
to establish a fresh TCP connection to the peer.
Failing to establish a connection will transition the peer to the unavailable
state until a fresh TCP connection becomes available.
The HTTP transport now accepts an
InnocenceWindow
duration, and aninnocenceWindow
config field.
- Added
Outbounds()
onDispatcher
to provide access to the configured outbounds. - Expose capacity option to configurator for the round-robin peer chooser.
- Expose capacity option to configurator for the fewest pending heap peer chooser.
- Dispatchers now log recovered handler panics via a Zap logger, if present.
- Responses for all transports now include a header containing the name of the service that handled the request.
- TChannel inbounds will blackhole requests when handlers return resource exhausted errors.
- Change log level to reflect error statuses. Previously all logs were logged at debug level. Errors are now logged at error level.
- Update pin for gogo/protobuf to ^1
- The YARPC HTTP outbound now implements http.RoundTripper. This makes YARPC's load balancers, other peer selectors, and peer availability management accessible to REST call sites.
- Adds
Addr()
ongrpc.Inbound
to expose the address the server is listening on when the server is running. - Adds Transport property to transport.Request and transport.RequestMeta Metrics will now be tagged with the transport of calls to handlers
- YARPC HTTP, gRPC, and TChannel transports are now compatible with any peer.Identifier implementation. They previously required a hostport.PeerIdentifier for RetainPeer and ReleasePeer calls.
- Removed
repo:
from glide.yaml because Apache Thrift development has moved to GitHub (https://issues.apache.org/jira/browse/INFRA-16287).
- Add methods to start and stop a dispatcher's transports, inbounds, and outbounds separately.
- Add
NewFx{{Service}}YARPCClient
andNewFx{{Service}}YARPCProcedures
generated methods from protoc-gen-yarpc-go for Fx.
- Enabled random shuffling of peerlist order by default.
- Reintroduce envelope-agnostic Thrift inbounds. Thrift inbounds will now accept Thrift requests with or without envelopes. This feature was originally added in 1.26.0 and removed in 1.26.1 because the implementation introduced an inbound request data corruption hazard.
- Adds an option to the TChannel transport to carry headers in their original form, instead of normalizing their case.
- Adds an option to disable observability middleware, in the event you provide alternate observability middleware.
- Removed buffer pooling from GRPC outbound requests which had possible data corruption issues.
- Regenerate thrift files.
- Add support for Inbound and Outbound streaming RPCs using gRPC and Protobuf.
- Add support for creating peer choosers through config with PeerChooserSpec.
- Add the option of injecting a
"go.uber.org/net/metrics".Scope
into the dispatcher metrics configuration, in lieu of a Tally Scope. Metrics scopes support in memory and Prometheus collection.
- Detect buffer pooling bugs by detecting concurrent accesses in production and more thorough use-after-free detection in tests.
- Removed buffer pooling from GRPC inbound responses which had possible data corruption issues.
- TChannel inbound response errors are now properly mapped from YARPC errors.
- Removed buffer pooling from GRPC inbound responses which had possible data corruption issues.
- Reverts the integration for envelope-agnostic Thrift. This change introduced data corruption to request bodies due to a buffer pooling bug.
- Support envelope-agnostic Thrift inbounds. Thrift inbounds will now accept Thrift requests with or without envelopes.
- Wrap errors returned from lifecycle.Once functions in the yarpcerrors API.
- Wrap errors returned from tchannel outbounds in the yarpcerrors API.
- Revert Providing a better error message if outbound calls are made or inbound calls are received before Dispatcher start or after Dispatcher stop.
- Make Dispatcher start/stop thread-safe.
- Validate all oneway calls have a TTL.
- Add opentracing tags to denote the YARPC version and Golang version to the gRPC and HTTP transports.
- Provide a better error message if outbound calls are made or inbound calls are received before Dispatcher start or after Dispatcher stop.
- Undeprecate ClientConfig function.
- Introduces
api/peer.ListImplementation
withpeer/peerlist.List
, a building block that provides peer availability management for peer lists like round-robin, hash-ring. - Adds /x/yarpctest infrastructure to create fake services and requests for tests.
- Adds a
peer/pendingheap
implementation that performs peer selection, sending requests to the available peer with the fewest pending requests. - Adds
OutboundConfig
andMustOutboundConfig
functions to the dispatcher to replace the ClientConfig function.
- Thrift: Fx modules generated by the ThriftRW plugin now include a function to register procedures with YARPC.
- Fix a bug in protoc-gen-yarpc-go where request or response types for methods in the same package but in a different file would result in an extraneous import.
- Add a Logger option to the HTTP, GRPC, and TChannel transports to allow for internal logging.
- http: Fix
http.Interceptor
ignoringhttp.Mux
.
- http: Add
http.Interceptor
option to inbounds, which allows intercepting incoming HTTP requests for that inbound.
- transport/grpc: Fix deadlock where Peers can never be stopped if their corresponding Transport was not started.
- transport/grpc: Add Chooser function to Outbound for testing.
- Promote
transport/x/grpc
out of experimental status, moving it totransport/grpc
.
- Remove staticcheck from glide.yaml.
- Add inbound/outbound direction tag to observability metrics.
- Remove x/retry to incubate internally.
- yarpcerrors: Undeprecate per error type creation and validation functions.
- yarpcerrors: Make core API much simpler and use a Status struct to represent YARPC errors.
- transport/http: Add GrabHeaders option to propagate specific headers starting with x- to handlers.
- tranxport/x/grpc: Remove ContextWrapper.
- Export no-op backoff strategy in api/backoff.
- ThriftRW Plugin: Added an option to strip TChannel-specific information from Contexts before making outgoing requests.
- x/retry: Fix bug where large TChannel responses would cause errors in retries.
- transport/http: Correct the Content-Type for Thrift responses, to
application/vnd.apache.thrift.binary
. - transport/http: Correct the Content-Type for Proto responses, to
application/x-protobuf
.
- yarpcerrors: Update the ErrorCode and ErrorMessage functions to return default values for non-YARPC errors.
- transport/http: Return appropriate Content-Type response headers based on the transport encoding.
- transport/x/grpc: Add options to specify the maximum message size sent and received over the wire.
- Increased granularity of error observability metrics to expose yarpc error types.
- Wrapped peer list
Choose
errors in yarpc error codes. - x/retry: Add granular metric counters for retry middleware.
- Removed experimental redis and cherami transports.
- Rename structured logging field to avoid a type collision.
- Added a
yarpc.ClientConfig
interface to provide access to ClientConfigs. All Dispatchers already implement this interface. - Thrift: Fx modules generated by the ThriftRW plugin now rely on
yarpc.ClientConfig
instead of the Dispatcher. - Promote
x/config
out of experimental status, moving it toyarpcconfig
.
- Fixed issue with github.com/apache/thrift by pinning to version 0.9.3 due to breaking change https://issues.apache.org/jira/browse/THRIFT-4261.
Experimental:
- x/debug: Added support for debug pages for introspection.
- Fixed bug where outbound HTTP errors were not being properly wrapped in yarpc errors.
Experimental:
- x/retry: Added support for procedure-based retry policies.
- x/retry: Fixed bug in retry middleware where a failed request that did not read the request body would not be retried.
- x/grpc: Altered inbound GRPC code in order to support RouterMiddleware.
- Thrift: UberFx-compatible modules are now generated for each service inside
a subpackage. Disable this by passing a
-no-fx
flag to the plugin. - Improves resilience of HTTP and TChannel by broadcasting peer availability to peer lists like round robin. A round robin or least pending peer list blocks requests until a peer becomes available.
- Add support for reading ShardKey, RoutingKey, and RoutingDelegate for inbound http and tchannel calls.
- Move encoding/x/protobuf to encoding/protobuf.
- Exposes the Lifecycle synchronization helper as pkg/lifecycle, for third-party implementations of transports, inbounds, outbounds, peer lists, and peer list bindings.
Experimental:
- x/retry: Added support for creating retry middleware directly from config.
- Different encodings can now register handlers under the same procedure name.
- http: Added support for configuring the HTTP transport using x/config.
- tchannel: Added support for configuring the TChannel transport using x/config.
- Moved the RoundRobin Peer List out of the /x/ package.
- Fixed race conditions in hostport.Peer.
- Buffers for inbound Thrift requests are now pooled to reduce allocations.
Experimental:
- x/cherami: Renamed the
InboundConfig
andOutboundConfig
structures toInboundOptions
andOutboundOptions
. - x/cherami: Added support for configuring the Cherami transport using x/config.
- x/roundrobin: Added support for taking peer list updates before and after the peer list has been started.
- x/config: Fix bug where embedded struct fields could not be interpolated.
- x/config: Fix bug where Chooser and Updater fields could not be interpolated.
- x/grpc: Remove
NewInbound
andNewSingleOutbound
in favor of methods onTransport
. - x/grpc: Use
rpc-caller
,rpc-service
,rpc-encoding
,rpc-shard-key
,rpc-routing-key
,rpc-routing-delegate
headers. - x/protobuf: Handle JSON-encoded protobuf requests and return JSON-encoded
protobuf responses if the
rpc-encoding
header is set tojson
. Protobuf clients may use JSON by supplying theprotobuf.UseJSON
option. - x/protobuf: Support instantiating clients with
yarpc.InjectClients
. - x/protobuf: The wire representation of request metadata was changed. This will break existing users of this encoding.
- Adds consistent structured logging and metrics to all RPCs. This feature
may be enabled and configured through
yarpc.Config
. - Adds an
http.AddHeader
option to HTTP outbounds to send certain HTTP headers for all requests. - Options
thrift.Multiplexed
andthrift.Enveloped
may now be provided for Thrift clients constructed byyarpc.InjectClients
by adding athrift
tag to the corresponding struct field with the name of the option. See the Thrift package documentation for more details. - Adds support for matching and constructing
UnrecognizedProcedureError
s indicating that the router was unable to find a handler for the request. - Adds support for linking peer lists and peer updaters using the
peer.Bind
function. - Adds an accessor to Dispatcher which provides access to the inbound middleware used by that Dispatcher.
- Fixes a bug where the TChannel inbounds would not write the response headers if the response body was empty.
Experimental:
- x/config: The service name is no longer part of the configuration and must
be passed as an argument to the
LoadConfig*
orNewDispatcher*
methods. - x/config: Configuration structures may now annotate primitive fields with
config:",interpolate"
to support reading environment variables in them. See theTransportSpec
documentation for more information.
- Thrift: Fixed a bug where deserialization of large lists would return corrupted data at high throughputs.
- x/config adds support for a pluggable configuration system that allows
building
yarpc.Config
andyarpc.Dispatcher
objects from YAML and arbitrarymap[string]interface{}
objects. Check the package documentation for more information. - tchannel: mask existing procedures with provided procedures.
- Adds a peer.Bind function that takes a peer.ChooserList and a binder (anything that binds a peer list to a peer provider and returns the Lifecycle of the binding), and returns a peer.Chooser that combines the lifecycle of the peer list and its bound peer provider. The peer chooser is suitable for passing to an outbound constructor, capturing the lifecycle of its dependencies.
- Adds a peer.ChooserList interface to the API, for convenience when passing instances with both capabilities (suitable for outbounds, suitable for peer list updaters).
- Remove buffer size limit from Thrift encoding/decoding buffer pool.
- Increased efficiency of inbound/outbound requests by pooling buffers.
- Added MaxIdleConnsPerHost option to HTTP transports. This option will configure the number of idle (keep-alive) outbound connections the transport will maintain per host.
- Fixed bug in Lifecycle Start/Stop where we would run the Stop functionality even if Start hadn't been called yet.
- Updated RoundRobin and PeerHeap implementations to block until the list has started or a timeout had been exceeded.
- Increased efficiency of Thrift encoding/decoding by pooling buffers.
- x/yarpcmeta make it easy to expose the list of procedures and other introspection information of a dispatcher on itself.
- Redis:
Client
now has anIsRunning
function to match theLifecycle
interface. - TChannel: bug fix that allows a YARPC proxy to relay requests for any inbound service name. Requires upgrade of TChannel to version 1.4 or greater.
- Relaxed version constraint for
jaeger-client-go
to>= 1, < 3
. - TChannel transport now supports procedures with a different service name than the default taken from the dispatcher. This brings the TChannel transport up to par with HTTP.
-
Added a
tchannel.NewTransport
. The new transport, a replacement for the temporarytchannel.NewChannelTransport
, supports YARPC peer choosers.transport, err := tchannel.NewTransport(tchannel.ServiceName("keyvalue")) chooser := peerheap.New(transport) outbound := transport.NewOutbound(chooser)
The new transport hides the implementation of TChannel entirely to give us flexibility going forward to relieve TChannel of all RPC-related responsibilities, leaving only the wire protocol at its core. As a consequence, you cannot thread an existing Channel through this transport.
-
All outbounds now support
Call
beforeStart
and all peer choosers now supportChoose
beforeStart
, within the context deadline. These would previously return an error indicating that the component was not yet started. They now wait for the component to start, or for their deadline to expire.
-
Added heap based PeerList under
peer/x/peerheap
. -
Added
RouterMiddleware
parameter toyarpc.Config
, which, if provided, will allow customizing routing to handlers. -
Added experimental
transports/x/cherami
for transporting RPCs through Cherami. -
Added ability to specify a ServiceName for outbounds on the transport.Outbounds object. This will allow defining outbounds with a
key
that is different from the service name they will use for requests. If no ServiceName is specified, the ServiceName will fallback to the config.Outbounds mapkey
.Before:
config.Outbounds['service'] := transport.Outbounds{ Unary: httpTransport.NewSingleOutbound(...) } ... cc := dispatcher.ClientConfig('service') cc.Service() // returns 'service'
After (optional):
config.Outbounds['service-key'] := transport.Outbounds{ ServiceName: 'service' Unary: httpTransport.NewSingleOutbound(...) } ... cc := dispatcher.ClientConfig('service-key') cc.Service() // returns 'service'
- Thrift: Mock clients compatible with gomock are now generated for each
service inside a test subpackage. Disable this by passing a
-no-gomock
flag to the plugin.
- Thrift: Fixed code generation for empty services.
- Thrift: Fixed code generation for Thrift services that inherit other Thrift services.
- Stable release: No more breaking changes will be made in the 1.x release series.
-
Breaking: The ThriftRW plugin now generates code under the subpackages
${service}server
and$[service}client
rather thanyarpc/${service}server
andyarpc/${service}client
.Given a
kv.thrift
that defines aKeyValue
service, previously the imports would be,import ".../kv/yarpc/keyvalueserver" import ".../kv/yarpc/keyvalueclient"
The same packages will now be available at,
import ".../kv/keyvalueserver" import ".../kv/keyvalueclient"
-
Breaking:
NewChannelTransport
can now return an error upon construction. -
Breaking:
http.URLTemplate
has no effect onhttp.NewSingleOutbound
. -
http.Transport.NewOutbound
now acceptshttp.OutboundOption
s.
-
Breaking: Removed the
yarpc.ReqMeta
andyarpc.ResMeta
types. To migrate your handlers, simply drop the argument and the return value from your handler definition.Before:
func (h *myHandler) Handle(ctx context.Context, reqMeta yarpc.ReqMeta, ...) (..., yarpc.ResMeta, error) { // ... }
After:
func (h *myHandler) Handle(ctx context.Context, ...) (..., error) { // ... }
To access information previously available in the
yarpc.ReqMeta
or to write response headers, use theyarpc.CallFromContext
function. -
Breaking: Removed the
yarpc.CallReqMeta
andyarpc.CallResMeta
types. To migrate your call sites, drop the argument and remove the return value.Before:
res, resMeta, err := client.Call(ctx, reqMeta, ...)
After:
res, err := client.Call(ctx, ...)
Use
yarpc.CallOption
s to specify per-request options andyarpc.ResponseHeaders
to receive response headers for the call. -
Breaking: Removed
yarpc.Headers
in favor ofmap[string]string
. -
Breaking:
yarpc.Dispatcher
no longer implements thetransport.Router
interface. -
Breaking: Start and Stop for Inbound and Outbound are now expected to be idempotent.
-
Breaking: Combine
ServiceProcedure
andRegistrant
intoProcedure
. -
Breaking: Rename
Registrar
toRouteTable
. -
Breaking: Rename
Registry
toRouter
. -
Breaking: Rename
middleware.{Oneway,Unary}{Inbound,Outbound}Middleware
tomiddleware.{Oneway,Unary}{Inbound,Outbound}
-
Breaking: Changed
peer.List.Update
to accept apeer.ListUpdates
struct instead of a list of additions and removals -
Breaking: yarpc.NewDispatcher now returns a pointer to a yarpc.Dispatcher. Previously, yarpc.Dispatcher was an interface, now a concrete struct.
This change will allow us to extend the Dispatcher after the 1.0.0 release without breaking tests depending on the rigidity of the Dispatcher interface.
-
Breaking:
Peer.StartRequest
andPeer.EndRequest
no longer accept adontNotify
argument. -
Added
yarpc.IsBadRequestError
,yarpc.IsUnexpectedError
andyarpc.IsTimeoutError
functions. -
Added a
transport.InboundBadRequestError
function to build errors which satisfytransport.IsBadRequestError
. -
Added a
transport.ValidateRequest
function to validatetransport.Request
s.
-
Moved the
yarpc/internal/crossdock/
andyarpc/internal/examples
folders toyarpc/crossdock/
andyarpc/examples
respectively. -
Breaking: Relocated the
go.uber.org/yarpc/transport
package togo.uber.org/yarpc/api/transport
. In the process themiddleware
logic from transport has been moved togo.uber.org/yarpc/api/middleware
and the concrete implementation of the Registry has been moved fromtransport.MapRegistry
toyarpc.MapRegistry
. This did not move the concrete implementations of http/tchannel from theyarpc/transport/
directory. -
Breaking: Relocated the
go.uber.org/yarpc/peer
package togo.uber.org/yarpc/api/peer
. This does not include the concrete implementations still in the/yarpc/peer/
directory. -
Breaking: This version overhauls the code required for constructing inbounds and outbounds.
Inbounds and Outbounds now share an underlying Transport, of which there should be one for each transport protocol, so one HTTP Transport for all HTTP inbounds and outbounds, and a TChannel transport for all TChannel inbounds and outbounds.
Before:
ch, err := tchannelProper.NewChannel("example-service", nil) if err != nil { log.Fatalln(err) } yarpc.NewDispatcher(yarpc.Config{ Name: "example-service", yarpc.Inbounds{ http.NewInbound(":80"), tchannel.NewInbound(ch, tchannel.ListenAddr(":4040")), }, yarpc.Outbounds{ http.NewOutbound("http://example-service/rpc/v1"), tchannel.NewOutbound(ch, tchannel.HostPort("127.0.0.1:4040")), }, })
After:
httpTransport := http.NewTransport() tchannelTransport := tchannel.NewChannelTransport( tchannel.ServiceName("example-service"), tchannel.ListenAddr(":4040"), ) yarpc.NewDispatcher(yarpc.Config{ Name: "example-service", yarpc.Inbounds{ httpTransport.NewInbound(":80"), tchannelTransport.NewInbound(), }, yarpc.Outbounds{ httpTransport.NewSingleOutbound("http://example-service/rpc/v1"), tchannelTransport.NewSingleOutbound("127.0.0.1:4040"), }, })
The dispatcher now collects all of the unique transport instances from inbounds and outbounds and manages their lifecycle independently.
This version repurposed the name
NewOutbound
for outbounds with a peer chooser, whereasNewSingleOutbound
is a convenience for creating an outbound addressing a specific single peer. You may need to rename existing usage. The compiler will complain that strings are notpeer.Chooser
instances.This version introduces support for peer choosers, peer lists, and peer list updaters for HTTP outbounds. This is made possible by the above change that introduces a concrete instance of a Transport for each protocol, which deduplicates peer instances across all inbounds and outbounds, making connection sharing and load balancing possible, eventually for all transport protocols.
Note that we use
NewChannelTransport
, as opposed toNewTransport
. We reserve this name for a future minor release that will provide parity with HTTP for outbounds with peer choosers.The new ChannelTransport constructor can still use a shared TChannel Channel instance, if that is required.
ch, err := tchannelProper.NewChannel("example-service", nil) if err != nil { log.Fatalln(err) } tchannelTransport := tchannel.NewChannelTransport( tchannel.WithChannel(ch), tchannel.ServiceName("example-service"), tchannel.ListenAddr(":4040"), ) yarpc.NewDispatcher(yarpc.Config{ Name: "example-service", yarpc.Inbounds{ tchannelTransport.NewInbound(), }, })
-
Breaking: the
transport.Inbound
andtransport.Outbound
interfaces now implementStart()
without any arguments.The dispatcher no longer threads a dependencies object through the start method of every configured transport. The only existing dependency was an opentracing Tracer, which you can now thread through Transport constructor options instead.
Before:
yarpc.NewDispatcher(yarpc.Config{ yarpc.Inbounds{ http.NewInbound(...), }, yarpc.Outbounds{ "callee": http.NewOutbound(...) }, Tracer: opentracing.GlobalTracer(), })
Now:
tracer := opentracing.GlobalTracer() httpTransport := http.NewTransport( http.Tracer(tracer), ) tchannelTransport := tchannel.NewChannelTransport( tchannel.Tracer(tracer), ) yarpc.NewDispatcher(yarpc.Config{ Name: "example-service", yarpc.Inbounds{ httpTransport.NewInbound(":80"), tchannelTransport.NewInbound(), }, yarpc.Outbounds{ httpTransport.NewSingleOutbound("http://example-service/rpc/v1"), tchannelTransport.NewSingleOutbound("127.0.0.1:4040"), }, })
The
yarpc.Config
Tracer
property is still accepted, but unused and deprecated.The dispatcher no longer provides a
transport.ServiceDetail
as an argument toStart
on inbound transports. Thetransport.ServiceDetail
no longer exists. You no longer need to provide the service name to start an inbound, only a registry. Instead of passing the service detail to start, the dispatcher now callsinbound.SetRegistry(transport.Registry)
before callingStart()
.Custom transport protocols must change their interface accordingly to satisfy the
transport.Inbound
interface. Uses that construct inbounds manually must either callSetRegistry
or use theWithRegistry
chained configuration method before callingStart
without aServiceDetail
.Before:
inbound := tchannel.NewInbound(...) err := inbound.Start( transport.ServiceDetail{ Name: "service", Registry: registry, }, transport.NoDeps, )
Now:
transport := tchannel.NewTransport() inbound := transport.NewInbound() inbound.SetRegistry(registry) err := inbound.Start()
The
transport.Deps
struct andtransport.NoDeps
instance no longer exist. -
Breaking: TChannel inbound and outbound constructors now return pointers to Inbound and Outbound structs with private state satisfying the
transport.Inbound
andtransport.Outbound
interfaces. These were previously transport specific Inbound and Outbound interfaces. This eliminates unnecessary polymorphism in some cases. -
Introduced OpenTracing helpers for transport authors.
-
Created the
yarpc.Serialize
package for marshalling RPC messages at rest. Useful for transports that persist RPC messages. -
Tranports have access to
DispatchOnewayHandler
andDispatchUnaryHandler
. These should be called by alltransport.Inbounds
instead of directly calling handlers.
- Breaking Renamed
Agent
toTransport
. - Breaking Renamed
hostport.Peer
'sAddSubscriber/RemoveSubscriber
toSubscribe/Unsubscribe
. - Breaking Updated
Peer.StartRequest
to take adontNotify
peer.Subscriber
to exempt from updates. Also addedPeer.EndRequest
function to replace thefinish
callback fromPeer.StartRequest
. - Breaking Renamed
peer.List
topeer.Chooser
,peer.ChangeListener
topeer.List
andpeer.Chooser.ChoosePeer
topeer.Chooser.Choose
. - Reduced complexity of
single
peer.Chooser
to retain the passed in peer immediately. - Breaking Moved
/peer/list/single.go
to/peer/single/list.go
. - Breaking Moved
/peer/x/list/roundrobin.go
to/peer/x/roundrobin/list.go
. - HTTP Oneway requests will now process http status codes and returns appropriate errors.
- Breaking Update
roundrobin.New
function to stop accepting an initial peer list. Uselist.Update
to initialize the peers in the list instead. - Breaking: Rename
Channel
toClientConfig
for both the dispatcher method and the interface.mydispatcher.Channel("myservice")
becomesmydispatcher.ClientConfig("myservice")
. TheClientConfig
object can then used to build a new Client as before:NewMyThriftClient(mydispatcher.ClientConfig("myservice"))
. - A comment is added atop YAML files generated by the recorder to help understanding where they come from.
-
Breaking: Rename the
Interceptor
andFilter
types toUnaryInboundMiddleware
andUnaryOutboundMiddleware
respectively. -
Breaking:
yarpc.Config
now accepts middleware using theInboundMiddleware
andOutboundMiddleware
fields.Before:
yarpc.Config{Interceptor: myInterceptor, Filter: myFilter}
Now:
yarpc.Config{ InboundMiddleware: yarpc.InboundMiddleware{Unary: myInterceptor}, OutboundMiddleware: yarpc.OutboundMiddleware{Unary: myFilter}, }
-
Add support for Oneway middleware via the
OnewayInboundMiddleware
andOnewayOutboundMiddleware
interfaces.
- Breaking: A detail of inbound transports has changed.
Starting an inbound transport accepts a ServiceDetail, including
the service name and a Registry. The Registry now must
implement
Choose(context.Context, transport.Request) (HandlerSpec, error)
instead ofGetHandler(service, procedure string) (HandlerSpec, error)
. Note that in the prior release,Handler
becameHandleSpec
to accommodate oneway handlers. - Upgrade to ThriftRW 1.0.
- TChannel:
NewInbound
andNewOutbound
now accept any object satisfying theChannel
interface. This should work with existing*tchannel.Channel
objects without any changes. - Introduced
yarpc.Inbounds
to be used instead of[]transport.Inbound
when configuring a Dispatcher. - Add support for peer lists in HTTP outbounds.
This release requires regeneration of ThriftRW code.
-
Breaking: Procedure registration must now always be done directly against the
Dispatcher
. Encoding-specific functionsjson.Register
,raw.Register
, andthrift.Register
have been deprecated in favor of theDispatcher.Register
method. Existing code may be migrated by running the following commands on your go files.gofmt -w -r 'raw.Register(d, h) -> d.Register(h)' $file.go gofmt -w -r 'json.Register(d, h) -> d.Register(h)' $file.go gofmt -w -r 'thrift.Register(d, h) -> d.Register(h)' $file.go
-
Add
yarpc.InjectClients
to automatically instantiate and inject clients into structs that need them. -
Thrift: Add a
Protocol
option to change the Thrift protocol used by clients and servers. -
Breaking: Remove the ability to set Baggage Headers through yarpc, use opentracing baggage instead
-
Breaking: Transport options have been removed completely. Encoding values differently based on the transport is no longer supported.
-
Breaking: Thrift requests and responses are no longer enveloped by default. The
thrift.Enveloped
option may be used to turn enveloping on when instantiating Thrift clients or registering handlers. -
Breaking: Use of
golang.org/x/net/context
has been dropped in favor of the standard library'scontext
package. -
Add support for providing peer lists to dynamically choose downstream peers in HTTP Outbounds
-
Rename
Handler
interface toUnaryHandler
and separateOutbound
interface intoOutbound
andUnaryOutbound
. -
Add
OnewayHandler
andHandlerSpec
to support oneway handlers. Transport inbounds can choose which RPC types to accept -
The package
yarpctest.recorder
can be used to record/replay requests during testing. A command line flag (--recorder=replay|append|overwrite
) is used to control the mode during the execution of the test.
- Fix missing canonical import path to
go.uber.org/yarpc
.
- Breaking: Rename project to
go.uber.org/yarpc
. - Breaking: Switch to
go.uber.org/thriftrw ~0.3
fromgithub.com/thriftrw/thriftrw-go ~0.2
. - Update opentracing-go to
>= 1, < 2
.
- Loosen constraint on
opentracing-go
to>= 0.9, < 2
.
- Update thriftrw-go to
>= 0.2, < 0.3
. - Implemented a ThriftRW plugin. This should now be used instead of the
ThriftRW
--yarpc
flag. Check the documentation of the thrift package for instructions on how to use it. - Adds support for opentracing. Pass an opentracing instance as a
Tracer
property of the YARPC config struct and both TChannel and HTTP transports will submit spans and propagate baggage. - This also modifies the public interface for transport inbounds and outbounds, which must now accept a transport.Deps struct. The deps struct carries the tracer and may eventually carry other dependencies.
- Panics from user handlers are recovered. The panic is logged (stderr), and an unexpected error is returned to the client about it.
- Thrift clients can now make requests to multiplexed Apache Thrift servers
using the
thrift.Multiplexed
client option.
- Use
github.com/yarpc/yarpc-go
as the import path; revert use ofgo.uber.org/yarpc
vanity path. There is an issue in Glide0.11
which causes installing these packages to fail, and thriftrw~0.1
's yarpc template is still usinggithub.com/yarpc/yarpc-go
.
- Initial release. [Unreleased]: https://github.com/yarpc/yarpc-go/compare/v1.58.0...HEAD [1.58.0]: https://github.com/yarpc/yarpc-go/compare/v1.57.1...v1.58.0 [1.57.1]: https://github.com/yarpc/yarpc-go/compare/v1.57.0...v1.57.1 [1.57.0]: https://github.com/yarpc/yarpc-go/compare/v1.56.1...v1.57.0 [1.56.1]: https://github.com/yarpc/yarpc-go/compare/v1.56.0...v1.56.1 [1.56.0]: https://github.com/yarpc/yarpc-go/compare/v1.55.1...v1.56.0 [1.55.1]: https://github.com/yarpc/yarpc-go/compare/v1.55.0...v1.55.1 [1.55.0]: https://github.com/yarpc/yarpc-go/compare/v1.54.2...v1.55.0 [1.54.2]: https://github.com/yarpc/yarpc-go/compare/v1.54.1...v1.54.2 [1.54.1]: https://github.com/yarpc/yarpc-go/compare/v1.54.0...v1.54.1 [1.54.0]: https://github.com/yarpc/yarpc-go/compare/v1.53.2...v1.54.0 [1.53.2]: https://github.com/yarpc/yarpc-go/compare/v1.53.1...v1.53.2 [1.53.1]: https://github.com/yarpc/yarpc-go/compare/v1.51.0...v1.52.0 [1.53.0]: https://github.com/yarpc/yarpc-go/compare/v1.52.0...v1.53.0 [1.52.0]: https://github.com/yarpc/yarpc-go/compare/v1.51.0...v1.52.0 [1.51.0]: https://github.com/yarpc/yarpc-go/compare/v1.50.0...v1.51.0 [1.50.0]: https://github.com/yarpc/yarpc-go/compare/v1.49.1...v1.50.0 [1.49.1]: https://github.com/yarpc/yarpc-go/compare/v1.49.0...v1.49.1 [1.49.0]: https://github.com/yarpc/yarpc-go/compare/v1.48.0...v1.49.0 [1.48.0]: https://github.com/yarpc/yarpc-go/compare/v1.47.2...v1.48.0 [1.47.2]: https://github.com/yarpc/yarpc-go/compare/v1.47.1...v1.47.2 [1.47.1]: https://github.com/yarpc/yarpc-go/compare/v1.47.0...v1.47.1 [1.47.0]: https://github.com/yarpc/yarpc-go/compare/v1.46.0...v1.47.0 [1.46.0]: https://github.com/yarpc/yarpc-go/compare/v1.45.0...v1.46.0 [1.45.0]: https://github.com/yarpc/yarpc-go/compare/v1.44.0...v1.45.0 [1.44.0]: https://github.com/yarpc/yarpc-go/compare/v1.43.0...v1.44.0 [1.43.0]: https://github.com/yarpc/yarpc-go/compare/v1.42.1...v1.43.0 [1.42.1]: https://github.com/yarpc/yarpc-go/compare/v1.42.0...v1.42.1 [1.42.0]: https://github.com/yarpc/yarpc-go/compare/v1.41.0...v1.42.0 [1.41.0]: https://github.com/yarpc/yarpc-go/compare/v1.40.0...v1.41.0 [1.40.0]: https://github.com/yarpc/yarpc-go/compare/v1.39.0...v1.40.0 [1.39.0]: https://github.com/yarpc/yarpc-go/compare/v1.38.0...v1.39.0 [1.38.0]: https://github.com/yarpc/yarpc-go/compare/v1.37.4...v1.38.0 [1.37.4]: https://github.com/yarpc/yarpc-go/compare/v1.37.3...v1.37.4 [1.37.3]: https://github.com/yarpc/yarpc-go/compare/v1.37.2...v1.37.3 [1.37.2]: https://github.com/yarpc/yarpc-go/compare/v1.37.1...v1.37.2 [1.37.1]: https://github.com/yarpc/yarpc-go/compare/v1.37.0...v1.37.1 [1.37.0]: https://github.com/yarpc/yarpc-go/compare/v1.36.2...v1.37.0 [1.36.2]: https://github.com/yarpc/yarpc-go/compare/v1.36.1...v1.36.2 [1.36.1]: https://github.com/yarpc/yarpc-go/compare/v1.36.0...v1.36.1 [1.36.0]: https://github.com/yarpc/yarpc-go/compare/v1.35.2...v1.36.0 [1.35.2]: https://github.com/yarpc/yarpc-go/compare/v1.35.1...v1.35.2 [1.35.1]: https://github.com/yarpc/yarpc-go/compare/v1.35.0...v1.35.1 [1.35.0]: https://github.com/yarpc/yarpc-go/compare/v1.34.0...v1.35.0 [1.34.0]: https://github.com/yarpc/yarpc-go/compare/v1.33.0...v1.34.0 [1.33.0]: https://github.com/yarpc/yarpc-go/compare/v1.32.4...v1.33.0 [1.32.4]: https://github.com/yarpc/yarpc-go/compare/v1.32.3...v1.32.4 [1.32.3]: https://github.com/yarpc/yarpc-go/compare/v1.32.2...v1.32.3 [1.32.2]: https://github.com/yarpc/yarpc-go/compare/v1.32.1...v1.32.2 [1.32.1]: https://github.com/yarpc/yarpc-go/compare/v1.32.0...v1.32.1 [1.32.0]: https://github.com/yarpc/yarpc-go/compare/v1.31.0...v1.32.0 [1.31.0]: https://github.com/yarpc/yarpc-go/compare/v1.30.0...v1.31.0 [1.30.0]: https://github.com/yarpc/yarpc-go/compare/v1.29.1...v1.30.0 [1.29.1]: https://github.com/yarpc/yarpc-go/compare/v1.29.0...v1.29.1 [1.29.0]: https://github.com/yarpc/yarpc-go/compare/v1.28.0...v1.29.0 [1.28.0]: https://github.com/yarpc/yarpc-go/compare/v1.27.2...v1.28.0 [1.27.2]: https://github.com/yarpc/yarpc-go/compare/v1.27.1...v1.27.2 [1.27.1]: https://github.com/yarpc/yarpc-go/compare/v1.27.0...v1.27.1 [1.27.0]: https://github.com/yarpc/yarpc-go/compare/v1.26.2...v1.27.0 [1.26.2]: https://github.com/yarpc/yarpc-go/compare/v1.26.1...v1.26.2 [1.26.1]: https://github.com/yarpc/yarpc-go/compare/v1.26.0...v1.26.1 [1.26.0]: https://github.com/yarpc/yarpc-go/compare/v1.25.1...v1.26.0 [1.25.1]: https://github.com/yarpc/yarpc-go/compare/v1.25.0...v1.25.1 [1.25.0]: https://github.com/yarpc/yarpc-go/compare/v1.24.1...v1.25.0 [1.24.1]: https://github.com/yarpc/yarpc-go/compare/v1.24.0...v1.24.1 [1.24.0]: https://github.com/yarpc/yarpc-go/compare/v1.22.0...v1.24.0 [1.22.0]: https://github.com/yarpc/yarpc-go/compare/v1.21.1...v1.22.0 [1.21.1]: https://github.com/yarpc/yarpc-go/compare/v1.21.0...v1.21.1 [1.21.0]: https://github.com/yarpc/yarpc-go/compare/v1.20.1...v1.21.0 [1.20.1]: https://github.com/yarpc/yarpc-go/compare/v1.20.0...v1.20.1 [1.20.0]: https://github.com/yarpc/yarpc-go/compare/v1.19.2...v1.20.0 [1.19.2]: https://github.com/yarpc/yarpc-go/compare/v1.19.1...v1.19.2 [1.19.1]: https://github.com/yarpc/yarpc-go/compare/v1.19.0...v1.19.1 [1.19.0]: https://github.com/yarpc/yarpc-go/compare/v1.18.1...v1.19.0 [1.18.1]: https://github.com/yarpc/yarpc-go/compare/v1.18.0...v1.18.1 [1.18.0]: https://github.com/yarpc/yarpc-go/compare/v1.17.0...v1.18.0 [1.17.0]: https://github.com/yarpc/yarpc-go/compare/v1.16.0...v1.17.0 [1.16.0]: https://github.com/yarpc/yarpc-go/compare/v1.15.0...v1.16.0 [1.15.0]: https://github.com/yarpc/yarpc-go/compare/v1.14.0...v1.15.0 [1.14.0]: https://github.com/yarpc/yarpc-go/compare/v1.13.1...v1.14.0 [1.13.1]: https://github.com/yarpc/yarpc-go/compare/v1.13.0...v1.13.1 [1.13.0]: https://github.com/yarpc/yarpc-go/compare/v1.12.1...v1.13.0 [1.12.1]: https://github.com/yarpc/yarpc-go/compare/v1.12.0...v1.12.1 [1.12.0]: https://github.com/yarpc/yarpc-go/compare/v1.11.0...v1.12.0 [1.11.0]: https://github.com/yarpc/yarpc-go/compare/v1.10.0...v1.11.0 [1.10.0]: https://github.com/yarpc/yarpc-go/compare/v1.9.0...v1.10.0 [1.9.0]: https://github.com/yarpc/yarpc-go/compare/v1.8.0...v1.9.0 [1.8.0]: https://github.com/yarpc/yarpc-go/compare/v1.7.1...v1.8.0 [1.7.1]: https://github.com/yarpc/yarpc-go/compare/v1.7.0...v1.7.1 [1.7.0]: https://github.com/yarpc/yarpc-go/compare/v1.6.0...v1.7.0 [1.6.0]: https://github.com/yarpc/yarpc-go/compare/v1.5.0...v1.6.0 [1.5.0]: https://github.com/yarpc/yarpc-go/compare/v1.4.0...v1.5.0 [1.4.0]: https://github.com/yarpc/yarpc-go/compare/v1.3.0...v1.4.0 [1.3.0]: https://github.com/yarpc/yarpc-go/compare/v1.2.0...v1.3.0 [1.2.0]: https://github.com/yarpc/yarpc-go/compare/v1.1.0...v1.2.0 [1.1.0]: https://github.com/yarpc/yarpc-go/compare/v1.0.1...v1.1.0 [1.0.1]: https://github.com/yarpc/yarpc-go/compare/v1.0.0...v1.0.1 [1.0.0]: https://github.com/yarpc/yarpc-go/compare/v1.0.0-rc5...v1.0.0 [1.0.0-rc5]: https://github.com/yarpc/yarpc-go/compare/v1.0.0-rc4...v1.0.0-rc5 [1.0.0-rc4]: https://github.com/yarpc/yarpc-go/compare/v1.0.0-rc3...v1.0.0-rc4 [1.0.0-rc3]: https://github.com/yarpc/yarpc-go/compare/v1.0.0-rc2...v1.0.0-rc3 [1.0.0-rc2]: https://github.com/yarpc/yarpc-go/compare/v1.0.0-rc1...v1.0.0-rc2 [1.0.0-rc1]: https://github.com/yarpc/yarpc-go/compare/v0.5.0...v1.0.0-rc1 [0.5.0]: https://github.com/yarpc/yarpc-go/compare/v0.4.0...v0.5.0 [0.4.0]: https://github.com/yarpc/yarpc-go/compare/v0.3.1...v0.4.0 [0.3.1]: https://github.com/yarpc/yarpc-go/compare/v0.3.0...v0.3.1 [0.3.0]: https://github.com/yarpc/yarpc-go/compare/v0.2.1...v0.3.0 [0.2.1]: https://github.com/yarpc/yarpc-go/compare/v0.2.0...v0.2.1 [0.2.0]: https://github.com/yarpc/yarpc-go/compare/v0.1.1...v0.2.0 [0.1.1]: https://github.com/yarpc/yarpc-go/compare/v0.1.0...v0.1.1