protocol-buffers - 如何从 grpc Context.current() 访问属性?
问题描述
是否可以从 rpc 方法定义访问 grpc 调用的上下文属性?
我写了一个类似于这个的服务器拦截器
@Override
public <ReqT, RespT> ServerCall.Listener<ReqT> interceptCall(ServerCall<ReqT, RespT> call, final Metadata requestHeaders, ServerCallHandler<ReqT, RespT> next) {
Context.Key<String> USER = Context.key("USER");
Context ctx = Context.current().withValue(USER, "chandan");
return Contexts.interceptCall(ctx, call, requestHeaders, next);
}
在服务实现中,我正在尝试类似的东西
Context.Key<String> key = Context.key("USER");
String value = key.get(Context.current())
每次值都为空。但是在 intellij 中调试时,我可以在 as 中看到这些context.current().keyValueEntries
值
CompressedIndex(bitmap=100001000000000000000000000000 Leaf(key=USER value=chandan) Leaf(key=opencensus-trace-span-key value=BlankSpan) )
如何访问上下文属性/正确的方法是什么?
解决方案
Context.Key
使用引用相等。该"USER"
字符串是在toString()
输出中使用的调试字符串。您应该创建Key
一次并在需要的任何地方引用该实例。
因为Context.Key
使用引用相等,您可以使用正常的 Java 可见性限制来限制谁可以访问该值,就像您可以使用ThreadLocal
.