1. 程式人生 > >上下文信息 RpcContext

上下文信息 RpcContext

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();
// 本端是否為消費端,這裏會返回true
boolean 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