目录
与很多框架一样,Dubbo也存在拦截(过滤)机制,可以通过该机制在执行目标程序前后执行我们指定 的代码。
Dubbo的Filter机制,是专门为服务提供方和服务消费方调用过程进行拦截设计的,每次远程方法执行,该拦截都会被执行。这样就为开发者提供了非常方便的扩展性,比如为dubbo接口实现ip白名单功 能、监控功能 、日志记录等。
步骤如下:
- 实现 org.apache.dubbo.rpc.Filter 接口
- 使用 org.apache.dubbo.common.extension.Activate 接口,对类进行注册。 通过group 可以指定生产端 消费端 如:
- 计算方法运行时间的代码实现
@Activate(group = {CommonConstants.CONSUMER,CommonConstants.PROVIDER})
- 在 META-INF.dubbo 中新建 org.apache.dubbo.rpc.Filter 文件,并将当前类的全名写入
注意:一般类似于这样的功能都是单独开发依赖的,所以再使用方的项目中只需要引入依赖,在调用接口时,该方法便会自动拦截。
在注解版基本demo基础上
新建一个项目,定义filter相关功能,并在provider和consumer引用
一、filter项目配置
1、pom
<dependencies>
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo</artifactId>
<version>2.7.5</version>
</dependency>
</dependencies>
2、添加一个自定义类,并继承Filter
注意:filter是dubbo中的。
package com.lagou.filter;
import org.apache.dubbo.common.constants.CommonConstants;
import org.apache.dubbo.common.extension.Activate;
import org.apache.dubbo.rpc.*;
@Activate(group = {CommonConstants.CONSUMER,CommonConstants.PROVIDER})
public class DubboInvokeFilter implements Filter {
@Override
public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
long startTime = System.currentTimeMillis();
try {
// 执行方法
return invoker.invoke(invocation);
} finally {
long endTime = System.currentTimeMillis();
System.out.println("invoke time 方法执行时长:" + (endTime - startTime) + "毫秒");
}
}
}
3、进行配置
在resources\META-INF\dubbo创建文件【org.apache.dubbo.rpc.Filter】
【org.apache.dubbo.rpc.Filter】:是Filter类的全限定类名
# timerFilter=包名.过滤器的名字
timeFilter=com.lagou.filter.DubboInvokeFilter
二、在需要的项目引用
本次测试,在filter的工程里,引入module的方式进行测试
pom引用
<!-- 引入自定义的dubbo-filter-->
<dependency>
<groupId>com.lagou</groupId>
<artifactId>dubbo-spi-filter</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
consumer
provider
三、注意
1、需要在filter类上方添加@Activate注解并使用group指定生产端 消费端
2、单独开发依赖
一般类似于这样的功能都是单独开发依赖的,所以再使用方的项目中只需要引入依赖,在调用接口时,该方法便会自动拦截。