Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(deps): update dependency io.grpc:grpc-protobuf to v1.61.0 - autoclosed #74

Conversation

renovate-bot
Copy link
Contributor

@renovate-bot renovate-bot commented Aug 30, 2021

Mend Renovate

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
io.grpc:grpc-protobuf 1.20.0 -> 1.61.0 age adoption passing confidence

Warning

Some dependencies could not be looked up. Check the Dependency Dashboard for more information.


Release Notes

grpc/grpc-java (io.grpc:grpc-protobuf)

v1.61.0

Compare Source

v1.60.1

Compare Source

Bug Fixes
  • util: Fix NPE when multiple addresses in an address group for petiole load balancer policies (#​10770)

v1.60.0

Compare Source

API Changes
  • api: Stabilize ForwardingServerBuilder, ForwardingChannelBuilder2, and ForwardingChannelBuilder. Note that ForwardingChannelBuilder is stabilized (no changes will be made to it), but immediately deprecated in favor of ForwardingChannelBuilder2. (#​10586)
  • api: Deprecate ForwardingChannelBuilder.delegate(). De facto this deprecates the class itself, since all classes extending ForwardingChannelBuilder implement the delegate() method. See javadoc for details (#​10587)
  • api: Changed recently-introduced LoadBalancer.acceptResolvedAddresses() to return Status instead of boolean (#​10636). This is part of continued work to align the LB API cross-language and API stabilization
  • stub: Deprecate StreamObservers (#​10654)
  • alts: AltsChannelBuilder now extends ForwardingChannelBuilder2 (#​10587)
  • protobuf: Stabilize ProtoUtils.metadataMarshaller() (#​10628)
  • protobuf-lite: ProtoLiteUtils experimental comment (#​10627)
Behavior Changes
  • core: ManagedChannels now check the address types provided by the nameResolver (for the given target) with the address types supported by the channel transport and generate an error in case of mismatch. That dramatically improves the error message when an issue occurs
  • core: When a server stream is closed due to user's code (an uncaught exception in halfClosed, messagesAvailable, onReady callback of a ServerStream's listener), the Status.UNKNOWN returned to the client will have Application error processing RPC description. Previously the description was empty. This is helpful to differentiate between server errors originated in user application, gRPC library, or even those injected by a proxy. (#​10643)
  • xds: Log ORCA UNIMPLEMENTED error to subchannel logger. This removes them from the normal application logs, reducing log spam
Improvements
  • Change the underlying implementations of RingHash, RoundRobin, WeightedRoundRobin and LeastRequest load balancers to utilize the pick first load balancer rather than directly manage subchannels. This should only be noticeable if it introduced a bug
  • core: Avoid flushing headers when the server returns a single response (#​9314). This is a performance optimization to reduce the number of packets for non-streaming responses
  • util: Make grpc-core an implementation dependency. This will prevent the io.grpc.internal classes in grpc-core from being visible during compilation when depending on just grpc-util
  • netty: Implement Http2Headers.isEmpty(). This fixes compatibility with Netty 4.1.101.Final.
  • netty: Add NettyServerBuilder.maxRstFramesPerWindow(). This can be used to limit impact of Rapid Reset
  • netty: Disable huffman coding in headers (#​10563). Huffman coding provides modest compression for relatively high CPU usage, especially within a data center. Rely just on the HPACK static and dynamic tables for compression, for higher performance. This only impacts header values 512 bytes or longer, as Netty already disabled Huffman for smaller values
  • alts: Improve handshake failure error message by propagating original exception (#​10644)
Bug Fixes
  • util: Remove shutdown subchannels from OD tracking (#​10683). This could have caused a memory leak on a long-lived channel. But we don’t think it could be triggered with our built-in load balancing policies.
Dependencies
  • Bump Netty to 4.1.100.Final
Acknowledgements

@​anthonyjpratti
@​fedorka
@​jpd236
@​mateusazis
@​pkoenig10
@​yannickepstein
@​amirhadadi

v1.59.1

Compare Source

  • netty: Implement Http2Headers.isEmpty(). This fixes compatibility with Netty 4.1.101.Final.
  • netty: Add NettyServerBuilder.maxRstFramesPerWindow(). This can be used to limit impact of Rapid Reset
  • xds: Log ORCA UNIMPLEMENTED error to subchannel logger. This removes them from the normal application logs, reducing log spam

v1.59.0

gRPC Java 1.59.0 Release Notes

PLANNED ABI BREAKAGE!

This breaks the ABI of the @ExperimentalApi classes listed below.
This does not impact source code (API); it only impacts code compiled with a different version of gRPC than it runs with (ABI).

Users that recompiled their code using grpc-java v1.36.0 (released on Feb 23, 2021) and later, ARE NOT AFFECTED.
Users that compiled their source using grpc-java earlier than v1.36.0 may need to recompile when upgrading to grpc-java v1.59.0.

See details in #​10406.

Affected classes

Class io.grpc.internal.AbstractManagedChannelImplBuilder is deleted, and no longer in the class hierarchy of the channel builders:

  • io.grpc.netty.NettyChannelBuilder
  • io.grpc.okhttp.OkhttpChannelBuilder
  • io.grpc.cronet.CronetChannelBuilder

Class io.grpc.internal.AbstractServerImplBuilder is deleted, and no longer in the class hierarchy of the server builders:

  • io.grpc.netty.NettyServerBuilder
  • io.grpc.inprocess.InProcessServerBuilder

API Changes
  • core: AbstractManagedChannelImplBuilder and AbstractServerImplBuilder are removed (#​10530). This is ABI-breaking, see the warning above. (#​10406)
  • core: Removed .class file hack previously introduced in v1.36.0 to ease removal of internal ABIs. (#​10406)
  • api: Add ForwardingChannelBuilder2, an ABI-safe version of ForwardingChannelBuilder, which will be deprecated in the following release. (#​10585, #​10406)
  • api: Add LoadBalancer.FixedResultPicker convenience class for load balancer implementations. It is a replacement for ErrorPicker and EMPTY_PICKER added in 1.58.0
  • testing: Stabilize TestMethodDescriptors (#​10530)
Behavior Changes
  • core: de-expermentalize pick first config parsing (#​10531)
  • netty: Respect -Dio.netty.allocator.type=unpooled when getting Netty Allocator instead of ignoring it (#​10543)
  • netty: Use UNAVAILABLE for connections closed while writing. Previously this would result in UNKNOWN
  • binder: Enable indirect addressing using s. (#​10550)
Improvements
  • core: only use reflection to resolve InternalCensusStatsAccessor once instead of once per channel
  • core: enhance error message in the case of DEADLINE_EXCEEDED to indicate name resolution delay.
  • netty: When creating a connection, use java.util.logging formatting instead of String.format to avoid work when not logged
  • netty: Touch ByteBuf when message framing has been decoded. If the buffer is leaked, this helps narrow down the source of reference counting bug
  • java_grpc_library.bzl: Disable Automatic Exec Groups inside grpc libraries (#​10514). This improves compatibility with future Bazel versions while retaining Bazel 5.x compatibility
Bug Fixes
  • netty: Avoid NettyAdaptiveCumulator incorrectly releasing its input ByteBuf twice when reading messages under certain error conditions (#​10537)
  • xds: Add fix for xdstp replacement for percent-encoded authorities (#​10571)
Documentation
  • API documentation (Javadoc) for Server and Channel builders now correctly displays inherited methods and the class hierarchy. (#​10406)
  • examples: add an example for OAuth (#​10560)
Dependencies
  • Upgrade Netty to 4.1.97.Final
Acknowledgements

John Cormie (@​jdcormie)
Stephane Landelle (@​slandelle)
@​kotlaja

v1.58.1

  • xds: PickFirst was not receiving its configuration so it used the default configuration which meant that randomize was ignored.

v1.58.0

API Changes
  • xds: Add missing ExperimentalApi to OrcaServiceImpl
  • stub: Removed deprecated methods attachHeaders and captureMetadata from MetadataUtils (#​10443)
  • api: Stabilized ServerCall.getAuthority() by removing experimental annotation (#​10498)
  • api: Stabilized ServerCall#setMessageCompression() and PartialForwardingServerCall#setMessageCompression() (#​10393)
  • protobuf: Stabilize ProtoUtils.setExtensionRegistry() and ProtoLiteUtils.setExtensionRegistry() (#​10392)
  • testing: Stabilize GrpcCleanupRule, GrpcServerRule (#​10494)
  • api: Stabilized ServerBuilder.handshakeTimeout (#​10499)
  • api: Removed Context.Storage deprecated method attach(), made doAttach() abstract (#​10379)
  • api : Stabilized methodDescriptor getRequestMarshaller, getResponseMarshaller (#​10495)
Behavior Changes
  • rls: Have RLS's LRU Cache rely on cleanup process to remove expired entries (#​10400)
  • core, inprocess, util: 2 new artifacts grpc-inprocess and grpc-util have been created by moving code from grpc-core to facilitate Java module support (#​10362, #​10390)
  • all: Automatic module name support added to all artifacts (#​10413)
  • xds: Encode the service authority in XdsNameResolver (#​10207)
Improvements
  • api: In Javadoc, link to gRFCs A8/A9 for keepalive and related settings
  • okhttp: Enable support for being returned by Grpc.newServerBuilderForPort(). At present, Netty always has higher priority than OkHttp, if they are both available, because ServerBuilder.forPort() is not supported in the OkHttp transport but is supported in the Netty transport
  • bazel: Enhance java_grpc_library.bzl to allow toolchain to use annotation processors
  • examples: Add pre-serialized-message example (#​10112)
  • examples: Android examples to use AGP 7.4.0 (#​10497)
Bug Fixes
  • Fix compatibility with Java 8. This fixes the NoSuchMethodError for ByteBuffer methods present in 1.57.0 (#​10441)
  • xds: Remove debug assert in WeightedRoundRobinLoadBalancer. The assert was to detect breakages in the static stride algorithm causing too much looping. However, with multithreading it is possible to trigger even in legitimate scenarios (#​10437)
  • util: Outlier detection tracer delegation (#​10459)
  • Handle header with errors and endStream = true. Was filling logs with NPEs. (#​10384)
  • core: Fix a retriablestream bug that may cause deadlock with OkHttp (#​10386)
  • stub: Remove ThreadlessExecutor from BlockingServerStream to eliminate the problem where sometimes the iterator’s next() method would get stuck. (#​10496)
  • compiler: Fix aarch_64 macs not being able to build the compiler module. (#​10516)
  • okhttp: Use padded length for flow control in both client and server transport (#​10422)
  • xds: Fix locality logging information in bootstrap (#​10423)
Dependencies
  • Upgraded protobuf to 3.24.0
  • android: Min SDK level to 21 (#​10505)
  • Various dependency upgrades (#​10359):
    androidx.core:core 1.10.0 -> 1.10.1
    com.google.api.grpc:proto-google-common-protos 2.17.0 -> 2.22.0
    com.google.cloud:google-cloud-logging 3.14.5 -> 3.15.5
    com.google.errorprone:error_prone_annotations 2.18.0 -> 2.20.0
    com.squareup.okio:okio 1.17.5 -> 2.10.0
Acknowledgements

Halvard Skogsrud

v1.57.2

Bug Fixes

v1.57.1

Bug fixes
  • Fix compatibility with Java 8. This fixes the NoSuchMethodError for ByteBuffer methods present in 1.57.0 (#​10441)
  • xds: Remove debug assert in WeightedRoundRobinLoadBalancer. The assert was to detect breakages in the static stride algorithm causing too much looping. However, with multithreading it is possible to trigger even in legitimate scenarios (#​10437)

v1.57.0

gRPC Java 1.57.0 Release Notes

This release accidentally broke Java 8: NoSuchMethodError for some ByteBuffer methods. The issue is tracked in https://github.com/grpc/grpc-java/issues/10432 and fixed in 1.57.1.

API Changes
  • Use fully qualified java.lang.String in all cases in generated code. This fixes compilation if a protobuf message is named “String”.
  • Stabilize io.grpc.Status.asRuntimeException(Metadata) and trailersFromThrowable
  • Stabilize io.grpc.ManagedChannelBuilder.useTransportSecurity (#​10244)
  • Stabilize io.grpc.util.MutableHandlerRegistry (#​10348)
Behavior Changes
  • api: CheckedForwardingClientCall now passes trailers from the caught exception
  • context, api: Package io.grpc is now consolidated into a single artifact grpc-api by moving classes from grpc-context to grpc-api. grpc-context now has a dependency on grpc-api (but excludes other dependencies of grpc-api) so any application previously using only grpc-context will now also bring in grpc-api. This fixes #​3522 which was the major issue preventing support of Java modules. We are not done fixing support, as some artifacts need to be split and Automatic-Module-Name needs to be added. The next release is likely to be more stable for modules.
  • core: Change delay for hedging retry after a non-fatal error to be 0 to match the gRFC (A6).
  • core: Wrap other name resolver types in a RetryingNameResolver . Previously, if authority was not overridden, then some name resolvers (such as grpclb) had no retry.
  • xds: Handle loops and duplicates in xds Aggregate clusters
  • xds: require EDS service name in CDS resources with an xdstp name
  • xds: Use Rule order instead of RuleChain
  • xds: Environment variable "GRPC_XDS_EXPERIMENTAL_SECURITY_SUPPORT" is no longer respected, so xDS security cannot be disabled any more (#​10243)
New Features
  • binder: Add UserHandle and BinderChannelCredentials to support cross-user communication (#​10197)
  • xds,orca: LRS named metrics support
Improvements
  • core: Resolve isAndroid only once on class loading. This can improve channel creation performance on Android.
  • xds: Pick a subchannel with new static stride scheduler in WeightedRoundRobinLoadBalancer
Bug Fixes
  • xds: Fix the server sending a GOAWAY when an LDS update with no changes other than ordering is received.
  • netty: Fix NPE when a header with errors is received with endStream=true. This was causing logs to be filled with errors when health checkers didn’t specify a content type.
  • okhttp: Fix the Socket data race when shutdown/closed during connecting that was causing a significant delay
Dependencies
  • Upgraded Netty to 4.1.93-Final
  • Update guava dependency to 32.0.1 to address CVE-2023-2976
Acknowledgements
  • Benjamin Peterson
  • Masakuni Oishi
  • Philip K. Warren
  • Stephane Landelle

v1.56.1

Bug fixes
  • core: Fix regression in 1.54.0 where polling NameResolvers would not refresh after a resolution error (#​10328). The symptom is a transient failure like "UNAVAILABLE: Unable to resolve host" continuing potentially forever. This did not impact DnsNameResolver, but it did impacted GrpclbNameResolver which is the dns name resolver used when grpc-grpclb is in the classpath. So even users that think "I don't use grpclb" may have been impacted. round_robin is mainly impacted on startup, but if the error happened afterward it would commonly fix itself for short transient DNS failures. pick_first is impacted at all times; any failed DNS resolution could cause all future RPCs on the channel to fail.

v1.56.0

API Changes
  • api: Stabilize the SynchronizationContext class (#​10130).
  • api: Stabilize io.grpc.CallCredentials (#​10208, #​10211). thisUsesUnstableApi() is @Deprecated and has a default implementation. CallCredentials implementations should delete their implementation or remove @Overrides, as the method will be deleted in the future.
  • api: Stabilize the ProxyDetector hierarchy and ManagedChannelBuilder.proxyDetector method.
Behavior Changes
  • core: Sticky TRANSIENT_FAILURE in PickFirstLoadBalancer (#​10106). See gRFC A62. If it can't connect, pick-first will now immediately fail RPCs until after it successfully connects. RPCs will no longer be delayed while it performs those attempts, which previously could cause significant (error) latency. It now also performs reconnect attempts after failure and backoff without prompting; previously it required an RPC to trigger the reconnect. ManagedChannel.idleTimeout (defaults to 30 minutes) still applies and forces the channel idle after a period of no RPCs.
  • stub: Add a null check for responseObserver into the methods for initiating a call that takes a responseObserver argument. This ensures a fail fast with a clearer cause instead of an NPE when the observer is first used.
  • xds: Flip default for RLS being enabled to true for XDS (#​10248) (#​10252). If there are no RLS configurations in your XDS or you already enabled it with the environment variable this will have no effect. To disable it, set the flag GRPC_EXPERIMENTAL_XDS_RLS_LB to false.
  • xds: Rename weighted_round_robin_experimental LB Policy to weighted_round_robin (#​10162).
New Features
  • protobuf,protobuf-lite: Allow to configure protobuf recursion limit (#​10094).
  • core: Optional address shuffle in PickFirstLoadBalancer (#​10110).
  • xds: pick_first LB configuration (#​10181).
Improvements
  • xds: Add error-per-second in weight formula for client-side WRR (#​10177).
  • xds: Use application_utilization and fallback to cpu_utilization if unset in weight formula for client-side WRR. (#​10256).
  • bazel: The README now mentions Bazel and where to find the example. (#​10217).
Bug Fixes
  • binder: Handle unexpected exceptions on binder threads. (#​10092.
  • ​​android,binder,cronet: .aar file when publishing. (#​10138).
  • api: Fix boundary check in Status.fromCodeValue(). (#​10155).
  • core: Don't use system Locale for content-type matching. (#​10097).
  • okhttp: Fix signed-byte comparison in server when checking for ASCII in header (#​10151). Without fix, authority could contain utf-8.
Dependencies
  • Version pinning (e.g., [1.56.0] instead of 1.56.0) has been removed from POMs, for both Netty and gRPC dependencies. The pinning was unreliable in Maven and ignored in Gradle, yet caused downloads during the build to fetch the version list. For a while we've had a BOM that helps reduce version skew. (#​10175).
  • bazel: Add java toolchain type to all rules using java_common. (#​10225).
  • Upgraded netty-tcnative-boringssl-static in grpc-netty-shaded to 2.0.61.Final (#​10260). Netty itself was not updated.
  • Upgraded AndroidX Annotation to 1.6.0 (#​10178).
  • Upgraded AndroidX Core to 1.10.0 (#​10178).
  • Upgraded AndroidX Lifecycle-Common to 2.6.1 (#​10178).
  • Upgraded OpenCensus to 0.31.1 (#​10178).
  • Upgraded Cronet API to 108.5359.79 (#​10178).
  • Upgraded proto-google-common-protos to 2.17.0 (#​10178).
  • Upgraded Gson to 2.10.1 (#​10178).
  • Upgraded PerfMark API to 0.26.0 (#​10178).
  • Upgraded RE2/J to 1.7 (#​10178).
Acknowledgements

v1.55.3

Bug fixes
  • core: Fix regression in 1.54.0 where polling NameResolvers would not refresh after a resolution error (#​10328). The symptom is a transient failure like "UNAVAILABLE: Unable to resolve host" continuing potentially forever. This did not impact DnsNameResolver, but it did impacted GrpclbNameResolver which is the dns name resolver used when grpc-grpclb is in the classpath. So even users that think "I don't use grpclb" may have been impacted. round_robin is mainly impacted on startup, but if the error happened afterward it would commonly fix itself for short transient DNS failures. pick_first is impacted at all times; any failed DNS resolution could cause all future RPCs on the channel to fail.

v1.55.1

The 1.55.0 release failed. There were no artifacts published for it.

API Changes
  • services: Rename MetricRecorder.setQps/clearQps to setQpsMetric/clearQpsMetric (#​10031)
Behavior Changes
  • gcp-observability: Remove monitored resource detection for logging (https://github.com/grpc/grpc-java/pull/10020). The cloud libraries will fill in these details instead
  • protoc-gen-grpc-java: binaries for Linux ARM and PPC are now built using Ubuntu 18.04. They will no longer work on Ubuntu 16.04 and Debian 9
New Features
  • api: Stabilize the frequently used compression APIs (#​9942): CallOptions.withCompression, CallOptions.getCompressor, AbstractStub.withCompression, ServerCall.setCompression, ServerCall.setMessageCompression
  • api: Stabilize Detachable and HasByteBuffer
  • gcp-observability: Stabilize GcpObservability (https://github.com/grpc/grpc-java/pull/10024). The GcpObservability API provides a simple way to export logging, tracing, and metrics to Google Cloud Operations. See the Google Cloud blog post.
  • census: Add new tracer annotation to indicate the time when name resolution completed for those RPCs that experienced name resolution delay, or the time when picking subchannel completed for those RPCs that experienced picking subchannel delay. (#​10014, #​10044)
  • protoc-gen-grpc-java: binary for s390x is now published (#​9455). The glibc version used is available in Ubuntu 20.04, Debian 11, and CentOS 9 and later
  • authz: Added FileWatcherAuthorizationServerInterceptor (#​9775)
  • services: Added OrcaMetricReportingServerInterceptor.create(MetricRecorder) which adds common metrics per-RPC (#​9902)
  • android: Add UdsChannelBuilder for using LocalSocket an Android (#​8418)
  • alts: Observe the GRPC_ALTS_MAX_CONCURRENT_HANDSHAKES environment variable user to adjust the max number of concurrent ALTS handshakes (#​10016)
  • binder: Expose client identity via PeerUid and PeerUids (#​9952)
  • binder: Add BindServiceFlags.setAllowActivityStarts() for BIND_ALLOW_ACTIVITY_STARTS added in Android U (#​10008)
Bug Fixes
  • core: Fix NPE race during hedging (https://github.com/grpc/grpc-java/pull/10007), fixing a Netty buffer memory leak for cancelled RPCs
  • core: Allow transparent retries after a retry attempt and the configured max retries was 1 (#​10066)
  • okhttp: properly implement OkHttpServerBuilder.maxConnectionAgeGrace() (#​9968)
  • xds: Enable federation support. See gRFC A47
  • xds: Enable Weighted Round Robin LB policy support. See gRFC A58
  • xds: Avoid ClassCastException if the control plane changes the top-level policy (#​10091). This is expected to be unlikely, but is possible
  • xds: Fix java.util.NoSuchElementException: SecurityProtocolNegotiators$ClientSdsHandler#0 (#​10118). This error did not cause any problems, other than unnecessary logging
  • xds: Avoid using the default locale for case insensitive path matching (#​10148)
  • googleapis: Enable ignore_resource_deletion for google-c2p: resolver’s default xds bootstrap (#​10121)
  • rls: Refresh name resolution on rejected addresses (#​10032)
New Examples
Dependencies
  • protobuf-java and protobuf-java-util upgraded to 3.22.3 (#​10045)
Acknowledgements

v1.54.2

Bug Fixes
  • core: Fix regression in 1.54.0 where polling NameResolvers would not refresh after a resolution error (https://github.com/grpc/grpc-java/pull/10328). The symptom is a transient failure like "UNAVAILABLE: Unable to resolve host" continuing potentially forever. This did not impact DnsNameResolver, but it did impacted GrpclbNameResolver which is the dns name resolver used when grpc-grpclb is in the classpath. So even users that think "I don't use grpclb" may have been impacted. round_robin is mainly impacted on startup, but if the error happened afterward it would commonly fix itself for short transient DNS failures. pick_first is impacted at all times; any failed DNS resolution could cause all future RPCs on the channel to fail.
  • xds: Avoid using the default locale for case insensitive path matching (#​10149)
  • xds: Avoid potential channel panic when control plane changes the field used to configure load balancing (#​10103)
  • core: Allow transparent retries after a retry attempt and the configured max retries was 1 (#​10080)

v1.54.1

Bug Fixes

Behavior Changes

API stabilizations

v1.54.0

New Features
  • xds: Add weightedRoundRobin LB policy. The WRR policy allows picking the subchannel by weight based on the metrics feedback from the backend using ORCA API. See gRFC A58: Weighted Round Robin LB Policy. (#​9873)
  • census: Add per call latency metric which is latency across all attempts (#​9906)
  • Generated code now has an interface named AsyncService that the <service-name>ImplBase class implements. This allows you to provide your own base class when used with the static <service-name>Grpc.bindService(AsyncService) method(#​9688).
Examples
  • Add examples for gcp observability (#​9967)
Bugfixes
  • rls:Fix throttling in route lookup where success and error metrics had been inverted (b/262779100) (#​9874)
  • protobuf: update external javadoc link (#​9890)
  • core: fix outlier detection default ejection time (#​9889)
  • xds: deletion only to watchers of same control plane (#​9896)
  • api: Target scheme is now properly case insensitive (#​9899). NameResolverProviders, however, are expected to return the scheme used for registration in lower-case
  • api: ForwardingServerCall now forwards getMethodDescriptor(). Previously only SimpleForwardingServerCall forwarded the method
Behavior Changes
  • xds:Allow a cluster’s sum of weights to exceed the maximum signed integer up to a limit of max unsigned integer (#​9864)
  • grpclb: no SRV lookup for "metadata.google.internal."
Improvements
  • xds, orca: Allow removing OobLoadReportListener from a subchannel in OrcaOobUil. (#​9881)
  • services: ORCA API change to allow recording QPS in MetricRecorder and CallMetricRecorder. (#​9866)
  • Move name resolution retry from managed channel to name resolver (take #​2) (#​9812)
  • Rename AbstractXdsClient to ControlPlaneClient (#​9934)
  • all: fix build with errorprone 2.18 (#​9886)
  • build: allow Java 11+ to use modern error prone
  • errorprone: enable UnnecessaryAnonymousClass (#​9927)
  • core: add logger to OutlierDetectionLoadBalancer (#​9880)
  • census: add trace annotation to report received message sizes (#​9944)
  • gcp-observability: emit latency and payload size metrics by default when monitoring is enabled (#​9893)
  • gcp-observability: add trace information like TraceId and SpanId in logs for log correlation when both logging and traces are enabled (#​9963)
  • gcp-observability: close() will take longer, to ensure metrics and traces are flushed (#​9972)
  • gcp-observability: update status code type in logs to Google RPC code instead of an integer (#​9959)
  • gcp-observability: retain default opencensus-task identifier even when custom labels are specified in the configuration (#​9982)
  • Build Improvements (#​9855)
  • Fixes MethodDescriptor java documentation (#​9860)
  • api: forward getSecurityLevel on PartialForwardingServerCall (#​9912)
  • Updating ServerInterceptors.java to support different marshallers for Request and Response messages. (#​9877)
API stabilizations
  • Stabilize method ServerBuilder.intercept which had previously been marked experimental. (#​9894)
  • api:stabilize offloadExecutor usage in ManagedChannelBuilder and NameResolver. (#​9931)
Dependencies
  • netty:Upgrade Netty from 4.1.79 to 4.1.87, tcnative from 2.0.54 to 2.0.56 (#​9784)
  • gcp-observability: Transitive gRPC components now have the same gRPC version
  • gcp-observability : Google cloud logging updated to 3.14.5
Acknowledgements

@​benjaminp
@​s-matyukevich
@​Faqa
@​antechrestos
@​carl-mastrangelo
@​ioanbsu

v1.53.0

New Features
  • googleapis: Allow user set c2p bootstrap config (#​9856)
  • xds: Add contain and stringMatcher in RouteConfiguration (#​9845)
  • core: Add grpc-previous-rpc-attempts to the initial response metadata (#​9686)
  • servlet: Implement gRPC server as a Servlet (#​8596)
  • authz: Implement static authorization server interceptor (#​8934)
Examples
  • servlet: Add servlet example (#​8596)
Bug Fixes
  • xds: Update xds error handling logic. Specifically:
    • When the ads stream is closed only send errors to subscribers that haven't yet gotten results
    • Timers to detect missing resources don’t start until the adsStream is ready (#​9745)
    • Call subscriber onError callback when xds client fails to connect to server (#​9827)
  • core: Delay retriable stream master listener close until all sub streams are closed. This fixes the call executor lifecycle and prevents potential RejectedExecutionException. (#​9754)
  • core: Free unused MessageProducer in RetriableStream (#​9853), fixing a Netty buffer memory leak for cancelled RPCs
  • api: Fail with NullPointerException when a Metadata.Marshaller returns null bytes (#​9781). This would previously cause a NullPointerException later during the RPC. Now the return value of the Marshaller is checked immediately, to help find the broken Marshaller
Behavior Changes
  • xds: Disallow duplicate addresses in the RingHashLB. (#​9776)
  • xds: EDS weight sums are allowed up to max unsigned int (was max signed int) (#​9765)
  • xds: Drop xds v2 support (#​9760)
Dependencies
  • JUnit upgraded to 4.13.2
  • bazel: Dropped support for Bazel 4. We track the two most recent major versions of Bazel, Bazel 5 and 6. Bazel 4 may still work, but we are no longer testing it
  • bazel: Include Tomcat annotations dependency for @Generated as used by autovalue (#​9762). Necessary for building xds and rls on Java 9+
  • bazel: Export deps from Maven Central-specific stand-in targets (#​9780). Some Maven Central artifacts are a combination of multiple Bazel targets, like grpc-core is composed of //core:inprocess, //core:internal, //core:util, //api. There is a “//core:core_maven” target used by maven_install that uses the other targets. Previously the target used runtime_deps to discourage their use by Bazel users, but that could cause compilation failures from lack of hjars. These targets now use exports
Acknowledgement

@​cpovirk
@​niloc132
@​stephenh
@​olderwei
@​pandaapo
@​panxuefeng

v1.52.1

Bug Fixes
  • xds: Fix an internal bug in xds resource subscription that might cause xds stream not accepting response update for that resource type entirely. (#​9810)

v1.52.0

gRPC Java 1.52.0 Release Notes

grpc-xds starting with 1.51.0 had a regression where resources might stop receiving updates. The trigger could happen hours or days after the binary had started. xDS users should avoid this release and use 1.50.x until patch releases with the fix are available. https://github.com/grpc/grpc-java/pull/9809

API Changes
  • Fix CallOptions to be properly @Immutable (#​9689)
  • binder: Promote out of experimental status (#​9669). Much of the API is now stable
New Features
  • xds: Support localities in multiple priorities (#​9683)
  • xds: Log xDS node ID with verbosity INFO when environment variable GRPC_LOG_XDS_NODE_ID=true (#​9731)
Examples
  • Add examples for name resolver and load balancer (#​9700)
  • Swap to ChannelCredentials/ServerCredentials API, as it is preferred
Bug Fixes
  • xds:Fix ConcurrentModificationException in PriorityLoadBalancer (#​9728)
  • ManagedChannelImpl.SubchannelImpl fix args check to avoid NPE (#​9651)
  • okhttp: Add missing server support for TLS ClientAuth (#​9711)
  • binder: Ensure the security interceptor is always closest to the actual transport (#​9716)
  • bazel: Include @​Generated dep for autovalue. This fixes builds of xds and rls using Java 9+
  • xds: Nack xds response when weighted cluster total weight sums zero (#​9738)
  • core: Fix a bug about a retriable stream lifecycle. It stops using the call executor resource in a retriable stream when the client call is closed, thus preventing potential channel panics. (#​9626)
Behavior Changes
  • binder: Set default idle timeout to 60 seconds, and enable "strict lifecycle management". (#​9486)
  • xds: Limit ring hash max size to 4K instead of 8M (#​9709). RingHashOptions.setRingSizeCap() can increase the limit
  • binder: Set default idle timeout to 60 seconds, and add BinderChannelBuilder.strictLifecycleManagement() which disables idle timeout and prevents it from being changed (#​9486). Disabling idle timeout can be useful to find bugs in applications that fail to promptly shut down the channel and are particularly sensitive to keeping Binder instances alive.
  • bazel: Replace ctx.host_configuration.host_path_separator with ctx.configuration.host_path_separator (#​9742). This changes no behavior today, but improves future compatibility with newer versions of Bazel
  • xds: Refactor internal logics about LDS and CDS resource handling. It may cause minor log line changes about corresponding RDS and EDS subscriber event notification, but it should not change xds name resolution and LB behavior. (#​9724)
Dependencies
Acknowledgement

@​RapperCL
@​Smityz
@​pandaapo

v1.51.3

Bug Fixes

v1.51.1

grpc-xds starting with 1.51.0 had a regression where resources might stop receiving updates. The trigger could happen hours or days after the binary had started. xDS users should avoid this release and use 1.50.x until patch releases with the fix are available. https://github.com/grpc/grpc-java/pull/9809

Bug Fixes
  • xds: Fix ConcurrentModificationException in PriorityLoadBalancer. (#​9744)

v1.51.0

grpc-xds starting with 1.51.0 had a regression where resources might stop receiving updates. The trigger could happen hours or days after the binary had started. xDS users should avoid this release and use 1.50.x until patch releases with the fix are available. https://github.com/grpc/grpc-java/pull/9809

Bug Fixes
  • grpclb: Fix a debug logging message which incorrectly logged loadbalancer addresses under backend addresses. (#​9602)
New Features
  • okhttp: okhttp server now supports maxConnectionAge and maxConnectionAgeGrace configuration for improved connection management. (#​9649)
Behavior Changes
  • netty: switch default cumulation strategy from MERGE to ADAPTIVE. When accumulating incoming network data, Adaptive cumulator dynamically switches between MERGE and COMPOSE strategies to minimize the amount of copying while also limiting per-buffer overhead. (#​9558)
Acknowledgements

@​TrevorEdwards

v1.50.3

Bug Fixes

v1.50.2

Bug fixes

gcp-observability: Supports period(.) in the service name part of regular expression for a fully-qualified method to accept "package.service"

v1.50.1

gcp-observability: support new configuration defined in grpc-gcp-observability public preview user guide

v1.50.0

New Features
  • okhttp: Added connection management features to okhttp server, including maxConnectionIdle(), permitKeepAliveTime(), and permitKeepAliveWithoutCalls() (#​9494, #​9544)
  • binder: Add SecurityPolicies for checking device owner/profile owner (#​9428)
API Changes
  • api: Add LoadBalancer.acceptResolvedAddresses() (#​9498). The method is like handleResolvedAddresses() but returns a boolean of whether the addresses and configuration were accepted. Not accepting the update triggers the NameResolver to retry after a delay. We are not yet encouraging migration to this method, as there is still a second future API change
  • core: add CallOptions to CallCredentials.RequestInfo (#​9538)
Bug Fixes
  • auth: Fix AppEngine failing while retrieving access token when instantiating a blocking stub using AppEngineCredentials (#​9504)
  • core: Ensure that context cancellationCause is set (#​9501)
  • core: Update outlier detection max ejection logic to allow exceeding the limit by one, to match Envoy. (#​9489, #​9492)
  • core: outlier detection to honor min host request volume (#​9490)
  • okhttp: Add timeout for HTTP CONNECT proxy handshake (#​9586)
  • xds: ringhash policy in TRANSIENT_FAILURE should not attempt connecting when already in connecting (#​9535). With workloads where most requests have the same hash, ring hash should behave more like pick-first of slowly trying backends
Dependencies
  • netty: upgrade netty from 4.1.77.Final to 4.1.79.Final and tcnative from 2.0.53 to 2.0.54 (#​9451)
Acknowledgements

@​cpovirk
@​prateek-0
@​sai-sunder-s

v1.49.2

Dependencies
  • Bump protobuf to 3.21.7

v1.49.1

Bug Fixes
  • xds: Fix a bug in ring-hash load balancing policy that, during TRANSIENT_FAILURE state, it might cause unnecessary internal connection requests on subchannels. (#​9537)
  • auth: Fix AppEngine failing while retrieving access token when instantiating a blocking stub using AppEngineCredentials (#​9524)
Behavior Changes

v1.49.0

New Features
  • okhttp: Add OkHttpServerBuilder. The server can be used directly, but is not yet available via ServerBuilder.forPort() and Grpc.newServerBuilderForPort(). It passes our tests, but has seen no real-world use. It is also lacking connection management features
  • okhttp: Add support for byte-based private keys via TlsChannelCredentials and TlsServerCredentials
  • core: New outlier detection load balancer
  • googleapis: google-c2p resolver is now stabilized
Bug Fixes
  • core: Fix retry causing memory leak for canceled RPCs. (#​9360)
  • core: Use SyncContext for InProcess transport callbacks to avoid deadlocks. This fixes the long-standing issue #​3084 which prevented using directExecutor() in some tests using streaming RPCs
  • core: Disable retries with in-process transport by default (#​9361). In-process does not compute message sizes so can retain excessive amounts of memory
  • bazel: Use valid target name for services and xds when overriding Maven targets (#​9422). This fixes an error of the form no such target '@&#8203;io_grpc_grpc_java//services:services' for services and missing ORCA classes for xds. The wrong target names were introduced in 1.47.0
  • xds: channel_id hash policy now uses a random per-channel id instead of an incrementing one. The incrementing id was the same for every process of a binary, which was not the intention (#​9453)
  • core: Fix a bug that the server stream should not deliver halfClose() when the call is immediately canceled. The bug causes a bad message INTERNAL, desc: Half-closed without a request at server call. (#​9362)
  • xds: Remove shaded orca proto dependency in ORCA api. The shading was broken and couldn't really be used. (#​9366)
Behavior Ch

Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR has been generated by Mend Renovate. View repository job log here.

@renovate-bot renovate-bot requested a review from a team as a code owner August 30, 2021 16:17
@google-cla google-cla bot added the cla: yes This human has signed the Contributor License Agreement. label Aug 30, 2021
@trusted-contributions-gcf trusted-contributions-gcf bot added kokoro:force-run Add this label to force Kokoro to re-run the tests. owlbot:run Add this label to trigger the Owlbot post processor. labels Aug 30, 2021
@gcf-owl-bot gcf-owl-bot bot removed the owlbot:run Add this label to trigger the Owlbot post processor. label Aug 30, 2021
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 3bec25d to b70138d Compare September 22, 2021 21:33
@renovate-bot renovate-bot changed the title chore(deps): update dependency io.grpc:grpc-protobuf to v1.40.1 chore(deps): update dependency io.grpc:grpc-protobuf to v1.41.0 Sep 22, 2021
@trusted-contributions-gcf trusted-contributions-gcf bot added the owlbot:run Add this label to trigger the Owlbot post processor. label Sep 22, 2021
@gcf-owl-bot gcf-owl-bot bot removed the owlbot:run Add this label to trigger the Owlbot post processor. label Sep 22, 2021
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from b70138d to eafd251 Compare March 7, 2022 11:07
@renovate-bot renovate-bot changed the title chore(deps): update dependency io.grpc:grpc-protobuf to v1.41.0 chore(deps): update dependency io.grpc:grpc-protobuf to v1.44.1 Mar 7, 2022
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from eafd251 to 69ee06b Compare March 26, 2022 15:26
@renovate-bot renovate-bot changed the title chore(deps): update dependency io.grpc:grpc-protobuf to v1.44.1 chore(deps): update dependency io.grpc:grpc-protobuf to v1.45.0 Mar 26, 2022
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 69ee06b to 9431a17 Compare April 25, 2022 02:53
@renovate-bot renovate-bot changed the title chore(deps): update dependency io.grpc:grpc-protobuf to v1.45.0 chore(deps): update dependency io.grpc:grpc-protobuf to v1.45.1 Apr 25, 2022
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 9431a17 to 2f28ebf Compare May 16, 2022 02:58
@renovate-bot renovate-bot changed the title chore(deps): update dependency io.grpc:grpc-protobuf to v1.45.1 chore(deps): update dependency io.grpc:grpc-protobuf to v1.46.0 May 16, 2022
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 2f28ebf to bbbddf0 Compare June 18, 2022 23:58
@renovate-bot renovate-bot changed the title chore(deps): update dependency io.grpc:grpc-protobuf to v1.46.0 chore(deps): update dependency io.grpc:grpc-protobuf to v1.47.0 Jun 18, 2022
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from bbbddf0 to 6fa56c0 Compare September 25, 2022 13:30
@renovate-bot renovate-bot changed the title chore(deps): update dependency io.grpc:grpc-protobuf to v1.47.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.49.1 Sep 25, 2022
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 6fa56c0 to 36608ba Compare November 20, 2022 14:36
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.49.1 fix(deps): update dependency io.grpc:grpc-protobuf to v1.51.0 Nov 20, 2022
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 36608ba to d8f46ab Compare December 18, 2022 00:39
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.51.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.51.1 Dec 18, 2022
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.51.1 fix(deps): update dependency io.grpc:grpc-protobuf to v1.52.0 Jan 11, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch 2 times, most recently from 879faa1 to 80fa4af Compare January 14, 2023 02:08
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.52.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.52.1 Jan 14, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 80fa4af to 6d6963f Compare February 9, 2023 23:10
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from ca1d9b7 to 1a90244 Compare April 17, 2023 02:34
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.54.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.54.1 Apr 17, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 1a90244 to 6361d27 Compare June 2, 2023 14:59
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.54.1 fix(deps): update dependency io.grpc:grpc-protobuf to v1.55.1 Jun 2, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 6361d27 to bc5ed43 Compare June 14, 2023 05:06
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.55.1 fix(deps): update dependency io.grpc:grpc-protobuf to v1.56.0 Jun 14, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from bc5ed43 to 454e5ba Compare July 1, 2023 04:46
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.56.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.56.1 Jul 1, 2023
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.56.1 fix(deps): update dependency io.grpc:grpc-protobuf to v1.57.0 Jul 28, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch 2 times, most recently from deeab15 to 9c0568f Compare August 1, 2023 22:27
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.57.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.57.1 Aug 1, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from 9c0568f to ada8816 Compare August 16, 2023 02:55
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.57.1 fix(deps): update dependency io.grpc:grpc-protobuf to v1.57.2 Aug 16, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from ada8816 to c846b5e Compare September 6, 2023 23:11
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.57.2 fix(deps): update dependency io.grpc:grpc-protobuf to v1.58.0 Sep 6, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from c846b5e to b2cdb09 Compare October 20, 2023 07:03
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.58.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.59.0 Oct 20, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from b2cdb09 to be0a273 Compare November 28, 2023 04:58
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.59.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.59.1 Nov 28, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from be0a273 to d90393e Compare December 5, 2023 17:13
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.59.1 fix(deps): update dependency io.grpc:grpc-protobuf to v1.60.0 Dec 5, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from d90393e to bcc01e2 Compare December 21, 2023 21:10
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.60.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.60.1 Dec 21, 2023
@renovate-bot renovate-bot force-pushed the renovate/io.grpc-grpc-protobuf-1.x branch from bcc01e2 to d18a996 Compare January 12, 2024 06:37
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.60.1 fix(deps): update dependency io.grpc:grpc-protobuf to v1.61.0 Jan 12, 2024
@renovate-bot renovate-bot changed the title fix(deps): update dependency io.grpc:grpc-protobuf to v1.61.0 fix(deps): update dependency io.grpc:grpc-protobuf to v1.61.0 - autoclosed Mar 12, 2024
@renovate-bot renovate-bot deleted the renovate/io.grpc-grpc-protobuf-1.x branch March 12, 2024 12:29
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cla: yes This human has signed the Contributor License Agreement. kokoro:force-run Add this label to force Kokoro to re-run the tests.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant