Java Code Examples for com.alibaba.dubbo.config.ReferenceConfig#setGeneric()

The following examples show how to use com.alibaba.dubbo.config.ReferenceConfig#setGeneric() . You can vote up the ones you like or vote down the ones you don't like, and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: DubboUtils.java    From java-master with Apache License 2.0 6 votes vote down vote up
private static <T> ReferenceConfig<T> getReferenceConfig(Class<?> interfaceClass, String group, String version,
                                                         String host) {
    String referenceKey = interfaceClass.getName();
    ReferenceConfig<T> referenceConfig = new ReferenceConfig<>();
    referenceConfig.setApplication(application);
    referenceConfig.setRegistry(getRegistryConfig(group, version));
    referenceConfig.setInterface(interfaceClass);
    referenceConfig.setVersion(version);
    referenceConfig.setTimeout(30000);
    referenceConfig.setGeneric(true);
    if (StringUtils.isNotBlank(host)) {
        String url = String.format("dubbo://%s/%s", host, referenceKey);
        referenceConfig.setUrl(url);
    }
    return referenceConfig;
}
 
Example 2
Source File: DubboSinkFunction.java    From alchemy with Apache License 2.0 6 votes vote down vote up
private ReferenceConfig<GenericService> referenceConfig(DubboProperties properties) throws Exception {
    ApplicationConfig application = new ApplicationConfig();
    application.setName(properties.getApplicationName());
    ReferenceConfig<GenericService> reference = new ReferenceConfig<>();
    reference.setApplication(application);
    reference.setRegistry(new RegistryConfig(properties.getRegistryAddr()));
    reference.setInterface(properties.getInterfaceName());
    reference.setVersion(properties.getVersion());
    reference.setGeneric(true);
    reference.setCheck(false);
    reference.setInit(true);
    if(properties.getProperties() != null){
        BeanUtils.copyProperties(reference, properties.getProperties());
    }
    return reference;
}
 
Example 3
Source File: DubboServiceFactory.java    From pampas with Apache License 2.0 6 votes vote down vote up
public Object genericInvoke(DubboRequest dubboRequest) {

        ReferenceConfig<GenericService> reference = new ReferenceConfig<>();
        reference.setApplication(application);
        reference.setRegistry(registry);
        reference.setInterface(dubboRequest.getService());
        reference.setGeneric(true);
        ReferenceConfigCache cache = ReferenceConfigCache.getCache();
        GenericService genericService = cache.get(reference);

        int len = dubboRequest.getParams().size();
        String[] invokeParamTyeps = new String[len];
        Object[] invokeParams = new Object[len];
        for (int i = 0; i < len; i++) {
            invokeParamTyeps[i] = String.valueOf(dubboRequest.getParams().getJSONObject(i).getString("type"));
            invokeParams[i] = dubboRequest.getParams().getJSONObject(i).get("value");
        }
        return genericService.$invoke(dubboRequest.getMethod(), invokeParamTyeps, invokeParams);

    }
 
Example 4
Source File: Consumer.java    From dubbo-samples with Apache License 2.0 6 votes vote down vote up
public static void main(String[] args) {

         System.out.println("\n\n\nstart to generic invoke");
         ApplicationConfig applicationConfig = new ApplicationConfig();
         ReferenceConfig<GenericService> reference = new ReferenceConfig<GenericService>();
         applicationConfig.setName("UserProviderGer");
         reference.setApplication(applicationConfig);
         RegistryConfig registryConfig = new RegistryConfig();
         registryConfig.setAddress("zookeeper://127.0.0.1:2181");
         reference.setRegistry(registryConfig);
         reference.setGeneric(true);
         reference.setInterface("com.ikurento.user.UserProvider");
         GenericService genericService = reference.get();
         Object[] parameterArgs = new Object[]{"A003"};
         Object result = genericService.$invoke("GetUser", null , parameterArgs);
         System.out.println("res: " + result);

         System.out.println("\n\n\nstart to generic invoke1");
         User user = new User();
         user.setName("Patrick");
         user.setId("id");
         user.setAge(10);
         parameterArgs = new Object[]{user};
         Object result1 = genericService.$invoke("queryUser", new String[]{"com.ikurento.user.User"} , parameterArgs);
         System.out.println("res: " + result1);
    }
 
Example 5
Source File: DubboInvoker.java    From dubbo-postman with MIT License 5 votes vote down vote up
ReferenceConfig<GenericService> createReference(PostmanDubboRequest request, DubboParamValue rpcParamValue){

        ReferenceConfig<GenericService> newReference = new ReferenceConfig<GenericService>();

        //设置默认超时无限制,用于在本地调试的时候用
        newReference.setTimeout(Integer.MAX_VALUE);
        newReference.setApplication(application);
        newReference.setInterface(request.getInterfaceName());

        String group = request.getGroup();

        //default是我加的,dubbo默认是没有的
        if(group.isEmpty() || group.equals("default")){

        }else{
            newReference.setGroup(group);
        }

        if(rpcParamValue.isUseDubbo()){
            //直连
            newReference.setUrl(rpcParamValue.getDubboUrl());
            logger.info("直连dubbo地址:"+rpcParamValue.getDubboUrl());
        }else{
            //通过zk访问
            newReference.setRegistry(new RegistryConfig(rpcParamValue.getRegistry()));
        }

        newReference.setVersion(request.getVersion());
        newReference.setGeneric(true);
        //hard code
        newReference.setRetries(1);

        return newReference;
    }
 
Example 6
Source File: ApplicationConfigCache.java    From soul with Apache License 2.0 5 votes vote down vote up
/**
 * Build reference config.
 *
 * @param metaData the meta data
 * @return the reference config
 */
public ReferenceConfig<GenericService> build(final MetaData metaData) {
    ReferenceConfig<GenericService> reference = new ReferenceConfig<>();
    reference.setGeneric(true);
    reference.setApplication(applicationConfig);
    reference.setRegistry(registryConfig);
    reference.setInterface(metaData.getServiceName());
    reference.setProtocol("dubbo");
    String rpcExt = metaData.getRpcExt();
    DubboParamExtInfo dubboParamExtInfo = GsonUtils.getInstance().fromJson(rpcExt, DubboParamExtInfo.class);
    if (Objects.nonNull(dubboParamExtInfo)) {
        if (StringUtils.isNoneBlank(dubboParamExtInfo.getVersion())) {
            reference.setVersion(dubboParamExtInfo.getVersion());
        }
        if (StringUtils.isNoneBlank(dubboParamExtInfo.getGroup())) {
            reference.setGroup(dubboParamExtInfo.getGroup());
        }
        if (StringUtils.isNoneBlank(dubboParamExtInfo.getLoadbalance())) {
            final String loadBalance = dubboParamExtInfo.getLoadbalance();
            reference.setLoadbalance(buildLoadBalanceName(loadBalance));
        }
        Optional.ofNullable(dubboParamExtInfo.getTimeout()).ifPresent(reference::setTimeout);
        Optional.ofNullable(dubboParamExtInfo.getRetries()).ifPresent(reference::setRetries);
    }
    Object obj = reference.get();
    if (obj != null) {
        log.info("init aliaba dubbo reference success there meteData is :{}", metaData.toString());
        cache.put(metaData.getServiceName(), reference);
    }
    return reference;
}
 
Example 7
Source File: DubboConsumerBootstrap.java    From sofa-rpc with Apache License 2.0 5 votes vote down vote up
private void copyConsumer(ConsumerConfig<T> consumerConfig, ReferenceConfig<T> referenceConfig) {
    referenceConfig.setId(consumerConfig.getId());
    referenceConfig.setInterface(consumerConfig.getInterfaceId());
    referenceConfig.setGroup(consumerConfig.getUniqueId());
    referenceConfig.setVersion("1.0");
    referenceConfig.setActives(consumerConfig.getConcurrents());
    referenceConfig.setCluster(consumerConfig.getCluster());
    referenceConfig.setConnections(consumerConfig.getConnectionNum());
    referenceConfig.setRetries(consumerConfig.getRetries());
    referenceConfig.setProxy(consumerConfig.getProxy());
    referenceConfig.setTimeout(consumerConfig.getTimeout());
    referenceConfig.setUrl(consumerConfig.getDirectUrl());
    referenceConfig.setCheck(consumerConfig.isCheck());
    referenceConfig.setLazy(consumerConfig.isLazy());
    referenceConfig.setGeneric(consumerConfig.isGeneric());
    String invokeType = consumerConfig.getInvokeType();
    if (invokeType != null) {
        if (RpcConstants.INVOKER_TYPE_ONEWAY.equals(invokeType)) {
            referenceConfig.setSent(false);
        }
        if (RpcConstants.INVOKER_TYPE_CALLBACK.equals(invokeType)
            || RpcConstants.INVOKER_TYPE_FUTURE.equals(invokeType)) {
            referenceConfig.setAsync(true);
        }
    }
    referenceConfig.setParameters(consumerConfig.getParameters());
}
 
Example 8
Source File: DubboMonitorConsumerFactory.java    From EasyTransaction with Apache License 2.0 5 votes vote down vote up
private GenericService generateService(String appId, Class<?> monitorInterface) {
    
    ReferenceConfig<GenericService> referenceConfig = new ReferenceConfig<GenericService>();
    referenceConfig.setInterface(monitorInterface); // 弱类型接口名 
    referenceConfig.setVersion("1.0.0"); 
    referenceConfig.setGeneric(true); // 声明为泛化接口 
    referenceConfig.setGroup(appId + "-" + monitorInterface.getSimpleName());
    referenceConfig.setCheck(false);
    
    if(applicationConfig != null) {
        referenceConfig.setApplication(applicationConfig);
    }
    
    if(registryConfig != null) {
        referenceConfig.setRegistry(registryConfig);
    }
    
    if(protocolConfig != null) {
        referenceConfig.setProtocol(protocolConfig.getName());
    }
    
    if(moduleConfig != null) {
        referenceConfig.setModule(moduleConfig);
    }
    
    if(monitorConfig != null) {
        referenceConfig.setMonitor(monitorConfig);
    }
    
    if(consumerConfig != null) {
        referenceConfig.setConsumer(consumerConfig);
    }
    
    if(customizationer != null) {
        customizationer.customDubboReferance(appId,null,referenceConfig);
    }
    
    return referenceConfig.get();
}
 
Example 9
Source File: DubboEasyTransRpcConsumerImpl.java    From EasyTransaction with Apache License 2.0 4 votes vote down vote up
private GenericService getCaller(String appId, String busCode,EasyTransRequest<?,?> request) {
	GenericService genericService = mapRef.get(getTargetKey(appId,busCode));
	if(genericService == null){
		
		List<Class<?>> typeArguments = ReflectUtil.getTypeArguments(EasyTransRequest.class, request.getClass());
		Class<?> executorCLass = typeArguments.get(1);
		RelativeInterface annotation = executorCLass.getAnnotation(RelativeInterface.class);
		Class<?> value = annotation.value();
		ReferenceConfig<GenericService> referenceConfig = new ReferenceConfig<GenericService>();
		referenceConfig.setInterface(value.getName()); // 弱类型接口名 
		referenceConfig.setVersion("1.0.0"); 
		referenceConfig.setGeneric(true); // 声明为泛化接口 
		referenceConfig.setGroup(appId + "-" + busCode);
		referenceConfig.setCheck(false);
		referenceConfig.setSticky(true);//设置粘滞连接以优化级联事务的级联提交性能
		
		if(applicationConfig != null) {
			referenceConfig.setApplication(applicationConfig);
		}
		
		if(registryConfig != null) {
			referenceConfig.setRegistry(registryConfig);
		}
		
		if(protocolConfig != null) {
			referenceConfig.setProtocol(protocolConfig.getName());
		}
		
		if(moduleConfig != null) {
			referenceConfig.setModule(moduleConfig);
		}
		
		if(monitorConfig != null) {
			referenceConfig.setMonitor(monitorConfig);
		}
		
		if(consumerConfig != null) {
			referenceConfig.setConsumer(consumerConfig);
		}
		
		if(customizationer != null) {
			customizationer.customDubboReferance(appId,busCode,referenceConfig);
		}
		
		genericService = referenceConfig.get();
		mapRef.put(getTargetKey(appId,busCode), genericService);
	}
	return genericService;
}