上下文信息 RpcContext
生活随笔
收集整理的這篇文章主要介紹了
上下文信息 RpcContext
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
上下文中存放的是當前調用過程中所需的環境信息。所有配置信息都將轉換為 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() {// 本端是否為提供端,這里會返回trueboolean isProviderSide = RpcContext.getContext().isProviderSide();// 獲取調用方IP地址String clientIP = RpcContext.getContext().getRemoteHost();// 獲取當前服務配置信息,所有配置信息都將轉換為URL的參數String application = RpcContext.getContext().getUrl().getParameter("application");// 注意:每發起RPC調用,上下文狀態會變化 yyyService.yyy();// 此時本端變成消費端,這里會返回falseboolean isProviderSide = RpcContext.getContext().isProviderSide();} }?
轉載于:https://www.cnblogs.com/yifanSJ/p/9180687.html
總結
以上是生活随笔為你收集整理的上下文信息 RpcContext的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mac svn 使用
- 下一篇: 第十周补做作业