dubbo Filter


官方說明:

調用攔截擴展

擴展說明

服務提供方和服務消費方調用過程攔截,Dubbo 本身的大多功能均基於此擴展點實現,每次遠程方法執行,該攔截都會被執行,請注意對性能的影響。

約定:

  • 用戶自定義 filter 默認在內置 filter 之后。
  • 特殊值 default,表示缺省擴展點插入的位置。比如:filter="xxx,default,yyy",表示 xxx 在缺省 filter 之前,yyy 在缺省 filter 之后。
  • 特殊符號 -,表示剔除。比如:filter="-foo1",剔除添加缺省擴展點 foo1。比如:filter="-default",剔除添加所有缺省擴展點。
  • provider 和 service 同時配置的 filter 時,累加所有 filter,而不是覆蓋。比如:<dubbo:provider filter="xxx,yyy"/> 和 <dubbo:service filter="aaa,bbb" />,則 xxx,yyy,aaa,bbb 均會生效。如果要覆蓋,需配置:<dubbo:service filter="-xxx,-yyy,aaa,bbb" />

 

簡單示例: github

1, 代碼

import com.alibaba.dubbo.common.Constants;
import com.alibaba.dubbo.common.extension.Activate;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.alibaba.dubbo.rpc.*;

import java.util.List;

@Activate(group = Constants.PROVIDER, order = -999)
public class AuthorityFilter implements Filter {
    private static final Logger logger = LoggerFactory.getLogger(AuthorityFilter.class);
    @Override
    public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {


        logger.info("接口名:{}",invocation.getInvoker().getInterface().getName());
        logger.info("方法名:{}",invocation.getMethodName());
        String clientIp = RpcContext.getContext().getRemoteHost();
        logger.info("訪問ip為{}", clientIp);

        return invoker.invoke(invocation);

    }
}

2,  配置  MATA-INF\dubbo\com.alibaba.dubbo.rpc.Filter 文件下面內容

AuthorityFilter=zzhiDubboprovider.filter.AuthorityFilter

 

3,測試:

2017-12-21 10:47:01.906  INFO 10820 --- [:20880-thread-2] z.filter.AuthorityFilter                 : 接口名:zzhiDubboapi.service.PeopleService
2017-12-21 10:47:01.908  INFO 10820 --- [:20880-thread-2] z.filter.AuthorityFilter                 : 方法名:findPeople
2017-12-21 10:47:01.908  INFO 10820 --- [:20880-thread-2] z.filter.AuthorityFilter                 : 訪問ip為10.255.2.122

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM