4.18. 实现泛化调用

实现一个通用的远程服务 Mock 框架,可通过实现 GenericService 接口处理所有服务请求。

泛接口实现方式主要用于服务器端没有 API 接口及模型类元的情况,参数及返回值中的所有 POJO 均用 Map 表示,通常用于框架集成,比如:实现一个通用的远程服务 Mock 框架,可通过实现 GenericService 接口处理所有服务请求。

  • 在 Java 代码中实现 GenericService 接口:
    package com.foo;
    public class MyGenericService implements GenericService {
        public Object $invoke(String methodName, String[] parameterTypes, Object[] args) throws GenericException {
            if ("sayHello".equals(methodName)) {
                return "Welcome " + args[0];
            }
        }
    }
    

通过 Spring 暴露泛化实现

  • 在 Spring 配置申明服务的实现:
    <bean id="genericService" class="com.foo.MyGenericService" />
    <dubbo:service interface="com.foo.BarService" ref="genericService" />
    

通过 API 方式暴露泛化实现

... 
// 用org.apache.dubbo.rpc.service.GenericService可以替代所有接口实现 
GenericService xxxService = new XxxGenericService(); 
// 该实例很重量,里面封装了所有与注册中心及服务提供方连接,请缓存 
ServiceConfig<GenericService> service = new ServiceConfig<GenericService>();
// 弱类型接口名 
service.setInterface("com.xxx.XxxService");  
service.setVersion("1.0.0"); 
// 指向一个通用服务实现 
service.setRef(xxxService); 
// 暴露及注册服务 
service.export();
下一节:通过回声测试检测 Dubbo 服务是否可用。