Open dominity opened 1 year ago
@arpan14 can you please help triage?
Is Context.current()
per server's grpc request or per thread basis?
Say an app receives grpc call which may perform Spanner operations from thread executor. How does Context.current()
ensures that the context is not shared across the threads?
@dominity Does this answer your question here https://cloud.google.com/spanner/docs/statement-timeout#java?
Thanks for stopping by to let us know something could be better!
Is your feature request related to a problem? Please describe. My current system receives request from other system which defines deadline/finishby timeout which varies from request type to request type. I'd like to instruct spanner client to propagate this value to spanner using 'grpc-timeout' header. Currently it's possible to do this interacting directly with GrpcCallContext via SpannerOptions.CallContextConfigurator. It would be great to have it as part of SpannerStubSettings, so I don't need to provide my own implementation of SpannerOptions.CallContextConfigurator and attach it to GrpcContext each time it's needed.
Describe the solution you'd like Not sure of what would be the best approach here. I have one idea in mind: SpannerStubSettings.Builder already contains method applyToAllUnaryMethods(...). But it's invoked once when settings are build. applyDynamicallyToAllUnaryMethods(ApiFunction f) method could be introduced which causes invocation of provided ApiFunction on each method invocation (or limit it to specific methods only to move it to UnaryCallSettings level).
Describe alternatives you've considered Currently my system interact with GrpcCallContext directly via SpannerOptions.CallContextConfigurator:
then spanner invocation is wrapped with custom grpc context: