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 documentation for the \u003ccode\u003eInstantiatingGrpcChannelProvider.Builder\u003c/code\u003e class, specifically for version 2.36.0 of the library.\u003c/p\u003e\n"],["\u003cp\u003eIt lists available versions of the class, with \u003ca href=\"/java/docs/reference/gax/latest/com.google.api.gax.grpc.InstantiatingGrpcChannelProvider.Builder\"\u003e2.63.1\u003c/a\u003e being the latest version and includes numerous previous releases down to version 2.7.1.\u003c/p\u003e\n"],["\u003cp\u003eThe class inherits methods from \u003ccode\u003ejava.lang.Object\u003c/code\u003e, including \u003ccode\u003eclone\u003c/code\u003e, \u003ccode\u003eequals\u003c/code\u003e, \u003ccode\u003ehashCode\u003c/code\u003e, and \u003ccode\u003etoString\u003c/code\u003e, among others.\u003c/p\u003e\n"],["\u003cp\u003eThe \u003ccode\u003eInstantiatingGrpcChannelProvider.Builder\u003c/code\u003e class includes methods such as \u003ccode\u003ebuild()\u003c/code\u003e, \u003ccode\u003egetEndpoint()\u003c/code\u003e, \u003ccode\u003esetChannelConfigurator()\u003c/code\u003e, \u003ccode\u003esetChannelPoolSettings()\u003c/code\u003e, and \u003ccode\u003esetKeepAliveTime()\u003c/code\u003e for configuring gRPC channel providers.\u003c/p\u003e\n"],["\u003cp\u003eDeprecated methods like \u003ccode\u003esetPoolSize()\u003c/code\u003e and \u003ccode\u003esetChannelsPerCpu()\u003c/code\u003e are still present but users are directed to use \u003ccode\u003esetChannelPoolSettings()\u003c/code\u003e instead.\u003c/p\u003e\n"]]],[],null,[]]