Add a callback that can intercept channel creation.
This can be used for advanced configuration like setting the netty event loop. The
callback will be invoked with a fully configured channel builder, which the callback can
augment or replace.
By setting a channelPrimer, the ChannelPool created by the provider will be refreshing
ChannelPool. channelPrimer will be invoked periodically when the channels are refreshed
This is public only for technical reasons, for advanced usage.
Sets the Executor for this TransportChannelProvider.
This is optional; if it is not provided, needsExecutor() will return true, meaning that an
Executor must be provided when getChannel is called on the constructed
TransportChannelProvider instance. Note: GrpcTransportProvider will automatically provide its
own Executor in this circumstance when it calls getChannel.
Sets the HeaderProvider for this TransportChannelProvider.
This is optional; if it is not provided, needsHeaders() will return true, meaning that
headers must be provided when getChannel is called on the constructed
TransportChannelProvider instance.
Sets the GrpcInterceptorProvider for this TransportChannelProvider.
The provider will be called once for each underlying gRPC ManagedChannel that is created.
It is recommended to return a new list of new interceptors on each call so that interceptors
are not shared among channels, but this is not required.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-15 UTC."],[[["\u003cp\u003eThe webpage provides a comprehensive list of versions for the \u003ccode\u003eInstantiatingGrpcChannelProvider.Builder\u003c/code\u003e, ranging from the latest version 2.63.1 down to version 2.7.1, along with direct links to their respective documentation.\u003c/p\u003e\n"],["\u003cp\u003eThe \u003ccode\u003eInstantiatingGrpcChannelProvider.Builder\u003c/code\u003e class extends from \u003ccode\u003ejava.lang.Object\u003c/code\u003e and contains a set of methods to configure and build an \u003ccode\u003eInstantiatingGrpcChannelProvider\u003c/code\u003e such as setting the endpoint, managing keep-alive settings, and configuring channel settings.\u003c/p\u003e\n"],["\u003cp\u003eThere are several deprecated methods, such as \u003ccode\u003egetPoolSize()\u003c/code\u003e, \u003ccode\u003esetChannelsPerCpu()\u003c/code\u003e, and \u003ccode\u003esetExecutorProvider()\u003c/code\u003e, that have been replaced with new methods that you should use instead.\u003c/p\u003e\n"],["\u003cp\u003eInternal-only and beta methods are available for use, such as \u003ccode\u003esetAllowHardBoundTokenTypes()\u003c/code\u003e, \u003ccode\u003esetAllowNonDefaultServiceAccount()\u003c/code\u003e, \u003ccode\u003esetAttemptDirectPath()\u003c/code\u003e and \u003ccode\u003esetChannelConfigurator()\u003c/code\u003e , indicating ongoing development and potential future changes.\u003c/p\u003e\n"],["\u003cp\u003eVarious \u003ccode\u003eset\u003c/code\u003e methods are available to adjust properties of the \u003ccode\u003eInstantiatingGrpcChannelProvider\u003c/code\u003e, these allow you to configure the channel builder with customized settings for your specific requirements.\u003c/p\u003e\n"]]],[],null,[]]