成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Dubbo秘密傳遞:讓你的代碼行云流水

開發(fā) 前端
經(jīng)過以上簡單的幾步,我們在對業(yè)務代碼無侵入的情況下,通過Filter實現(xiàn)了Dubbo遠程調(diào)用中的隱式傳參。這可以方便地在服務調(diào)用鏈中傳遞一些公共的上下文信息,如登錄信息、請求ID等。

哈嘍,大家好,我是了不起。

在Dubbo使用過程中,有一些通用參數(shù)如果顯式的在接口參數(shù)中傳遞,使用起來會有一些不方便。

比如:經(jīng)常使用的用戶信息、token等上下文信息,如果都放入?yún)?shù)中傳遞,這樣會耦合到業(yè)務邏輯中了,這時隱式傳參就是一種比較好的處理方式了。

隱式傳參

Dubbo提供了RpcContext隱式傳參的方式:

//消費側(cè)傳入?yún)?shù)
RpcContext.getContext().setAttachment(String key, String value);

//服務提供側(cè)接收參數(shù)
RpcContext.getContext().getAttachment(String key);

通過上面兩個方法,我們可以在消費端傳入?yún)?shù),然后在提供側(cè)就可以接收到參數(shù)了,類似于線程變量ThreadLocal

為了更好的兼顧Dubbo多重調(diào)用導致隱式傳參丟失的問題,我們可以在每個Dubbo服務程序中加入兩個filter可解決問題

創(chuàng)建Filter

消費側(cè):

import java.util.HashMap;
import java.util.Map;

import com.alibaba.dubbo.common.extension.Activate;
import com.alibaba.dubbo.rpc.Filter;
import com.alibaba.dubbo.rpc.Invocation;
import com.alibaba.dubbo.rpc.Invoker;
import com.alibaba.dubbo.rpc.Result;
import com.alibaba.dubbo.rpc.RpcContext;
import com.alibaba.dubbo.rpc.RpcException;
import com.alibaba.fastjson.JSONObject;

@Activate(group = {Constants.CONSUMER})
public class DubboConsumerContextFilter implements Filter {
 
 @Override
 public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
  RpcContext.getContext().setAttachment("token", "tokenvalue");
  return invoker.invoke(invocation);
 }
}

服務提供側(cè):

import java.util.Map;

import com.alibaba.dubbo.common.extension.Activate;
import com.alibaba.dubbo.rpc.Filter;
import com.alibaba.dubbo.rpc.Invocation;
import com.alibaba.dubbo.rpc.Invoker;
import com.alibaba.dubbo.rpc.Result;
import com.alibaba.dubbo.rpc.RpcContext;
import com.alibaba.dubbo.rpc.RpcException;
import com.alibaba.fastjson.JSONObject;

@Activate(group = {Constants.PROVIDER})
public class DubboProviderContextFilter implements Filter {
 @Override
 public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
  // 處理token
  String token = RpcContext.getContext().getAttachment("token");
        //TODO 處理代碼
  return invoker.invoke(invocation);
 }
}

其中@Activate注解指定了這個Filter是在消費端生效還是服務端生效。

配置filter到META-INF中

在/src/main/resources/META-INF/dubbo/下新建文件,文件名為com.alibaba.dubbo.rpc.Filter,沒錯,這就是文件的名稱,而不是包路徑。

文件內(nèi)容:

dubboProviderContextFilter=com.xxx.DubboProviderContextFilter
dubboConsumerContextFilter=com.xxx.DubboConsumerContextFilter

總結(jié)

經(jīng)過以上簡單的幾步,我們在對業(yè)務代碼無侵入的情況下,通過Filter實現(xiàn)了Dubbo遠程調(diào)用中的隱式傳參。這可以方便地在服務調(diào)用鏈中傳遞一些公共的上下文信息,如登錄信息、請求ID等。

責任編輯:武曉燕 來源: Java技術(shù)指北
相關(guān)推薦

2024-12-20 13:00:00

C++編程C++17

2021-08-11 22:17:48

負載均衡LVS機制

2018-03-30 10:02:08

代碼規(guī)范維護工程師

2010-01-04 19:08:41

Silverlight

2018-11-28 13:23:19

Kagglefeatexp特征

2010-08-27 13:41:30

UPS

2025-03-11 08:30:00

Pythonretrying代碼

2024-05-30 14:21:00

lambdaPython代碼

2011-04-13 10:51:58

MATLAB

2019-01-29 05:34:47

GitHub插件代碼

2023-12-12 08:41:01

2010-08-23 09:56:09

Java性能監(jiān)控

2020-04-03 14:55:39

Python 代碼編程

2022-03-08 06:41:35

css代碼

2017-09-08 12:15:54

Python代碼Pythonic

2019-12-12 09:23:29

Hello World操作系統(tǒng)函數(shù)庫

2020-12-29 08:47:45

緩沖SQL磁盤

2022-03-10 08:25:27

JavaScrip變量作用域
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日韩欧美在线观看视频 | 国产aⅴ爽av久久久久久久 | 免费一区二区三区 | 在线观看黄免费 | 欧美四虎| 夜夜夜久久久 | 欧美精品日韩精品国产精品 | 日韩三区在线观看 | av黄在线观看 | 性欧美xxxx| 青青草一区二区 | 国产亚洲网站 | av三级在线观看 | 97视频人人澡人人爽 | 一区二区三区免费在线观看 | 国产一区二区三区色淫影院 | 欧美美女爱爱 | 久久精品视频99 | 免费黄色的视频 | 久久婷婷麻豆国产91天堂 | 本道综合精品 | 国产欧美在线一区二区 | 久久另类 | 天天干狠狠干 | 久久精品国产清自在天天线 | 日韩视频1| 日韩中文一区二区 | 国产成人精品福利 | 99精品免费久久久久久日本 | 成人福利在线视频 | 亚洲一区在线观看视频 | 国产小视频在线 | 狠狠狠干 | 国内av在线 | 国产乱人伦精品一区二区 | 日韩欧美国产成人一区二区 | 成人一区二区三区视频 | 欧洲一区二区三区 | 一区二区三区视频在线观看 | 久久高清 | 成人国产一区二区三区精品麻豆 |