上下文信息 RpcContext
阿新 • • 發佈:2018-06-14
AR provider ren color thread OS geturl TP ID
上下文中存放的是當前調用過程中所需的環境信息。所有配置信息都將轉換為 URL 的參數,參見 schema 配置參考手冊 中的對應URL參數一列。
RpcContext 是一個 ThreadLocal 的臨時狀態記錄器,當接收到 RPC 請求,或發起 RPC 請求時,RpcContext 的狀態都會變化。比如:A 調 B,B 再調 C,則 B 機器上,在 B 調 C 之前,RpcContext 記錄的是 A 調 B 的信息,在 B 調 C 之後,RpcContext 記錄的是 B 調 C 的信息。
服務消費方
// 遠程調用 xxxService.xxx(); // 本端是否為消費端,這裏會返回trueboolean isConsumerSide = RpcContext.getContext().isConsumerSide(); // 獲取最後一次調用的提供方IP地址 String serverIP = RpcContext.getContext().getRemoteHost(); // 獲取當前服務配置信息,所有配置信息都將轉換為URL的參數 String application = RpcContext.getContext().getUrl().getParameter("application"); // 註意:每發起RPC調用,上下文狀態會變化 yyyService.yyy();
服務提供方
public class XxxServiceImpl implements XxxService { public void xxx() { // 本端是否為提供端,這裏會返回true boolean isProviderSide = RpcContext.getContext().isProviderSide(); // 獲取調用方IP地址 String clientIP = RpcContext.getContext().getRemoteHost(); // 獲取當前服務配置信息,所有配置信息都將轉換為URL的參數String application = RpcContext.getContext().getUrl().getParameter("application"); // 註意:每發起RPC調用,上下文狀態會變化 yyyService.yyy(); // 此時本端變成消費端,這裏會返回false boolean isProviderSide = RpcContext.getContext().isProviderSide(); } }
上下文信息 RpcContext