Dubbo泛化调用

– 参考博客url:http://blog.csdn.net/linuu/article/details/54313560

package org.bazinga.service.test;  

import com.alibaba.dubbo.config.ApplicationConfig;  
import com.alibaba.dubbo.config.ReferenceConfig;  
import com.alibaba.dubbo.config.RegistryConfig;  
import com.alibaba.dubbo.config.utils.ReferenceConfigCache;  
import com.alibaba.dubbo.rpc.service.GenericService;  

public class DubboConsumerGenericService {  

    public static void main(String[] args) {  

        // 普通编码配置方式  
        ApplicationConfig application = new ApplicationConfig();  
        application.setName("bazinga-consumer");  

        // 连接注册中心配置  
        RegistryConfig registry = new RegistryConfig();  
        registry.setAddress("zookeeper://127.0.0.1:2181");  

        ReferenceConfig reference = new ReferenceConfig();  
        reference.setApplication(application);  
        reference.setRegistry(registry);  
        reference.setInterface("org.bazinga.service.EasyCommonService");  
        reference.setGeneric(true); // 声明为泛化接口  

        ReferenceConfigCache cache = ReferenceConfigCache.getCache();  
        GenericService genericService = cache.get(reference);  

        // 基本类型以及Date,List,Map等不需要转换,直接调用  
        Object result = genericService.$invoke("helloService", new String[] { "java.lang.String" },  
                new Object[] { "world" });  
        System.out.println(result);  

    }  

}  

你可能感兴趣的:(Dubbo)