diff --git a/README.md b/README.md index 888c4848ef7..3360449a65f 100644 --- a/README.md +++ b/README.md @@ -1,202 +1,143 @@ -Dubbox now means Dubbo eXtensions. If you know java, javax and dubbo, you know what dubbox is :) +# dubbo3 -Dubbox adds features like RESTful remoting, Kyro/FST serialization, etc to the popular [dubbo service framework](http://github.com/alibaba/dubbo). It's been used by several projects of [dangdang.com](http://www.dangdang.com), which is one of the major e-commerce companies in China. +dubbo3 基于 [dubbox 2.8.4] (https://github.com/dangdangdotcom/dubbox) 修改 +具体的使用方法请参考[dubbox 2.8.4] (https://github.com/dangdangdotcom/dubbox) -## 主要贡献者 +## dubbo3修改和增加的功能 -* 沈理 [当当网](http://www.dangdang.com/) shenli@dangdang.com -* 王宇轩 [当当网](http://www.dangdang.com/) wangyuxuan@dangdang.com -* 马金凯 [韩都衣舍](http://www.handu.com/) majinkai@handu.com -* Dylan 独立开发者 dinguangx@163.com -* Kangfoo 独立开发者 +* 重新设计实现了consumer端的异步实现方式,支持guava的ListenableFuture,使用异步调用api更加简单 -有技术问题请移步此处讨论 https://github.com/dangdangdotcom/dubbox/issues +* 添加NotifyCluster和NotifyClusterInvoker代替BroadcastCluster和BroadcastClusterInvoker实现广播 -## Dubbox当前的主要功能 +* 实现基于dubbo、hessian、http协议的分布式服务链路监控和追踪功能,可以将服务链路信息报告给[Zipkin](http://zipkin.io/),Zipkin的用户界面可以浏览全链路每一个服务的延迟 -* **支持REST风格远程调用(HTTP + JSON/XML)**:基于非常成熟的JBoss [RestEasy](http://resteasy.jboss.org/)框架,在dubbo中实现了REST风格(HTTP + JSON/XML)的远程调用,以显著简化企业内部的跨语言交互,同时显著简化企业对外的Open API、无线API甚至AJAX服务端等等的开发。事实上,这个REST调用也使得Dubbo可以对当今特别流行的“微服务”架构提供基础性支持。 另外,REST调用也达到了比较高的性能,在基准测试下,HTTP + JSON与Dubbo 2.x默认的RPC协议(即TCP + Hessian2二进制序列化)之间只有1.5倍左右的差距,详见文档中的基准测试报告。 +* 修改了ExchangeChannel中同步调用的接口,增加Interceptor接口拦截request记录服务调用信息 -* **支持基于Kryo和FST的Java高效序列化实现**:基于当今比较知名的[Kryo](https://github.com/EsotericSoftware/kryo)和[FST](https://github.com/RuedigerMoeller/fast-serialization)高性能序列化库,为Dubbo默认的RPC协议添加新的序列化实现,并优化调整了其序列化体系,比较显著的提高了Dubbo RPC的性能,详见文档中的基准测试报告。 +* 添加了okhttp3支持hessian协议、http协议,目前对这两种协议的拦截基于OkhttpClient的Interceptor机制 -* **支持基于Jackson的JSON序列化**:基于业界应用最广泛的[Jackson](http://jackson.codehaus.org/)序列化库,为Dubbo默认的RPC协议添加新的JSON序列化实现。 +### consumer异步调用 -* **支持基于嵌入式Tomcat的HTTP remoting体系**:基于嵌入式tomcat实现dubbo的HTTP remoting体系(即dubbo-remoting-http),用以逐步取代Dubbo中旧版本的嵌入式Jetty,可以显著的提高REST等的远程调用性能,并将Servlet API的支持从2.5升级到3.1。(注:除了REST,dubbo中的WebServices、Hessian、HTTP Invoker等协议都基于这个HTTP remoting体系)。 +#### Example 1: 基于guava ListenableFuture示例 +```java +ListenableFuture future = simpleService.async_getComplex("abc"); +Futures.addCallback(future, new FutureCallback() { + @Override + public void onSuccess(Complex result) { + + } -* **升级Spring**:将dubbo中Spring由2.x升级到目前最常用的3.x版本,减少版本冲突带来的麻烦。 + @Override + public void onFailure(Throwable t) { -* **升级ZooKeeper客户端**:将dubbo中的zookeeper客户端升级到最新的版本,以修正老版本中包含的bug。 - -* **支持完全基于Java代码的Dubbo配置**:基于Spring的Java Config,实现完全无XML的纯Java代码方式来配置dubbo - -* **调整Demo应用**:暂时将dubbo的demo应用调整并改写以主要演示REST功能、Dubbo协议的新序列化方式、基于Java代码的Spring配置等等。 - -* **修正了dubbo的bug** 包括配置、序列化、管理界面等等的bug。 - -**注:dubbox和dubbo 2.x是兼容的,没有改变dubbo的任何已有的功能和配置方式(除了升级了spring之类的版本)** - -## 文档资料 - -[在Dubbo中开发REST风格的远程调用(RESTful Remoting)](http://dangdangdotcom.github.io/dubbox/rest.html) - -[在Dubbo中使用高效的Java序列化(Kryo和FST)](http://dangdangdotcom.github.io/dubbox/serialization.html) - -[使用JavaConfig方式配置dubbox](http://dangdangdotcom.github.io/dubbox/java-config.html) - -[Dubbo Jackson序列化使用说明](http://dangdangdotcom.github.io/dubbox/jackson.html) - -[Demo应用简单运行指南](http://dangdangdotcom.github.io/dubbox/demo.html) - -[Dubbox@InfoQ](http://www.infoq.com/cn/news/2014/10/dubbox-open-source) - -[Dubbox Wiki](https://github.com/dangdangdotcom/dubbox/wiki) (由社区志愿者自由编辑的) - -## 版本 + } +}); +``` +dubbo3中异步实现思路是为同步接口生成对应的异步接口,consumer和provider使用生成的接口 +在客户端的代理InvocationHandler中调用同步接口, 具体实现参考AsyncableInvocationHandler +origin interface: +```java +@AutoAsync +public interface SimpleService { + @Asyncable + Complex getComplex(String id); +} +``` +async interface:(使用auto-async自动生成) +```java +@AutoGenerated( + value = "net.auto.async.processor.AutoAsyncProcessor" +) +public interface Unified_SimpleService extends SimpleService { + ListenableFuture async_getComplex(String id); +} +``` +consumer配置 +```xml + +``` +provider配置 +```xml + +``` -详见:https://github.com/dangdangdotcom/dubbox/releases +#### auto-async自动生成异步接口 +自动生成async interface需要使用[auto-async] (https://github.com/YanXs/auto-async) +```xml + + net.vakilla + auto-async + 1.0.0 + +``` +### NotifyCluster广播 +dubbo中使用BroadcastCluster实现广播功能,实现方式是顺序调用所有的invoker。这种方式带来的问题是效率低,时间复杂度O(m*n),m代表invoker数量,n代表方法执行时间 +NotifyCluster采用异步模式并行调用invoker,时间复杂度可以接近O(n),当然取决于线程数量和invoker的数量,但是相比于BroadcastCluster线性调用性能高出很多 -* **dubbox-2.8.0**:主要支持REST风格远程调用、支持Kryo和FST序列化、升级了Spring和Zookeeper客户端、调整了demo应用等等 -* **dubbox-2.8.1**:主要支持基于嵌入式tomcat的http-remoting,优化了REST客户端性能,在REST中支持限制服务端接纳的最大HTTP连接数等等 -* **dubbox-2.8.2**: - * 支持REST中的HTTP logging,包括HTTP header的字段和HTTP body中的消息体,方便调试、日志纪录等等 - * 提供辅助类便于REST的中文处理 - * 改变使用`@Reference` annotation配置时的异常处理方式,即当用annotation配置时,过去dubbo在启动期间不抛出依赖服务找不到的异常,而是在具体调用时抛出NPE,这与用XML配置时的行为不一致。 - * 较大的充实了Dubbo REST的文档 -* **dubbox-2.8.3**: - * 在REST中支持dubbo统一的方式用bean validation annotation作参数校验(沈理) - * 在RpcContext上支持获取底层协议的Request/Response(沈理) - * 支持采用Spring的Java Config方式配置dubbo(马金凯) - * 在Dubbo协议中支持基于Jackson的json序列化(Dylan) - * 在Spring AOP代理过的对象上支持dubbo annotation配置(Dylan) - * 修正Dubbo管理界面中没有consumer时出现空指针异常(马金凯) - * 修正@Reference annotation中protocol设置不起作用的bug(沈理) - * 修正@Reference annotation放在setter方法上即会出错的bug(Dylan) +使用方式与broadcastCluster相同,只需要cluster=notify即可 +具体实现参考NotifyClusterInvoker -## 依赖 -从dubbox-2.8.4开始,所有依赖库的使用方式将和dubbo原来的一样:即如果要使用REST、Kyro、FST、Jackson等功能,需要用户自行手工添加相关的依赖。例如: +### rpcTracker分布式链路追踪 -### REST风格远程调用 +目前tracker的使用方式只支持spring xml配置,目前有如下两种方式 +方式一: ```xml - - org.jboss.resteasy - resteasy-jaxrs - 3.0.7.Final - - - org.jboss.resteasy - resteasy-client - 3.0.7.Final - - - javax.validation - validation-api - 1.0.0.GA - + +``` - - - org.jboss.resteasy - resteasy-jackson-provider - 3.0.7.Final - +* address: zipkin transport address +* collector(transport): http\kafka\scribe +* sampler:采样器 +* samplerate:采样率 +* flushinterval:数据刷新频率 - - - org.jboss.resteasy - resteasy-jaxb-provider - 3.0.7.Final - +方式二: +使用方式一在dubbo内部创建tracker对象,因为目前只支持zipkin,tracker对应Brave,没有办法同其他系统,比如数据库的监控结合起来,推荐使用下面的方式 +配置 - - - org.jboss.resteasy - resteasy-netty - 3.0.7.Final - +```xml + - - - org.jboss.resteasy - resteasy-jdk-http - 3.0.7.Final - + + + - - - org.apache.tomcat.embed - tomcat-embed-core - 8.0.11 - - - org.apache.tomcat.embed - tomcat-embed-logging-juli - 8.0.11 - + + + + + ``` -### Kyro序列化 -```xml - - com.esotericsoftware.kryo - kryo - 2.24.0 - - - de.javakaffee - kryo-serializers - 0.26 - -``` +## 依赖 -### FST序列化 +服务链路追踪主要基于Zipkin的 [brave] (https://github.com/openzipkin/brave) +链路追踪功能参考另一个项目 [nightawk] (https://github.com/YanXs/nighthawk) +项目中需要引用 ```xml - de.ruedigermoeller - fst - 1.55 + com.alibaba + dubbo + 3.0.1 -``` - -### Jackson序列化 -```xml - com.fasterxml.jackson.core - jackson-core - 2.3.3 + io.vakilla.nightawk + nightawk-core + 1.0.0.RELEASE + - com.fasterxml.jackson.core - jackson-databind - 2.3.3 + io.vakilla.nightawk + nightawk-dubbo3 + 1.0.0.RELEASE ``` - -## FAQ(暂存) - -### Dubbox需要什么版本的JDK? - -目前最好在JDK 1.7以上运行 - -### Dubbo REST的服务能和Dubbo注册中心、监控中心集成吗? - -可以的,而且是自动集成的,也就是你在dubbo中开发的所有REST服务都会自动注册到服务册中心和监控中心,可以通过它们做管理。 - -但是,只有当REST的消费端也是基于dubbo的时候,注册中心中的许多服务治理操作才能完全起作用。而如果消费端是非dubbo的,自然不受注册中心管理,所以其中很多操作是不会对消费端起作用的。 - -### Dubbo REST中如何实现负载均衡和容错(failover)? - -如果dubbo REST的消费端也是dubbo的,则Dubbo REST和其他dubbo远程调用协议基本完全一样,由dubbo框架透明的在消费端做load balance、failover等等。 - -如果dubbo REST的消费端是非dubbo的,甚至是非java的,则最好配置服务提供端的软负载均衡机制,目前可考虑用LVS、HAProxy、 Nginx等等对HTTP请求做负载均衡。 -### JAX-RS中重载的方法能够映射到同一URL地址吗? +以上依赖需要自己使用maven编译打包(以后会提交到maven中央库) -http://stackoverflow.com/questions/17196766/can-resteasy-choose-method-based-on-query-params -### JAX-RS中作POST的方法能够接收多个参数吗? -http://stackoverflow.com/questions/5553218/jax-rs-post-multiple-objects diff --git a/dubbo-admin/pom.xml b/dubbo-admin/pom.xml index ec2a30be84a..13a9dd9c991 100644 --- a/dubbo-admin/pom.xml +++ b/dubbo-admin/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-admin war diff --git a/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/domain/LoadBalance.java b/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/domain/LoadBalance.java index 1d83f89e405..53c171face2 100644 --- a/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/domain/LoadBalance.java +++ b/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/domain/LoadBalance.java @@ -1,12 +1,12 @@ /** * Project: dubbo.registry.server-1.1.0-SNAPSHOT - * + *

* File Created at 2010-10-21 * $Id: LoadBalance.java 181192 2012-06-21 05:05:47Z tony.chenl $ - * + *

* Copyright 2008 Alibaba.com Croporation Limited. * All rights reserved. - * + *

* This software is the confidential and proprietary information of * Alibaba Company. ("Confidential Information"). You shall not * disclose such Confidential Information and shall use it only in @@ -20,19 +20,19 @@ * @author rain.chenjr * */ -public class LoadBalance extends Entity{ +public class LoadBalance extends Entity { private static final long serialVersionUID = -6050324375352581440L; - + public static final String ALL_METHOD = "*"; - private String service; /* 服务名称 */ - - private String method; /* 方法名称 */ - - private String strategy; /*负载均衡策略*/ - - private String username; /*用户名*/ + private String service; /* 服务名称 */ + + private String method; /* 方法名称 */ + + private String strategy; /*负载均衡策略*/ + + private String username; /*用户名*/ public LoadBalance() { } @@ -40,7 +40,7 @@ public LoadBalance() { public LoadBalance(Long id) { super(id); } - + public String getService() { return service; } @@ -73,5 +73,5 @@ public void setUsername(String username) { this.username = username; } - + } diff --git a/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/domain/Registry.java b/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/domain/Registry.java index 4c00f8eb4d1..601d3f050d8 100644 --- a/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/domain/Registry.java +++ b/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/domain/Registry.java @@ -1,12 +1,12 @@ /** * Project: dubbo.registry-1.1.0-SNAPSHOT - * + *

* File Created at 2010-4-9 * $Id: Registry.java 181192 2012-06-21 05:05:47Z tony.chenl $ - * + *

* Copyright 2008 Alibaba.com Croporation Limited. * All rights reserved. - * + *

* This software is the confidential and proprietary information of * Alibaba Company. ("Confidential Information"). You shall not * disclose such Confidential Information and shall use it only in @@ -19,7 +19,7 @@ /** * Registry - * + * * @author william.liangf */ public class Registry extends Entity { @@ -27,22 +27,22 @@ public class Registry extends Entity { private static final long serialVersionUID = -8866645978415551309L; private String registry;/* 注册中心地址 */ - + private String url; - + private int connections = 0;/*注册中心连接数*/ private Date expired; /*过期时间*/ - + private long alived; - + public Registry() { } public Registry(Long id) { super(id); } - + public Registry(String registryAddress, String consoleUrl, int aliveSeconds) { this.registry = registryAddress; this.url = consoleUrl; @@ -81,12 +81,12 @@ public void setAlived(long aliveSeconds) { this.alived = aliveSeconds; } - + public int getConnections() { return connections; } - + public void setConnections(int connections) { this.connections = connections; } diff --git a/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/route/RouteRule.java b/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/route/RouteRule.java index 6f2732e7d98..12be17acfa5 100644 --- a/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/route/RouteRule.java +++ b/dubbo-admin/src/main/java/com/alibaba/dubbo/registry/common/route/RouteRule.java @@ -1,12 +1,12 @@ /** * Project: dubbo.registry.server - * + *

* File Created at Oct 18, 2010 * $Id: RouteRule.java 182348 2012-06-27 09:16:58Z tony.chenl $ - * + *

* Copyright 1999-2100 Alibaba.com Corporation Limited. * All rights reserved. - * + *

* This software is the confidential and proprietary information of * Alibaba Company. ("Confidential Information"). You shall not * disclose such Confidential Information and shall use it only in @@ -15,19 +15,15 @@ */ package com.alibaba.dubbo.registry.common.route; +import com.alibaba.dubbo.common.utils.StringUtils; +import com.alibaba.dubbo.registry.common.domain.Route; + import java.text.ParseException; -import java.util.Collections; -import java.util.HashMap; -import java.util.HashSet; -import java.util.Map; +import java.util.*; import java.util.Map.Entry; -import java.util.Set; import java.util.regex.Matcher; import java.util.regex.Pattern; -import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.registry.common.domain.Route; - /** * Rule分成两部分,When条件和Then条件。
@@ -37,63 +33,64 @@ * 使用条件对样本进行的匹配的过程称为“过滤”(或称为“筛选”)(Filter)。 * 使用When条件过滤和使用Then条件过滤的样本,不需要是相同的集合。如在Dubbo中,分别对应的是Consumer和Provider。 * 对于RouteRule(路由规则)含义即,符合When条件的Consumer,则对Provider进行Then过滤,出来的Provide即是提供给这个Consumer的Provider。
- * + * * Rule的字符串格式如下: * key1 = value11,value12 & key2 = value21 & key2 != value22 => key3 = value3 & key4 = value41,vlaue42 & key5 !=value51 * 。 * =>之前的称为When条件,是KV对;之后是Then条件,是KV对。KV的Value可以有多个值。

- * + * * 值对象,线程安全。 - * + * * @author william.liangf * @author ding.lid */ public class RouteRule { public static class MatchPair { - Set matches = new HashSet(); + Set matches = new HashSet(); Set unmatches = new HashSet(); public MatchPair() { } - + public MatchPair(Set matches, Set unmatches) { - if(matches == null || unmatches == null) { + if (matches == null || unmatches == null) { throw new IllegalArgumentException("argument of MatchPair is null!"); } - + this.matches = matches; this.unmatches = unmatches; } - + public Set getMatches() { return matches; } - + public Set getUnmatches() { return unmatches; } - + public MatchPair copy() { MatchPair ret = new MatchPair(); ret.matches.addAll(matches); ret.unmatches.addAll(unmatches); return ret; } - + private volatile boolean freezed = false; + void freeze() { - if(freezed) return; + if (freezed) return; synchronized (this) { - if(freezed) return; + if (freezed) return; matches = Collections.unmodifiableSet(matches); unmatches = Collections.unmodifiableSet(unmatches); } } - + public boolean containeValue(String value) { return matches.contains(value) || unmatches.contains(value); } - + /** * 给定的值是否通过该{@link MatchPair}匹配。

* 返回{@code false},如果 @@ -104,16 +101,14 @@ public boolean containeValue(String value) { * otherwise返回true。 */ public boolean pass(String sample) { - if(unmatches.contains(sample)) return false; - if(matches.isEmpty()) return true; - return matches.contains(sample); + return !unmatches.contains(sample) && (matches.isEmpty() || matches.contains(sample)); } - + @Override public String toString() { return String.format("{matches=%s,unmatches=%s}", matches.toString(), unmatches.toString()); } - + // 用Eclipse自动生成 @Override public int hashCode() { @@ -152,15 +147,15 @@ public boolean equals(Object obj) { final Map thenCondition; private static Pattern ROUTE_PATTERN = Pattern.compile("([&!=,]*)\\s*([^&!=,\\s]+)"); - + private static Pattern CONDITION_SEPERATOR = Pattern.compile("(.*)=>(.*)"); - + public static Map parseRule(String rule) throws ParseException { - Map condition = new HashMap(); - if(StringUtils.isBlank(rule)) { + Map condition = new HashMap(); + if (StringUtils.isBlank(rule)) { return condition; - } + } // 匹配或不匹配Key-Value对 MatchPair pair = null; // 多个Value值 @@ -222,27 +217,27 @@ else if (",".equals(separator)) { // 如果为逗号表示 } return condition; } - + // FIXME 集合都要加上unmodified的Wrapper,避免构造后的对象被修改 private RouteRule(Map when, Map then) { - for(Map.Entry entry : when.entrySet()) { + for (Map.Entry entry : when.entrySet()) { entry.getValue().freeze(); } - for(Map.Entry entry : then.entrySet()) { + for (Map.Entry entry : then.entrySet()) { entry.getValue().freeze(); } - + // NOTE: When条件是允许为空的,外部业务来保证类似的约束条件 this.whenCondition = when; this.thenCondition = then; } @SuppressWarnings("unchecked") - static RouteRule EMPTY = new RouteRule(Collections.EMPTY_MAP, Collections.EMPTY_MAP); - + static RouteRule EMPTY = new RouteRule(Collections.EMPTY_MAP, Collections.EMPTY_MAP); + /** * 把字符串形式的RouteRule的解析成对象。 - * + * * @throws ParseException RouteRule字符串格式不对了。以下输入的情况,RouteRule都是非法的。 *

  • 输入是null。 *
  • 输入是空串,或是空白串。 @@ -251,39 +246,39 @@ private RouteRule(Map when, Map then) { *
*/ public static RouteRule parse(Route route) throws ParseException { - if(route == null) + if (route == null) throw new ParseException("null route!", 0); - - if(route.getMatchRule() == null && route.getFilterRule() == null) { + + if (route.getMatchRule() == null && route.getFilterRule() == null) { return parse(route.getRule()); } - - return parse(route == null ? null : route.getMatchRule(), route == null ? null : route.getFilterRule()); + + return parse(route.getMatchRule(), route.getFilterRule()); } - + public static RouteRule parse(String whenRule, String thenRule) throws ParseException { - /*if (whenRule == null || whenRule.trim().length() == 0) { + /*if (whenRule == null || whenRule.trim().length() == 0) { throw new ParseException("Illegal route rule without when express", 0); }*/ - if (thenRule == null || thenRule.trim().length() == 0) { - throw new ParseException("Illegal route rule without then express", 0); - } - Map when = parseRule(whenRule.trim()); + if (thenRule == null || thenRule.trim().length() == 0) { + throw new ParseException("Illegal route rule without then express", 0); + } + Map when = parseRule(whenRule.trim()); Map then = parseRule(thenRule.trim()); return new RouteRule(when, then); } - + public static RouteRule parse(String rule) throws ParseException { - if(StringUtils.isBlank(rule)) { + if (StringUtils.isBlank(rule)) { throw new ParseException("Illegal blank route rule", 0); } - + final Matcher matcher = CONDITION_SEPERATOR.matcher(rule); - if(!matcher.matches()) throw new ParseException("condition seperator => not found!", 0); - + if (!matcher.matches()) throw new ParseException("condition seperator => not found!", 0); + return parse(matcher.group(1), matcher.group(2)); } - + /** * @see #parse(String) * @throws RuntimeException 解析出错时,Wrap了{@link #parse(String)}方法的抛出的{@link ParseException}的异常。 @@ -292,150 +287,149 @@ public static RouteRule parseQuitely(Route route) { try { return parse(route); } catch (ParseException e) { - throw new RuntimeException(e); + throw new RuntimeException(e); } } - + private static Pattern VALUE_LIST_SEPARATOR = Pattern.compile("\\s*,\\s*"); - + static Map parseNameAndValueListString2Condition(Map params, Map notParams) { Map condition = new HashMap(); - - for(Entry entry : params.entrySet()) { + + for (Entry entry : params.entrySet()) { String valueListString = entry.getValue(); - if(StringUtils.isBlank(valueListString)) { + if (StringUtils.isBlank(valueListString)) { continue; } String[] list = VALUE_LIST_SEPARATOR.split(valueListString); Set set = new HashSet(); - for(String item : list) { - if(StringUtils.isBlank(item)) { + for (String item : list) { + if (StringUtils.isBlank(item)) { continue; } set.add(item.trim()); } - if(set.isEmpty()) { + if (set.isEmpty()) { continue; } - + String key = entry.getKey(); MatchPair matchPair = condition.get(key); - if(null == matchPair) { + if (null == matchPair) { matchPair = new MatchPair(); condition.put(key, matchPair); } - + matchPair.matches = set; } - for(Entry entry : notParams.entrySet()) { + for (Entry entry : notParams.entrySet()) { String valueListString = entry.getValue(); - if(StringUtils.isBlank(valueListString)) { + if (StringUtils.isBlank(valueListString)) { continue; } String[] list = VALUE_LIST_SEPARATOR.split(valueListString); Set set = new HashSet(); - for(String item : list) { - if(StringUtils.isBlank(item)) { + for (String item : list) { + if (StringUtils.isBlank(item)) { continue; } set.add(item.trim()); } - if(set.isEmpty()) { + if (set.isEmpty()) { continue; } - + String key = entry.getKey(); MatchPair matchPair = condition.get(key); - if(null == matchPair) { + if (null == matchPair) { matchPair = new MatchPair(); condition.put(key, matchPair); } - + matchPair.unmatches = set; } - + return condition; } - + public static RouteRule createFromNameAndValueListString(Map whenParams, Map notWhenParams, Map thenParams, Map notThenParams) { Map when = parseNameAndValueListString2Condition(whenParams, notWhenParams); Map then = parseNameAndValueListString2Condition(thenParams, notThenParams); - + return new RouteRule(when, then); } - + public static RouteRule createFromCondition(Map whenCondition, Map thenCondition) { return new RouteRule(whenCondition, thenCondition); } - + public static RouteRule copyWithRemove(RouteRule copy, Set whenParams, Set thenParams) { Map when = new HashMap(); - for(Entry entry : copy.getWhenCondition().entrySet()) { - if(whenParams == null || !whenParams.contains(entry.getKey())) { + for (Entry entry : copy.getWhenCondition().entrySet()) { + if (whenParams == null || !whenParams.contains(entry.getKey())) { when.put(entry.getKey(), entry.getValue()); } } - + Map then = new HashMap(); - for(Entry entry : copy.getThenCondition().entrySet()) { - if(thenParams ==null || !thenParams.contains(entry.getKey())) { + for (Entry entry : copy.getThenCondition().entrySet()) { + if (thenParams == null || !thenParams.contains(entry.getKey())) { then.put(entry.getKey(), entry.getValue()); } } - + return new RouteRule(when, then); } - + /** * 使用新的条件值来替换。 - * + * * @param copy 替换的Base * @param whenCondition 要替换的whenCondition,如果Base没有项目,则直接插入。 * @param thenCondition 要替换的thenCondition,如果Base没有项目,则直接插入。 * @return 替换后的RouteRule */ public static RouteRule copyWithReplace(RouteRule copy, Map whenCondition, Map thenCondition) { - if(null == copy) { + if (null == copy) { throw new NullPointerException("Argument copy is null!"); } - + Map when = new HashMap(); when.putAll(copy.getWhenCondition()); - if(whenCondition != null) { + if (whenCondition != null) { when.putAll(whenCondition); } - + Map then = new HashMap(); then.putAll(copy.getThenCondition()); - if(thenCondition != null) { + if (thenCondition != null) { then.putAll(thenCondition); } - + return new RouteRule(when, then); } - + // TODO 目前ToString出来的列表是乱序的,是否要排序? static void join(StringBuilder sb, Set valueSet) { boolean isFirst = true; - for(String s : valueSet) { - if(isFirst) { - isFirst = false; - } - else { - sb.append(","); - } - - sb.append(s); + for (String s : valueSet) { + if (isFirst) { + isFirst = false; + } else { + sb.append(","); + } + + sb.append(s); } } - + /** * 样本是否通过条件。 *

* 如果样本的KV中,存在Key有对应的MatchPair,且Value不通过MatchPair里,返回{@code false}; * 否则返回{@code true}。 - * + * * @see MatchPair#pass(String) */ public static boolean matchCondition(Map sample, @@ -450,66 +444,59 @@ public static boolean matchCondition(Map sample, } return true; } - - + + // FIXME 去掉这样的方法调用 public static String join(Set valueSet) { StringBuilder sb = new StringBuilder(128); join(sb, valueSet); return sb.toString(); } - + // TODO 目前Condition的多个Key是乱序的,是否要排序? public static void contidionToString(StringBuilder sb, Map condition) { boolean isFirst = true; - for(Entry entry: condition.entrySet()) { + for (Entry entry : condition.entrySet()) { String keyName = entry.getKey(); MatchPair p = entry.getValue(); - + @SuppressWarnings("unchecked") Set[] setArray = new Set[]{p.matches, p.unmatches}; String[] opArray = {" = ", " != "}; - - for(int i = 0; i < setArray.length; ++i) { - if(setArray[i].isEmpty()) { + + for (int i = 0; i < setArray.length; ++i) { + if (setArray[i].isEmpty()) { continue; } - if(isFirst) { + if (isFirst) { isFirst = false; - } - else { + } else { sb.append(" & "); } - + sb.append(keyName); sb.append(opArray[i]); join(sb, setArray[i]); } } } - + public boolean isWhenContainValue(String key, String value) { MatchPair matchPair = whenCondition.get(key); - if(null == matchPair) { - return false; - } - - return matchPair.containeValue(value); + return null != matchPair && matchPair.containeValue(value); + } - + public boolean isThenContainValue(String key, String value) { MatchPair matchPair = thenCondition.get(key); - if(null == matchPair) { - return false; - } - - return matchPair.containeValue(value); + return null != matchPair && matchPair.containeValue(value); + } - + public boolean isContainValue(String key, String value) { return isWhenContainValue(key, value) || isThenContainValue(key, value); } - + public Map getWhenCondition() { return whenCondition; } @@ -517,25 +504,25 @@ public Map getWhenCondition() { public Map getThenCondition() { return thenCondition; } - + public String getWhenConditionString() { - StringBuilder sb = new StringBuilder(512); + StringBuilder sb = new StringBuilder(512); contidionToString(sb, whenCondition); - return sb.toString(); + return sb.toString(); } public String getThenConditionString() { - StringBuilder sb = new StringBuilder(512); + StringBuilder sb = new StringBuilder(512); contidionToString(sb, thenCondition); - return sb.toString(); + return sb.toString(); } private volatile String tostring = null; - + @Override public String toString() { - if(tostring != null) - return tostring; + if (tostring != null) + return tostring; StringBuilder sb = new StringBuilder(512); contidionToString(sb, whenCondition); sb.append(" => "); @@ -548,8 +535,8 @@ public String toString() { public int hashCode() { final int prime = 31; int result = 1; - result = prime * result + ((thenCondition == null) ? 0 : thenCondition.hashCode()); - result = prime * result + ((whenCondition == null) ? 0 : whenCondition.hashCode()); + result = prime * result + (thenCondition.hashCode()); + result = prime * result + (whenCondition.hashCode()); return result; } @@ -563,15 +550,9 @@ public boolean equals(Object obj) { if (getClass() != obj.getClass()) return false; RouteRule other = (RouteRule) obj; - if (thenCondition == null) { - if (other.thenCondition != null) - return false; - } else if (!thenCondition.equals(other.thenCondition)) + if (!thenCondition.equals(other.thenCondition)) return false; - if (whenCondition == null) { - if (other.whenCondition != null) - return false; - } else if (!whenCondition.equals(other.whenCondition)) + if (!whenCondition.equals(other.whenCondition)) return false; return true; } diff --git a/dubbo-cluster/pom.xml b/dubbo-cluster/pom.xml index ec6af560cb0..23c75b0ec09 100644 --- a/dubbo-cluster/pom.xml +++ b/dubbo-cluster/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-cluster jar diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/loadbalance/RandomLoadBalance.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/loadbalance/RandomLoadBalance.java index de5002c489a..0a058c41417 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/loadbalance/RandomLoadBalance.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/loadbalance/RandomLoadBalance.java @@ -1,26 +1,26 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.cluster.loadbalance; -import java.util.List; -import java.util.Random; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.rpc.Invocation; +import com.alibaba.dubbo.rpc.Invoker; + +import java.util.List; +import java.util.Random; /** * random load balance. @@ -28,14 +28,14 @@ * @author qianlei * @author william.liangf */ -public class RandomLoadBalance extends AbstractLoadBalance { +public class RandomLoadBalance extends AbstractLoadBalance { public static final String NAME = "random"; private final Random random = new Random(); protected Invoker doSelect(List> invokers, URL url, Invocation invocation) { - int length = invokers.size(); // 总个数 + int length = invokers.size(); // 总个数 int totalWeight = 0; // 总权重 boolean sameWeight = true; // 权重是否都一样 for (int i = 0; i < length; i++) { @@ -46,19 +46,19 @@ protected Invoker doSelect(List> invokers, URL url, Invocation sameWeight = false; // 计算所有权重是否一样 } } - if (totalWeight > 0 && ! sameWeight) { + if (totalWeight > 0 && !sameWeight) { // 如果权重不相同且权重大于0则按总权重数随机 int offset = random.nextInt(totalWeight); // 并确定随机值落在哪个片断上 - for (int i = 0; i < length; i++) { - offset -= getWeight(invokers.get(i), invocation); + for (Invoker invoker : invokers) { + offset -= getWeight(invoker, invocation); if (offset < 0) { - return invokers.get(i); + return invoker; } } } // 如果权重相同或权重为0则均等随机 return invokers.get(random.nextInt(length)); - } + } } \ No newline at end of file diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/router/MockInvokersSelector.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/router/MockInvokersSelector.java index 8ec3a2b40cd..37158b044cb 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/router/MockInvokersSelector.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/router/MockInvokersSelector.java @@ -15,9 +15,6 @@ */ package com.alibaba.dubbo.rpc.cluster.router; -import java.util.ArrayList; -import java.util.List; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.rpc.Invocation; @@ -25,65 +22,68 @@ import com.alibaba.dubbo.rpc.RpcException; import com.alibaba.dubbo.rpc.cluster.Router; +import java.util.ArrayList; +import java.util.List; + /** * mock invoker选择器 - * @author chao.liuc * + * @author chao.liuc */ public class MockInvokersSelector implements Router { - public List> route(final List> invokers, - URL url, final Invocation invocation) throws RpcException { - if (invocation.getAttachments() == null) { - return getNormalInvokers(invokers); - } else { - String value = invocation.getAttachments().get(Constants.INVOCATION_NEED_MOCK); - if (value == null) - return getNormalInvokers(invokers); - else if (Boolean.TRUE.toString().equalsIgnoreCase(value)){ - return getMockedInvokers(invokers); - } - } - return invokers; - } - - private List> getMockedInvokers(final List> invokers) { - if (! hasMockProviders(invokers)){ - return null; - } - List> sInvokers = new ArrayList>(1); - for (Invoker invoker : invokers){ - if (invoker.getUrl().getProtocol().equals(Constants.MOCK_PROTOCOL)){ - sInvokers.add(invoker); - } - } - return sInvokers; - } - - private List> getNormalInvokers(final List> invokers){ - if (! hasMockProviders(invokers)){ - return invokers; - } else { - List> sInvokers = new ArrayList>(invokers.size()); - for (Invoker invoker : invokers){ - if (! invoker.getUrl().getProtocol().equals(Constants.MOCK_PROTOCOL)){ - sInvokers.add(invoker); - } - } - return sInvokers; - } - } - - private boolean hasMockProviders(final List> invokers){ - boolean hasMockProvider = false; - for (Invoker invoker : invokers){ - if (invoker.getUrl().getProtocol().equals(Constants.MOCK_PROTOCOL)){ - hasMockProvider = true; - break; - } - } - return hasMockProvider; - } + public List> route(final List> invokers, + URL url, final Invocation invocation) throws RpcException { + if (invocation.getAttachments() == null) { + return getNormalInvokers(invokers); + } else { + String value = invocation.getAttachments().get(Constants.INVOCATION_NEED_MOCK); + if (value == null) + return getNormalInvokers(invokers); + else if (Boolean.TRUE.toString().equalsIgnoreCase(value)) { + return getMockedInvokers(invokers); + } + } + return invokers; + } + + private List> getMockedInvokers(final List> invokers) { + if (!hasMockProviders(invokers)) { + return null; + } + List> sInvokers = new ArrayList>(1); + for (Invoker invoker : invokers) { + if (invoker.getUrl().getProtocol().equals(Constants.MOCK_PROTOCOL)) { + sInvokers.add(invoker); + } + } + return sInvokers; + } + + private List> getNormalInvokers(final List> invokers) { + if (!hasMockProviders(invokers)) { + return invokers; + } else { + List> sInvokers = new ArrayList>(invokers.size()); + for (Invoker invoker : invokers) { + if (!invoker.getUrl().getProtocol().equals(Constants.MOCK_PROTOCOL)) { + sInvokers.add(invoker); + } + } + return sInvokers; + } + } + + private boolean hasMockProviders(final List> invokers) { + boolean hasMockProvider = false; + for (Invoker invoker : invokers) { + if (invoker.getUrl().getProtocol().equals(Constants.MOCK_PROTOCOL)) { + hasMockProvider = true; + break; + } + } + return hasMockProvider; + } public URL getUrl() { return null; diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/router/condition/ConditionRouter.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/router/condition/ConditionRouter.java index d9bca59ef20..eac784f8e23 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/router/condition/ConditionRouter.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/router/condition/ConditionRouter.java @@ -15,16 +15,6 @@ */ package com.alibaba.dubbo.rpc.cluster.router.condition; -import java.text.ParseException; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.Set; -import java.util.regex.Matcher; -import java.util.regex.Pattern; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; @@ -37,23 +27,28 @@ import com.alibaba.dubbo.rpc.RpcException; import com.alibaba.dubbo.rpc.cluster.Router; +import java.text.ParseException; +import java.util.*; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + /** * ConditionRouter - * + * * @author william.liangf */ public class ConditionRouter implements Router, Comparable { - + private static final Logger logger = LoggerFactory.getLogger(ConditionRouter.class); private final URL url; - + private final int priority; private final boolean force; private final Map whenCondition; - + private final Map thenCondition; public ConditionRouter(URL url) { @@ -85,12 +80,12 @@ public List> route(List> invokers, URL url, Invocation return invokers; } try { - if (! matchWhen(url)) { + if (!matchWhen(url)) { return invokers; } List> result = new ArrayList>(); if (thenCondition == null) { - logger.warn("The current consumer in the service blacklist. consumer: " + NetUtils.getLocalHost() + ", service: " + url.getServiceKey()); + logger.warn("The current consumer in the service blacklist. consumer: " + NetUtils.getLocalHost() + ", service: " + url.getServiceKey()); return result; } for (Invoker invoker : invokers) { @@ -101,8 +96,8 @@ public List> route(List> invokers, URL url, Invocation if (result.size() > 0) { return result; } else if (force) { - logger.warn("The route result is empty and force execute. consumer: " + NetUtils.getLocalHost() + ", service: " + url.getServiceKey() + ", router: " + url.getParameterAndDecoded(Constants.RULE_KEY)); - return result; + logger.warn("The route result is empty and force execute. consumer: " + NetUtils.getLocalHost() + ", service: " + url.getServiceKey() + ", router: " + url.getParameterAndDecoded(Constants.RULE_KEY)); + return result; } } catch (Throwable t) { logger.error("Failed to execute condition router rule: " + getUrl() + ", invokers: " + invokers + ", cause: " + t.getMessage(), t); @@ -129,27 +124,27 @@ public boolean matchWhen(URL url) { public boolean matchThen(URL url, URL param) { return thenCondition != null && matchCondition(thenCondition, url, param); } - + private boolean matchCondition(Map condition, URL url, URL param) { Map sample = url.toMap(); for (Map.Entry entry : sample.entrySet()) { String key = entry.getKey(); MatchPair pair = condition.get(key); - if (pair != null && ! pair.isMatch(entry.getValue(), param)) { + if (pair != null && !pair.isMatch(entry.getValue(), param)) { return false; } } return true; } - + private static Pattern ROUTE_PATTERN = Pattern.compile("([&!=,]*)\\s*([^&!=,\\s]+)"); - + private static Map parseRule(String rule) throws ParseException { Map condition = new HashMap(); - if(StringUtils.isBlank(rule)) { + if (StringUtils.isBlank(rule)) { return condition; - } + } // 匹配或不匹配Key-Value对 MatchPair pair = null; // 多个Value值 @@ -214,9 +209,10 @@ else if (",".equals(separator)) { // 如果为逗号表示 private static final class MatchPair { final Set matches = new HashSet(); final Set mismatches = new HashSet(); + public boolean isMatch(String value, URL param) { for (String match : matches) { - if (! UrlUtils.isMatchGlobPattern(match, value, param)) { + if (!UrlUtils.isMatchGlobPattern(match, value, param)) { return false; } } diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/AbstractClusterInvoker.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/AbstractClusterInvoker.java index bb895faf4c7..d5772944286 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/AbstractClusterInvoker.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/AbstractClusterInvoker.java @@ -15,9 +15,6 @@ */ package com.alibaba.dubbo.rpc.cluster.support; -import java.util.ArrayList; -import java.util.List; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; @@ -33,35 +30,38 @@ import com.alibaba.dubbo.rpc.cluster.LoadBalance; import com.alibaba.dubbo.rpc.support.RpcUtils; +import java.util.ArrayList; +import java.util.List; + /** * AbstractClusterInvoker - * + * * @author william.liangf * @author chao.liuc */ public abstract class AbstractClusterInvoker implements Invoker { - private static final Logger logger = LoggerFactory - .getLogger(AbstractClusterInvoker.class); - protected final Directory directory; + private static final Logger logger = LoggerFactory.getLogger(AbstractClusterInvoker.class); + + protected final Directory directory; - protected final boolean availablecheck; - - private volatile boolean destroyed = false; + protected final boolean availablecheck; - private volatile Invoker stickyInvoker = null; + private volatile boolean destroyed = false; + + private volatile Invoker stickyInvoker = null; public AbstractClusterInvoker(Directory directory) { this(directory, directory.getUrl()); } - + public AbstractClusterInvoker(Directory directory, URL url) { if (directory == null) throw new IllegalArgumentException("service directory == null"); - - this.directory = directory ; + + this.directory = directory; //sticky 需要检测 avaliablecheck - this.availablecheck = url.getParameter(Constants.CLUSTER_AVAILABLE_CHECK_KEY, Constants.DEFAULT_CLUSTER_AVAILABLE_CHECK) ; + this.availablecheck = url.getParameter(Constants.CLUSTER_AVAILABLE_CHECK_KEY, Constants.DEFAULT_CLUSTER_AVAILABLE_CHECK); } public Class getInterface() { @@ -88,39 +88,35 @@ public void destroy() { /** * 使用loadbalance选择invoker.
* a)先lb选择,如果在selected列表中 或者 不可用且做检验时,进入下一步(重选),否则直接返回
- * b)重选验证规则:selected > available .保证重选出的结果尽量不在select中,并且是可用的 - * - * @param availablecheck 如果设置true,在选择的时候先选invoker.available == true + * b)重选验证规则:selected > available .保证重选出的结果尽量不在select中,并且是可用的 + * * @param selected 已选过的invoker.注意:输入保证不重复 - * */ protected Invoker select(LoadBalance loadbalance, Invocation invocation, List> invokers, List> selected) throws RpcException { if (invokers == null || invokers.size() == 0) return null; String methodName = invocation == null ? "" : invocation.getMethodName(); - - boolean sticky = invokers.get(0).getUrl().getMethodParameter(methodName,Constants.CLUSTER_STICKY_KEY, Constants.DEFAULT_CLUSTER_STICKY) ; - { - //ignore overloaded method - if ( stickyInvoker != null && !invokers.contains(stickyInvoker) ){ - stickyInvoker = null; - } - //ignore cucurrent problem - if (sticky && stickyInvoker != null && (selected == null || !selected.contains(stickyInvoker))){ - if (availablecheck && stickyInvoker.isAvailable()){ - return stickyInvoker; - } + + boolean sticky = invokers.get(0).getUrl().getMethodParameter(methodName, Constants.CLUSTER_STICKY_KEY, Constants.DEFAULT_CLUSTER_STICKY); + //ignore overloaded method + if (stickyInvoker != null && !invokers.contains(stickyInvoker)) { + stickyInvoker = null; + } + //ignore cucurrent problem + if (sticky && stickyInvoker != null && (selected == null || !selected.contains(stickyInvoker))) { + if (availablecheck && stickyInvoker.isAvailable()) { + return stickyInvoker; } } - Invoker invoker = doselect(loadbalance, invocation, invokers, selected); - - if (sticky){ + Invoker invoker = doSelect(loadbalance, invocation, invokers, selected); + + if (sticky) { stickyInvoker = invoker; } return invoker; } - - private Invoker doselect(LoadBalance loadbalance, Invocation invocation, List> invokers, List> selected) throws RpcException { + + private Invoker doSelect(LoadBalance loadbalance, Invocation invocation, List> invokers, List> selected) throws RpcException { if (invokers == null || invokers.size() == 0) return null; if (invokers.size() == 1) @@ -130,33 +126,34 @@ private Invoker doselect(LoadBalance loadbalance, Invocation invocation, List return selected.get(0) == invokers.get(0) ? invokers.get(1) : invokers.get(0); } Invoker invoker = loadbalance.select(invokers, getUrl(), invocation); - + //如果 selected中包含(优先判断) 或者 不可用&&availablecheck=true 则重试. - if( (selected != null && selected.contains(invoker)) - ||(!invoker.isAvailable() && getUrl()!=null && availablecheck)){ - try{ + if ((selected != null && selected.contains(invoker)) + || (!invoker.isAvailable() && getUrl() != null && availablecheck)) { + try { Invoker rinvoker = reselect(loadbalance, invocation, invokers, selected, availablecheck); - if(rinvoker != null){ - invoker = rinvoker; - }else{ + if (rinvoker != null) { + invoker = rinvoker; + } else { //看下第一次选的位置,如果不是最后,选+1位置. int index = invokers.indexOf(invoker); - try{ + try { //最后在避免碰撞 - invoker = index doselect(LoadBalance loadbalance, Invocation invocation, List * @return * @throws RpcException */ - private Invoker reselect(LoadBalance loadbalance,Invocation invocation, - List> invokers, List> selected ,boolean availablecheck) + private Invoker reselect(LoadBalance loadbalance, Invocation invocation, + List> invokers, List> selected, boolean availablecheck) throws RpcException { - + //预先分配一个,这个列表是一定会用到的. - List> reselectInvokers = new ArrayList>(invokers.size()>1?(invokers.size()-1):invokers.size()); - + List> reselectInvokers = new ArrayList>(invokers.size() > 1 ? (invokers.size() - 1) : invokers.size()); + //先从非select中选 - if( availablecheck ){ //选isAvailable 的非select - for(Invoker invoker : invokers){ - if(invoker.isAvailable()){ - if(selected ==null || !selected.contains(invoker)){ + if (availablecheck) { //选isAvailable 的非select + for (Invoker invoker : invokers) { + if (invoker.isAvailable()) { + if (selected == null || !selected.contains(invoker)) { reselectInvokers.add(invoker); } } } - if(reselectInvokers.size()>0){ - return loadbalance.select(reselectInvokers, getUrl(), invocation); + if (reselectInvokers.size() > 0) { + return loadbalance.select(reselectInvokers, getUrl(), invocation); } - }else{ //选全部非select - for(Invoker invoker : invokers){ - if(selected ==null || !selected.contains(invoker)){ + } else { //选全部非select + for (Invoker invoker : invokers) { + if (selected == null || !selected.contains(invoker)) { reselectInvokers.add(invoker); } } - if(reselectInvokers.size()>0){ - return loadbalance.select(reselectInvokers, getUrl(), invocation); + if (reselectInvokers.size() > 0) { + return loadbalance.select(reselectInvokers, getUrl(), invocation); } } //最后从select中选可用的. { - if(selected != null){ - for(Invoker invoker : selected){ - if((invoker.isAvailable()) //优先选available - && !reselectInvokers.contains(invoker)){ + if (selected != null) { + for (Invoker invoker : selected) { + if ((invoker.isAvailable()) //优先选available + && !reselectInvokers.contains(invoker)) { reselectInvokers.add(invoker); } } } - if(reselectInvokers.size()>0){ - return loadbalance.select(reselectInvokers, getUrl(), invocation); + if (reselectInvokers.size() > 0) { + return loadbalance.select(reselectInvokers, getUrl(), invocation); } } return null; } - - public Result invoke(final Invocation invocation) throws RpcException { + public Result invoke(final Invocation invocation) throws RpcException { checkWheatherDestoried(); - LoadBalance loadbalance; - List> invokers = list(invocation); if (invokers != null && invokers.size() > 0) { loadbalance = ExtensionLoader.getExtensionLoader(LoadBalance.class).getExtension(invokers.get(0).getUrl() - .getMethodParameter(invocation.getMethodName(),Constants.LOADBALANCE_KEY, Constants.DEFAULT_LOADBALANCE)); + .getMethodParameter(invocation.getMethodName(), Constants.LOADBALANCE_KEY, Constants.DEFAULT_LOADBALANCE)); } else { loadbalance = ExtensionLoader.getExtensionLoader(LoadBalance.class).getExtension(Constants.DEFAULT_LOADBALANCE); } @@ -228,8 +222,7 @@ public Result invoke(final Invocation invocation) throws RpcException { } protected void checkWheatherDestoried() { - - if(destroyed){ + if (destroyed) { throw new RpcException("Rpc cluster invoker for " + getInterface() + " on consumer " + NetUtils.getLocalHost() + " use dubbo version " + Version.getVersion() + " is now destroyed! Can not invoke any more."); @@ -240,13 +233,13 @@ protected void checkWheatherDestoried() { public String toString() { return getInterface() + " -> " + getUrl().toString(); } - + protected void checkInvokers(List> invokers, Invocation invocation) { if (invokers == null || invokers.size() == 0) { throw new RpcException("Failed to invoke the method " - + invocation.getMethodName() + " in the service " + getInterface().getName() + + invocation.getMethodName() + " in the service " + getInterface().getName() + ". No provider available for the service " + directory.getUrl().getServiceKey() - + " from registry " + directory.getUrl().getAddress() + + " from registry " + directory.getUrl().getAddress() + " on the consumer " + NetUtils.getLocalHost() + " using the dubbo version " + Version.getVersion() + ". Please check if the providers have been started and registered."); @@ -255,9 +248,8 @@ protected void checkInvokers(List> invokers, Invocation invocation) { protected abstract Result doInvoke(Invocation invocation, List> invokers, LoadBalance loadbalance) throws RpcException; - - protected List> list(Invocation invocation) throws RpcException { - List> invokers = directory.list(invocation); - return invokers; + + protected List> list(Invocation invocation) throws RpcException { + return directory.list(invocation); } } \ No newline at end of file diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/BroadcastCluster.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/BroadcastCluster.java index 907ec788a23..4f1bdb0aa71 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/BroadcastCluster.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/BroadcastCluster.java @@ -22,13 +22,13 @@ /** * BroadcastCluster - * + * * @author william.liangf */ +@Deprecated public class BroadcastCluster implements Cluster { public Invoker join(Directory directory) throws RpcException { return new BroadcastClusterInvoker(directory); } - } \ No newline at end of file diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/BroadcastClusterInvoker.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/BroadcastClusterInvoker.java index e5d74121206..09ee6c005d8 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/BroadcastClusterInvoker.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/BroadcastClusterInvoker.java @@ -15,38 +15,34 @@ */ package com.alibaba.dubbo.rpc.cluster.support; -import java.util.List; - import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.cluster.Directory; import com.alibaba.dubbo.rpc.cluster.LoadBalance; +import java.util.List; + /** * BroadcastClusterInvoker - * + * * @author william.liangf */ +@Deprecated public class BroadcastClusterInvoker extends AbstractClusterInvoker { - + private static final Logger logger = LoggerFactory.getLogger(BroadcastClusterInvoker.class); public BroadcastClusterInvoker(Directory directory) { super(directory); } - @SuppressWarnings({ "unchecked", "rawtypes" }) + @SuppressWarnings({"unchecked", "rawtypes"}) public Result doInvoke(final Invocation invocation, List> invokers, LoadBalance loadbalance) throws RpcException { checkInvokers(invokers, invocation); - RpcContext.getContext().setInvokers((List)invokers); RpcException exception = null; Result result = null; - for (Invoker invoker: invokers) { + for (Invoker invoker : invokers) { try { result = invoker.invoke(invocation); } catch (RpcException e) { @@ -62,5 +58,4 @@ public Result doInvoke(final Invocation invocation, List> invokers, L } return result; } - } \ No newline at end of file diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/FailoverClusterInvoker.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/FailoverClusterInvoker.java index 71c7f283283..d58118c8615 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/FailoverClusterInvoker.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/FailoverClusterInvoker.java @@ -15,29 +15,25 @@ */ package com.alibaba.dubbo.rpc.cluster.support; -import java.util.ArrayList; -import java.util.HashSet; -import java.util.List; -import java.util.Set; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.cluster.Directory; import com.alibaba.dubbo.rpc.cluster.LoadBalance; +import java.util.ArrayList; +import java.util.HashSet; +import java.util.List; +import java.util.Set; + /** * 失败转移,当出现失败,重试其它服务器,通常用于读操作,但重试会带来更长延迟。 - * + *

* Failover - * + * * @author william.liangf * @author chao.liuc */ @@ -49,10 +45,10 @@ public FailoverClusterInvoker(Directory directory) { super(directory); } - @SuppressWarnings({ "unchecked", "rawtypes" }) + @SuppressWarnings({"unchecked", "rawtypes"}) public Result doInvoke(Invocation invocation, final List> invokers, LoadBalance loadbalance) throws RpcException { - List> copyinvokers = invokers; - checkInvokers(copyinvokers, invocation); + List> copyinvokers = invokers; + checkInvokers(copyinvokers, invocation); int len = getUrl().getMethodParameter(invocation.getMethodName(), Constants.RETRIES_KEY, Constants.DEFAULT_RETRIES) + 1; if (len <= 0) { len = 1; @@ -62,24 +58,23 @@ public Result doInvoke(Invocation invocation, final List> invokers, L List> invoked = new ArrayList>(copyinvokers.size()); // invoked invokers. Set providers = new HashSet(len); for (int i = 0; i < len; i++) { - //重试时,进行重新选择,避免重试时invoker列表已发生变化. - //注意:如果列表发生了变化,那么invoked判断会失效,因为invoker示例已经改变 - if (i > 0) { - checkWheatherDestoried(); - copyinvokers = list(invocation); - //重新检查一下 - checkInvokers(copyinvokers, invocation); - } + //重试时,进行重新选择,避免重试时invoker列表已发生变化. + //注意:如果列表发生了变化,那么invoked判断会失效,因为invoker示例已经改变 + if (i > 0) { + checkWheatherDestoried(); + copyinvokers = list(invocation); + //重新检查一下 + checkInvokers(copyinvokers, invocation); + } Invoker invoker = select(loadbalance, invocation, copyinvokers, invoked); invoked.add(invoker); - RpcContext.getContext().setInvokers((List)invoked); try { Result result = invoker.invoke(invocation); if (le != null && logger.isWarnEnabled()) { logger.warn("Although retry the method " + invocation.getMethodName() + " in the service " + getInterface().getName() + " was successful by the provider " + invoker.getUrl().getAddress() - + ", but there have been failed providers " + providers + + ", but there have been failed providers " + providers + " (" + providers.size() + "/" + copyinvokers.size() + ") from the registry " + directory.getUrl().getAddress() + " on the consumer " + NetUtils.getLocalHost() @@ -99,9 +94,9 @@ public Result doInvoke(Invocation invocation, final List> invokers, L } } throw new RpcException(le != null ? le.getCode() : 0, "Failed to invoke the method " - + invocation.getMethodName() + " in the service " + getInterface().getName() - + ". Tried " + len + " times of the providers " + providers - + " (" + providers.size() + "/" + copyinvokers.size() + + invocation.getMethodName() + " in the service " + getInterface().getName() + + ". Tried " + len + " times of the providers " + providers + + " (" + providers.size() + "/" + copyinvokers.size() + ") from the registry " + directory.getUrl().getAddress() + " on the consumer " + NetUtils.getLocalHost() + " using the dubbo version " + Version.getVersion() + ". Last error is: " diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/ForkingClusterInvoker.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/ForkingClusterInvoker.java index 1ee93ec827a..07d63f59578 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/ForkingClusterInvoker.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/ForkingClusterInvoker.java @@ -13,8 +13,8 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.rpc.cluster.support; - +package com.alibaba.dubbo.rpc.cluster.support; + import java.util.ArrayList; import java.util.List; import java.util.concurrent.BlockingQueue; @@ -33,67 +33,66 @@ import com.alibaba.dubbo.rpc.RpcException; import com.alibaba.dubbo.rpc.cluster.Directory; import com.alibaba.dubbo.rpc.cluster.LoadBalance; - -/** + +/** * 并行调用,只要一个成功即返回,通常用于实时性要求较高的操作,但需要浪费更多服务资源。 * - * Fork - * - * @author william.liangf - */ -public class ForkingClusterInvoker extends AbstractClusterInvoker{ + * Fork + * + * @author william.liangf + */ +public class ForkingClusterInvoker extends AbstractClusterInvoker{ private final ExecutorService executor = Executors.newCachedThreadPool(new NamedThreadFactory("forking-cluster-timer", true)); - - public ForkingClusterInvoker(Directory directory) { - super(directory); - } - + + public ForkingClusterInvoker(Directory directory) { + super(directory); + } + @SuppressWarnings({ "unchecked", "rawtypes" }) public Result doInvoke(final Invocation invocation, List> invokers, LoadBalance loadbalance) throws RpcException { checkInvokers(invokers, invocation); - final List> selected; - final int forks = getUrl().getParameter(Constants.FORKS_KEY, Constants.DEFAULT_FORKS); - final int timeout = getUrl().getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); - if (forks <= 0 || forks >= invokers.size()) { - selected = invokers; - } else { - selected = new ArrayList>(); - for (int i = 0; i < forks; i++) { - //在invoker列表(排除selected)后,如果没有选够,则存在重复循环问题.见select实现. - Invoker invoker = select(loadbalance, invocation, invokers, selected); - if(!selected.contains(invoker)){//防止重复添加invoker - selected.add(invoker); - } - } + final List> selected; + final int forks = getUrl().getParameter(Constants.FORKS_KEY, Constants.DEFAULT_FORKS); + final int timeout = getUrl().getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); + if (forks <= 0 || forks >= invokers.size()) { + selected = invokers; + } else { + selected = new ArrayList>(); + for (int i = 0; i < forks; i++) { + //在invoker列表(排除selected)后,如果没有选够,则存在重复循环问题.见select实现. + Invoker invoker = select(loadbalance, invocation, invokers, selected); + if(!selected.contains(invoker)){//防止重复添加invoker + selected.add(invoker); + } + } } - RpcContext.getContext().setInvokers((List)selected); - final AtomicInteger count = new AtomicInteger(); - final BlockingQueue ref = new LinkedBlockingQueue(); - for (final Invoker invoker : selected) { - executor.execute(new Runnable() { - public void run() { - try { - Result result = invoker.invoke(invocation); - ref.offer(result); - } catch(Throwable e) { - int value = count.incrementAndGet(); - if (value >= selected.size()) { - ref.offer(e); - } - } - } - }); - } - try { + final AtomicInteger count = new AtomicInteger(); + final BlockingQueue ref = new LinkedBlockingQueue(); + for (final Invoker invoker : selected) { + executor.execute(new Runnable() { + public void run() { + try { + Result result = invoker.invoke(invocation); + ref.offer(result); + } catch(Throwable e) { + int value = count.incrementAndGet(); + if (value >= selected.size()) { + ref.offer(e); + } + } + } + }); + } + try { Object ret = ref.poll(timeout, TimeUnit.MILLISECONDS); if (ret instanceof Throwable) { Throwable e = (Throwable) ret; throw new RpcException(e instanceof RpcException ? ((RpcException)e).getCode() : 0, "Failed to forking invoke provider " + selected + ", but no luck to perform the invocation. Last error is: " + e.getMessage(), e.getCause() != null ? e.getCause() : e); } - return (Result) ret; - } catch (InterruptedException e) { - throw new RpcException("Failed to forking invoke provider " + selected + ", but no luck to perform the invocation. Last error is: " + e.getMessage(), e); - } - } + return (Result) ret; + } catch (InterruptedException e) { + throw new RpcException("Failed to forking invoke provider " + selected + ", but no luck to perform the invocation. Last error is: " + e.getMessage(), e); + } + } } \ No newline at end of file diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/MergeableClusterInvoker.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/MergeableClusterInvoker.java index f1d8e479e4f..073cdac0151 100644 --- a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/MergeableClusterInvoker.java +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/MergeableClusterInvoker.java @@ -15,19 +15,6 @@ */ package com.alibaba.dubbo.rpc.cluster.support; -import java.lang.reflect.Array; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.concurrent.Callable; -import java.util.concurrent.ExecutorService; -import java.util.concurrent.Executors; -import java.util.concurrent.Future; -import java.util.concurrent.TimeUnit; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; @@ -35,26 +22,30 @@ import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.ConfigUtils; import com.alibaba.dubbo.common.utils.NamedThreadFactory; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.RpcResult; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.cluster.Directory; import com.alibaba.dubbo.rpc.cluster.Merger; import com.alibaba.dubbo.rpc.cluster.merger.MergerFactory; +import java.lang.reflect.Array; +import java.lang.reflect.Method; +import java.lang.reflect.Modifier; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.concurrent.*; + /** * @author kimi */ -@SuppressWarnings( "unchecked" ) +@SuppressWarnings("unchecked") public class MergeableClusterInvoker implements Invoker { private static final Logger log = LoggerFactory.getLogger(MergeableClusterInvoker.class); private ExecutorService executor = Executors.newCachedThreadPool(new NamedThreadFactory("mergeable-cluster-executor", true)); - + private final Directory directory; public MergeableClusterInvoker(Directory directory) { @@ -62,121 +53,120 @@ public MergeableClusterInvoker(Directory directory) { } @SuppressWarnings("rawtypes") - public Result invoke(final Invocation invocation) throws RpcException { + public Result invoke(final Invocation invocation) throws RpcException { List> invokers = directory.list(invocation); - - String merger = getUrl().getMethodParameter( invocation.getMethodName(), Constants.MERGER_KEY ); - if ( ConfigUtils.isEmpty(merger) ) { // 如果方法不需要Merge,退化为只调一个Group - for(final Invoker invoker : invokers ) { + + String merger = getUrl().getMethodParameter(invocation.getMethodName(), Constants.MERGER_KEY); + if (ConfigUtils.isEmpty(merger)) { // 如果方法不需要Merge,退化为只调一个Group + for (final Invoker invoker : invokers) { if (invoker.isAvailable()) { return invoker.invoke(invocation); } } return invokers.iterator().next().invoke(invocation); } - + Class returnType; try { - returnType = getInterface().getMethod( - invocation.getMethodName(), invocation.getParameterTypes() ).getReturnType(); - } catch ( NoSuchMethodException e ) { + returnType = getInterface().getMethod(invocation.getMethodName(), invocation.getParameterTypes()).getReturnType(); + } catch (NoSuchMethodException e) { returnType = null; } - + Map> results = new HashMap>(); - for( final Invoker invoker : invokers ) { - Future future = executor.submit( new Callable() { + for (final Invoker invoker : invokers) { + Future future = executor.submit(new Callable() { public Result call() throws Exception { return invoker.invoke(new RpcInvocation(invocation, invoker)); } - } ); - results.put( invoker.getUrl().getServiceKey(), future ); + }); + results.put(invoker.getUrl().getServiceKey(), future); } Object result = null; - - List resultList = new ArrayList( results.size() ); - - int timeout = getUrl().getMethodParameter( invocation.getMethodName(), Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT ); - for ( Map.Entry> entry : results.entrySet() ) { + + List resultList = new ArrayList(results.size()); + + int timeout = getUrl().getMethodParameter(invocation.getMethodName(), Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); + for (Map.Entry> entry : results.entrySet()) { Future future = entry.getValue(); try { Result r = future.get(timeout, TimeUnit.MILLISECONDS); if (r.hasException()) { log.error(new StringBuilder(32).append("Invoke ") - .append(getGroupDescFromServiceKey(entry.getKey())) - .append(" failed: ") - .append(r.getException().getMessage()).toString(), - r.getException()); + .append(getGroupDescFromServiceKey(entry.getKey())) + .append(" failed: ") + .append(r.getException().getMessage()).toString(), + r.getException()); } else { resultList.add(r); } - } catch ( Exception e ) { - throw new RpcException( new StringBuilder( 32 ) - .append( "Failed to invoke service " ) - .append( entry.getKey() ) - .append( ": " ) - .append( e.getMessage() ).toString(), - e ); + } catch (Exception e) { + throw new RpcException(new StringBuilder(32) + .append("Failed to invoke service ") + .append(entry.getKey()) + .append(": ") + .append(e.getMessage()).toString(), + e); } } - + if (resultList.size() == 0) { - return new RpcResult((Object)null); + return new RpcResult((Object) null); } else if (resultList.size() == 1) { return resultList.iterator().next(); } if (returnType == void.class) { - return new RpcResult((Object)null); + return new RpcResult((Object) null); } - if ( merger.startsWith(".") ) { + if (merger.startsWith(".")) { merger = merger.substring(1); Method method; try { - method = returnType.getMethod( merger, returnType ); - } catch ( NoSuchMethodException e ) { - throw new RpcException( new StringBuilder( 32 ) - .append( "Can not merge result because missing method [ " ) - .append( merger ) - .append( " ] in class [ " ) - .append( returnType.getClass().getName() ) - .append( " ]" ) - .toString() ); + method = returnType.getMethod(merger, returnType); + } catch (NoSuchMethodException e) { + throw new RpcException(new StringBuilder(32) + .append("Can not merge result because missing method [ ") + .append(merger) + .append(" ] in class [ ") + .append(returnType.getClass().getName()) + .append(" ]") + .toString()); } - if ( method != null ) { - if ( !Modifier.isPublic( method.getModifiers() ) ) { - method.setAccessible( true ); + if (method != null) { + if (!Modifier.isPublic(method.getModifiers())) { + method.setAccessible(true); } - result = resultList.remove( 0 ).getValue(); + result = resultList.remove(0).getValue(); try { - if ( method.getReturnType() != void.class - && method.getReturnType().isAssignableFrom( result.getClass() ) ) { - for ( Result r : resultList ) { - result = method.invoke( result, r.getValue() ); + if (method.getReturnType() != void.class + && method.getReturnType().isAssignableFrom(result.getClass())) { + for (Result r : resultList) { + result = method.invoke(result, r.getValue()); } } else { - for ( Result r : resultList ) { - method.invoke( result, r.getValue() ); + for (Result r : resultList) { + method.invoke(result, r.getValue()); } } - } catch ( Exception e ) { - throw new RpcException( - new StringBuilder( 32 ) - .append( "Can not merge result: " ) - .append( e.getMessage() ).toString(), - e ); + } catch (Exception e) { + throw new RpcException( + new StringBuilder(32) + .append("Can not merge result: ") + .append(e.getMessage()).toString(), + e); } } else { throw new RpcException( - new StringBuilder( 32 ) - .append( "Can not merge result because missing method [ " ) - .append( merger ) - .append( " ] in class [ " ) - .append( returnType.getClass().getName() ) - .append( " ]" ) - .toString() ); + new StringBuilder(32) + .append("Can not merge result because missing method [ ") + .append(merger) + .append(" ] in class [ ") + .append(returnType.getClass().getName()) + .append(" ]") + .toString()); } } else { Merger resultMerger; @@ -187,16 +177,16 @@ public Result call() throws Exception { } if (resultMerger != null) { List rets = new ArrayList(resultList.size()); - for(Result r : resultList) { + for (Result r : resultList) { rets.add(r.getValue()); } result = resultMerger.merge( - rets.toArray((Object[])Array.newInstance(returnType, 0))); + rets.toArray((Object[]) Array.newInstance(returnType, 0))); } else { - throw new RpcException( "There is no merger to merge result." ); + throw new RpcException("There is no merger to merge result."); } } - return new RpcResult( result ); + return new RpcResult(result); } public Class getInterface() { @@ -219,7 +209,7 @@ private String getGroupDescFromServiceKey(String key) { int index = key.indexOf("/"); if (index > 0) { return new StringBuilder(32).append("group [ ") - .append(key.substring(0, index)).append(" ]").toString(); + .append(key.substring(0, index)).append(" ]").toString(); } return key; } diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/NotifyCluster.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/NotifyCluster.java new file mode 100644 index 00000000000..0230538bc82 --- /dev/null +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/NotifyCluster.java @@ -0,0 +1,19 @@ +package com.alibaba.dubbo.rpc.cluster.support; + +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.cluster.Cluster; +import com.alibaba.dubbo.rpc.cluster.Directory; + +/** + * @author Xs + */ +public class NotifyCluster implements Cluster{ + + public final static String NAME = "notify"; + + @Override + public Invoker join(Directory directory) throws RpcException { + return new NotifyClusterInvoker(directory); + } +} diff --git a/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/NotifyClusterInvoker.java b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/NotifyClusterInvoker.java new file mode 100644 index 00000000000..95574791d90 --- /dev/null +++ b/dubbo-cluster/src/main/java/com/alibaba/dubbo/rpc/cluster/support/NotifyClusterInvoker.java @@ -0,0 +1,170 @@ +package com.alibaba.dubbo.rpc.cluster.support; + +import com.alibaba.dubbo.common.logger.Logger; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.rpc.Invocation; +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.Result; +import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.async.CommandListener; +import com.alibaba.dubbo.rpc.async.ListenableAsyncCommand; +import com.alibaba.dubbo.rpc.cluster.Directory; +import com.alibaba.dubbo.rpc.cluster.LoadBalance; + +import java.util.ArrayList; +import java.util.List; +import java.util.concurrent.CountDownLatch; + +/** + * @author Xs + */ +public class NotifyClusterInvoker extends AbstractClusterInvoker { + + private static final Logger logger = LoggerFactory.getLogger(NotifyClusterInvoker.class); + + public NotifyClusterInvoker(Directory directory) { + super(directory); + } + + @SuppressWarnings({"unchecked", "rawtypes"}) + public Result doInvoke(final Invocation invocation, List> invokers, LoadBalance loadbalance) throws RpcException { + checkInvokers(invokers, invocation); + return doInvokeAsync(invocation, invokers); + } + + private Result doInvokeAsync(final Invocation invocation, List> invokers) { + CountDownLatch latch = new CountDownLatch(invokers.size()); + AsyncResultProcessor asyncResultProcessor = new AsyncResultProcessor(invokers.size()); + for (final Invoker invoker : invokers) { + ListenableAsyncCommand command = new AsyncInvocationCommand(invoker, invocation); + AsyncResult result = new AsyncResult(latch); + command.addListener(result).submit(); + asyncResultProcessor.addAsyncResult(result); + } + try { + latch.await(); + } catch (InterruptedException e) { + throw new RpcException(e.getMessage(), e); + } + asyncResultProcessor.processResult(); + if (asyncResultProcessor.getException() != null) { + throw asyncResultProcessor.getException(); + } + return asyncResultProcessor.getResult(); + } + + private class AsyncInvocationCommand extends ListenableAsyncCommand { + + private final Invoker invoker; + + private final Invocation invocation; + + public AsyncInvocationCommand(Invoker invoker, Invocation invocation) { + this.invoker = invoker; + this.invocation = invocation; + } + + @Override + public Result run() throws Exception { + return doInvoke(invoker, invocation); + } + } + + private class AsyncResult implements CommandListener { + + private final CountDownLatch latch; + + private Result reVal; + + private RpcException exception; + + private AsyncResult(CountDownLatch latch) { + this.latch = latch; + } + + @Override + public void onSuccess(Result result) { + try { + reVal = result; + } finally { + latch.countDown(); + } + } + + @Override + public void onFailure(Throwable t) { + try { + if (t instanceof RpcException) { + exception = (RpcException) t; + } else { + exception = new RpcException(t.getMessage(), t); + } + } finally { + latch.countDown(); + } + } + + public RpcException getException() { + return exception; + } + + public Result getResult() { + return reVal; + } + } + + private class AsyncResultProcessor { + + private final List asyncResult; + + private RpcException exception; + + private Result result; + + public AsyncResultProcessor(int size) { + asyncResult = new ArrayList(size); + } + + public void addAsyncResult(AsyncResult asyncResult) { + this.asyncResult.add(asyncResult); + } + + void processResult() { + for (AsyncResult invocation : asyncResult) { + exception = invocation.getException(); + if (exception != null) { + break; + } + } + if (exception == null) { + result = asyncResult.get(0).getResult(); + } + } + + public Result getResult() { + return result; + } + + public RpcException getException() { + return exception; + } + } + + private Result doInvoke(Invoker invoker, Invocation invocation) { + Result result = null; + RpcException exception = null; + try { + result = invoker.invoke(invocation); + } catch (RpcException e) { + exception = e; + logger.warn(e.getMessage(), e); + } catch (Throwable e) { + exception = new RpcException(e.getMessage(), e); + logger.warn(e.getMessage(), e); + } + if (exception != null) { + throw exception; + } + return result; + } +} diff --git a/dubbo-cluster/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.Cluster b/dubbo-cluster/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.Cluster index 54e85ed763b..729c67c9cf8 100644 --- a/dubbo-cluster/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.Cluster +++ b/dubbo-cluster/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.Cluster @@ -6,4 +6,5 @@ failback=com.alibaba.dubbo.rpc.cluster.support.FailbackCluster forking=com.alibaba.dubbo.rpc.cluster.support.ForkingCluster available=com.alibaba.dubbo.rpc.cluster.support.AvailableCluster mergeable=com.alibaba.dubbo.rpc.cluster.support.MergeableCluster -broadcast=com.alibaba.dubbo.rpc.cluster.support.BroadcastCluster \ No newline at end of file +broadcast=com.alibaba.dubbo.rpc.cluster.support.BroadcastCluster +notify=com.alibaba.dubbo.rpc.cluster.support.NotifyCluster \ No newline at end of file diff --git a/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailSafeClusterInvokerTest.java b/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailSafeClusterInvokerTest.java index 5d96da77c03..ad582b54a15 100644 --- a/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailSafeClusterInvokerTest.java +++ b/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailSafeClusterInvokerTest.java @@ -94,7 +94,6 @@ public void testInvokeExceptoin() { resetInvokerToException(); FailsafeClusterInvoker invoker = new FailsafeClusterInvoker(dic); invoker.invoke(invocation); - Assert.assertNull(RpcContext.getContext().getInvoker()); } @Test() diff --git a/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailbackClusterInvokerTest.java b/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailbackClusterInvokerTest.java index 8ad9065c6eb..4c48fd22d59 100644 --- a/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailbackClusterInvokerTest.java +++ b/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailbackClusterInvokerTest.java @@ -98,7 +98,6 @@ public void testInvokeExceptoin() { FailbackClusterInvoker invoker = new FailbackClusterInvoker( dic); invoker.invoke(invocation); - Assert.assertNull(RpcContext.getContext().getInvoker()); } @Test() @@ -143,7 +142,6 @@ public void testRetryFailed() { FailbackClusterInvoker invoker = new FailbackClusterInvoker( dic); invoker.invoke(invocation); - Assert.assertNull(RpcContext.getContext().getInvoker()); invoker.retryFailed();// when retry the invoker which get from failed map already is not the mocked invoker,so // it can be invoke successfully } diff --git a/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailfastClusterInvokerTest.java b/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailfastClusterInvokerTest.java index 72fdb8a6b14..52fca7ff0bb 100644 --- a/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailfastClusterInvokerTest.java +++ b/dubbo-cluster/src/test/java/com/alibaba/dubbo/rpc/cluster/support/FailfastClusterInvokerTest.java @@ -1,42 +1,42 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.cluster.support; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.fail; - -import java.util.ArrayList; -import java.util.List; - -import junit.framework.Assert; - -import org.easymock.EasyMock; -import org.junit.After; -import org.junit.Before; -import org.junit.Test; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.RpcResult; -import com.alibaba.dubbo.rpc.cluster.Directory; +import static org.junit.Assert.assertFalse; +import static org.junit.Assert.fail; + +import java.util.ArrayList; +import java.util.List; + +import junit.framework.Assert; + +import org.easymock.EasyMock; +import org.junit.After; +import org.junit.Before; +import org.junit.Test; + +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.rpc.Invocation; +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.Result; +import com.alibaba.dubbo.rpc.RpcContext; +import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.RpcInvocation; +import com.alibaba.dubbo.rpc.RpcResult; +import com.alibaba.dubbo.rpc.cluster.Directory; /** * FailfastClusterInvokerTest @@ -95,7 +95,6 @@ public void testInvokeExceptoin() { resetInvoker1ToException(); FailfastClusterInvoker invoker = new FailfastClusterInvoker(dic); invoker.invoke(invocation); - Assert.assertSame(invoker1, RpcContext.getContext().getInvoker()); } @Test() @@ -106,30 +105,30 @@ public void testInvokeNoExceptoin() { FailfastClusterInvoker invoker = new FailfastClusterInvoker(dic); Result ret = invoker.invoke(invocation); Assert.assertSame(result, ret); - } - - @Test() - public void testNoInvoke() { - dic = EasyMock.createMock(Directory.class); - - EasyMock.expect(dic.getUrl()).andReturn(url).anyTimes(); - EasyMock.expect(dic.list(invocation)).andReturn(null).anyTimes(); - EasyMock.expect(dic.getInterface()).andReturn(FailfastClusterInvokerTest.class).anyTimes(); - - invocation.setMethodName("method1"); - EasyMock.replay(dic); - - invokers.add(invoker1); - - resetInvoker1ToNoException(); - - FailfastClusterInvoker invoker = new FailfastClusterInvoker(dic); - try { - invoker.invoke(invocation); - fail(); - } catch (RpcException expected) { - assertFalse(expected.getCause() instanceof RpcException); - } - } + } + + @Test() + public void testNoInvoke() { + dic = EasyMock.createMock(Directory.class); + + EasyMock.expect(dic.getUrl()).andReturn(url).anyTimes(); + EasyMock.expect(dic.list(invocation)).andReturn(null).anyTimes(); + EasyMock.expect(dic.getInterface()).andReturn(FailfastClusterInvokerTest.class).anyTimes(); + + invocation.setMethodName("method1"); + EasyMock.replay(dic); + + invokers.add(invoker1); + + resetInvoker1ToNoException(); + + FailfastClusterInvoker invoker = new FailfastClusterInvoker(dic); + try { + invoker.invoke(invocation); + fail(); + } catch (RpcException expected) { + assertFalse(expected.getCause() instanceof RpcException); + } + } } \ No newline at end of file diff --git a/dubbo-common/pom.xml b/dubbo-common/pom.xml index 0d5e9f761de..8eaeb85dd41 100644 --- a/dubbo-common/pom.xml +++ b/dubbo-common/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-common jar diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/Constants.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/Constants.java index 2c712237bc6..07f9c188acd 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/Constants.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/Constants.java @@ -20,425 +20,425 @@ /** * Constants - * + * * @author william.liangf */ public class Constants { - public static final String PROVIDER = "provider"; + public static final String PROVIDER = "provider"; - public static final String CONSUMER = "consumer"; + public static final String CONSUMER = "consumer"; - public static final String REGISTER = "register"; + public static final String REGISTER = "register"; - public static final String UNREGISTER = "unregister"; + public static final String UNREGISTER = "unregister"; - public static final String SUBSCRIBE = "subscribe"; + public static final String SUBSCRIBE = "subscribe"; - public static final String UNSUBSCRIBE = "unsubscribe"; - - public static final String CATEGORY_KEY = "category"; + public static final String UNSUBSCRIBE = "unsubscribe"; - public static final String PROVIDERS_CATEGORY = "providers"; + public static final String CATEGORY_KEY = "category"; - public static final String CONSUMERS_CATEGORY = "consumers"; + public static final String PROVIDERS_CATEGORY = "providers"; - public static final String ROUTERS_CATEGORY = "routers"; + public static final String CONSUMERS_CATEGORY = "consumers"; - public static final String CONFIGURATORS_CATEGORY = "configurators"; + public static final String ROUTERS_CATEGORY = "routers"; - public static final String DEFAULT_CATEGORY = PROVIDERS_CATEGORY; + public static final String CONFIGURATORS_CATEGORY = "configurators"; - public static final String ENABLED_KEY = "enabled"; + public static final String DEFAULT_CATEGORY = PROVIDERS_CATEGORY; - public static final String DISABLED_KEY = "disabled"; + public static final String ENABLED_KEY = "enabled"; - public static final String VALIDATION_KEY = "validation"; + public static final String DISABLED_KEY = "disabled"; - public static final String CACHE_KEY = "cache"; + public static final String VALIDATION_KEY = "validation"; - public static final String DYNAMIC_KEY = "dynamic"; + public static final String CACHE_KEY = "cache"; - public static final String DUBBO_PROPERTIES_KEY = "dubbo.properties.file"; + public static final String DYNAMIC_KEY = "dynamic"; - public static final String DEFAULT_DUBBO_PROPERTIES = "dubbo.properties"; + public static final String DUBBO_PROPERTIES_KEY = "dubbo.properties.file"; - public static final String SENT_KEY = "sent"; + public static final String DEFAULT_DUBBO_PROPERTIES = "dubbo.properties"; - public static final boolean DEFAULT_SENT = false; + public static final String SENT_KEY = "sent"; - public static final String REGISTRY_PROTOCOL = "registry"; + public static final boolean DEFAULT_SENT = false; - public static final String $INVOKE = "$invoke"; + public static final String REGISTRY_PROTOCOL = "registry"; - public static final String $ECHO = "$echo"; + public static final String $INVOKE = "$invoke"; - public static final int DEFAULT_IO_THREADS = Runtime.getRuntime() - .availableProcessors() + 1; + public static final String $ECHO = "$echo"; - public static final String DEFAULT_PROXY = "javassist"; + public static final int DEFAULT_IO_THREADS = Runtime.getRuntime() + .availableProcessors() + 1; - public static final int DEFAULT_PAYLOAD = 8 * 1024 * 1024; // 8M + public static final String DEFAULT_PROXY = "javassist"; - public static final String DEFAULT_CLUSTER = "failover"; + public static final int DEFAULT_PAYLOAD = 8 * 1024 * 1024; // 8M - public static final String DEFAULT_DIRECTORY = "dubbo"; + public static final String DEFAULT_CLUSTER = "failover"; - public static final String DEFAULT_LOADBALANCE = "random"; + public static final String DEFAULT_DIRECTORY = "dubbo"; - public static final String DEFAULT_PROTOCOL = "dubbo"; + public static final String DEFAULT_LOADBALANCE = "random"; - public static final String DEFAULT_EXCHANGER = "header"; + public static final String DEFAULT_PROTOCOL = "dubbo"; - public static final String DEFAULT_TRANSPORTER = "netty"; + public static final String DEFAULT_EXCHANGER = "header"; - public static final String DEFAULT_REMOTING_SERVER = "netty"; + public static final String DEFAULT_TRANSPORTER = "netty"; - public static final String DEFAULT_REMOTING_CLIENT = "netty"; + public static final String DEFAULT_REMOTING_SERVER = "netty"; - public static final String DEFAULT_REMOTING_CODEC = "dubbo"; + public static final String DEFAULT_REMOTING_CLIENT = "netty"; - public static final String DEFAULT_REMOTING_SERIALIZATION = "hessian2"; + public static final String DEFAULT_REMOTING_CODEC = "dubbo"; - public static final String DEFAULT_HTTP_SERVER = "servlet"; + public static final String DEFAULT_REMOTING_SERIALIZATION = "hessian2"; - public static final String DEFAULT_HTTP_CLIENT = "jdk"; + public static final String DEFAULT_HTTP_SERVER = "servlet"; - public static final String DEFAULT_HTTP_SERIALIZATION = "json"; + public static final String DEFAULT_HTTP_CLIENT = "jdk"; - public static final String DEFAULT_CHARSET = "UTF-8"; + public static final String DEFAULT_HTTP_SERIALIZATION = "json"; - public static final int DEFAULT_WEIGHT = 100; + public static final String DEFAULT_CHARSET = "UTF-8"; - public static final int DEFAULT_FORKS = 2; + public static final int DEFAULT_WEIGHT = 100; - public static final String DEFAULT_THREAD_NAME = "Dubbo"; + public static final int DEFAULT_FORKS = 2; - public static final int DEFAULT_CORE_THREADS = 0; + public static final String DEFAULT_THREAD_NAME = "Dubbo"; - public static final int DEFAULT_THREADS = 200; + public static final int DEFAULT_CORE_THREADS = 0; + + public static final int DEFAULT_THREADS = 200; public static final boolean DEFAULT_KEEP_ALIVE = true; - public static final int DEFAULT_QUEUES = 0; + public static final int DEFAULT_QUEUES = 0; - public static final int DEFAULT_ALIVE = 60 * 1000; + public static final int DEFAULT_ALIVE = 60 * 1000; - public static final int DEFAULT_CONNECTIONS = 0; + public static final int DEFAULT_CONNECTIONS = 0; - public static final int DEFAULT_ACCEPTS = 0; + public static final int DEFAULT_ACCEPTS = 0; - public static final int DEFAULT_IDLE_TIMEOUT = 600 * 1000; + public static final int DEFAULT_IDLE_TIMEOUT = 600 * 1000; - public static final int DEFAULT_HEARTBEAT = 60 * 1000; + public static final int DEFAULT_HEARTBEAT = 60 * 1000; - public static final int DEFAULT_TIMEOUT = 1000; + public static final int DEFAULT_TIMEOUT = 1000; - public static final int DEFAULT_CONNECT_TIMEOUT = 3000; + public static final int DEFAULT_CONNECT_TIMEOUT = 3000; - public static final int DEFAULT_REGISTRY_CONNECT_TIMEOUT = 5000; + public static final int DEFAULT_REGISTRY_CONNECT_TIMEOUT = 5000; - public static final int DEFAULT_RETRIES = 2; + public static final int DEFAULT_RETRIES = 2; // default buffer size is 8k. - public static final int DEFAULT_BUFFER_SIZE = 8 * 1024; + public static final int DEFAULT_BUFFER_SIZE = 8 * 1024; - public static final int MAX_BUFFER_SIZE = 16 * 1024; + public static final int MAX_BUFFER_SIZE = 16 * 1024; - public static final int MIN_BUFFER_SIZE = 1 * 1024; + public static final int MIN_BUFFER_SIZE = 1024; - public static final String REMOVE_VALUE_PREFIX = "-"; + public static final String REMOVE_VALUE_PREFIX = "-"; - public static final String HIDE_KEY_PREFIX = "."; + public static final String HIDE_KEY_PREFIX = "."; - public static final String DEFAULT_KEY_PREFIX = "default."; + public static final String DEFAULT_KEY_PREFIX = "default."; - public static final String DEFAULT_KEY = "default"; + public static final String DEFAULT_KEY = "default"; - public static final String LOADBALANCE_KEY = "loadbalance"; + public static final String LOADBALANCE_KEY = "loadbalance"; // key for router type, for e.g., "script"/"file", corresponding to ScriptRouterFactory.NAME, FileRouterFactory.NAME - public static final String ROUTER_KEY = "router"; + public static final String ROUTER_KEY = "router"; - public static final String CLUSTER_KEY = "cluster"; + public static final String CLUSTER_KEY = "cluster"; - public static final String REGISTRY_KEY = "registry"; + public static final String REGISTRY_KEY = "registry"; - public static final String MONITOR_KEY = "monitor"; + public static final String MONITOR_KEY = "monitor"; - public static final String SIDE_KEY = "side"; + public static final String SIDE_KEY = "side"; - public static final String PROVIDER_SIDE = "provider"; + public static final String PROVIDER_SIDE = "provider"; - public static final String CONSUMER_SIDE = "consumer"; + public static final String CONSUMER_SIDE = "consumer"; - public static final String DEFAULT_REGISTRY = "dubbo"; + public static final String DEFAULT_REGISTRY = "dubbo"; - public static final String BACKUP_KEY = "backup"; + public static final String BACKUP_KEY = "backup"; - public static final String DIRECTORY_KEY = "directory"; + public static final String DIRECTORY_KEY = "directory"; - public static final String DEPRECATED_KEY = "deprecated"; + public static final String DEPRECATED_KEY = "deprecated"; - public static final String ANYHOST_KEY = "anyhost"; + public static final String ANYHOST_KEY = "anyhost"; - public static final String ANYHOST_VALUE = "0.0.0.0"; + public static final String ANYHOST_VALUE = "0.0.0.0"; - public static final String LOCALHOST_KEY = "localhost"; + public static final String LOCALHOST_KEY = "localhost"; - public static final String LOCALHOST_VALUE = "127.0.0.1"; + public static final String LOCALHOST_VALUE = "127.0.0.1"; - public static final String APPLICATION_KEY = "application"; + public static final String APPLICATION_KEY = "application"; - public static final String LOCAL_KEY = "local"; + public static final String LOCAL_KEY = "local"; - public static final String STUB_KEY = "stub"; + public static final String STUB_KEY = "stub"; - public static final String MOCK_KEY = "mock"; + public static final String MOCK_KEY = "mock"; - public static final String PROTOCOL_KEY = "protocol"; + public static final String PROTOCOL_KEY = "protocol"; - public static final String PROXY_KEY = "proxy"; + public static final String PROXY_KEY = "proxy"; - public static final String WEIGHT_KEY = "weight"; + public static final String WEIGHT_KEY = "weight"; - public static final String FORKS_KEY = "forks"; + public static final String FORKS_KEY = "forks"; - public static final String DEFAULT_THREADPOOL = "limited"; + public static final String DEFAULT_THREADPOOL = "limited"; - public static final String DEFAULT_CLIENT_THREADPOOL = "cached"; + public static final String DEFAULT_CLIENT_THREADPOOL = "cached"; - public static final String THREADPOOL_KEY = "threadpool"; + public static final String THREADPOOL_KEY = "threadpool"; - public static final String THREAD_NAME_KEY = "threadname"; + public static final String THREAD_NAME_KEY = "threadname"; - public static final String IO_THREADS_KEY = "iothreads"; + public static final String IO_THREADS_KEY = "iothreads"; - public static final String CORE_THREADS_KEY = "corethreads"; + public static final String CORE_THREADS_KEY = "corethreads"; - public static final String THREADS_KEY = "threads"; + public static final String THREADS_KEY = "threads"; - public static final String QUEUES_KEY = "queues"; + public static final String QUEUES_KEY = "queues"; - public static final String ALIVE_KEY = "alive"; + public static final String ALIVE_KEY = "alive"; - public static final String EXECUTES_KEY = "executes"; + public static final String EXECUTES_KEY = "executes"; - public static final String BUFFER_KEY = "buffer"; + public static final String BUFFER_KEY = "buffer"; - public static final String PAYLOAD_KEY = "payload"; + public static final String PAYLOAD_KEY = "payload"; - public static final String REFERENCE_FILTER_KEY = "reference.filter"; + public static final String REFERENCE_FILTER_KEY = "reference.filter"; - public static final String INVOKER_LISTENER_KEY = "invoker.listener"; + public static final String INVOKER_LISTENER_KEY = "invoker.listener"; - public static final String SERVICE_FILTER_KEY = "service.filter"; + public static final String SERVICE_FILTER_KEY = "service.filter"; - public static final String EXPORTER_LISTENER_KEY = "exporter.listener"; + public static final String EXPORTER_LISTENER_KEY = "exporter.listener"; - public static final String ACCESS_LOG_KEY = "accesslog"; + public static final String ACCESS_LOG_KEY = "accesslog"; - public static final String ACTIVES_KEY = "actives"; + public static final String ACTIVES_KEY = "actives"; - public static final String CONNECTIONS_KEY = "connections"; + public static final String CONNECTIONS_KEY = "connections"; - public static final String ACCEPTS_KEY = "accepts"; + public static final String ACCEPTS_KEY = "accepts"; - public static final String IDLE_TIMEOUT_KEY = "idle.timeout"; + public static final String IDLE_TIMEOUT_KEY = "idle.timeout"; - public static final String HEARTBEAT_KEY = "heartbeat"; + public static final String HEARTBEAT_KEY = "heartbeat"; - public static final String HEARTBEAT_TIMEOUT_KEY = "heartbeat.timeout"; + public static final String HEARTBEAT_TIMEOUT_KEY = "heartbeat.timeout"; - public static final String CONNECT_TIMEOUT_KEY = "connect.timeout"; + public static final String CONNECT_TIMEOUT_KEY = "connect.timeout"; - public static final String TIMEOUT_KEY = "timeout"; + public static final String TIMEOUT_KEY = "timeout"; - public static final String RETRIES_KEY = "retries"; + public static final String RETRIES_KEY = "retries"; - public static final String PROMPT_KEY = "prompt"; + public static final String PROMPT_KEY = "prompt"; - public static final String DEFAULT_PROMPT = "dubbo>"; + public static final String DEFAULT_PROMPT = "dubbo>"; - public static final String CODEC_KEY = "codec"; + public static final String CODEC_KEY = "codec"; - public static final String SERIALIZATION_KEY = "serialization"; + public static final String SERIALIZATION_KEY = "serialization"; // modified by lishen public static final String EXTENSION_KEY = "extension"; // modified by lishen - public static final String KEEP_ALIVE_KEY = "keepalive"; + public static final String KEEP_ALIVE_KEY = "keepalive"; // modified by lishen // TODO change to a better name - public static final String OPTIMIZER_KEY = "optimizer"; + public static final String OPTIMIZER_KEY = "optimizer"; + + public static final String EXCHANGER_KEY = "exchanger"; - public static final String EXCHANGER_KEY = "exchanger"; + public static final String TRANSPORTER_KEY = "transporter"; - public static final String TRANSPORTER_KEY = "transporter"; + public static final String SERVER_KEY = "server"; - public static final String SERVER_KEY = "server"; + public static final String CLIENT_KEY = "client"; - public static final String CLIENT_KEY = "client"; + public static final String ID_KEY = "id"; - public static final String ID_KEY = "id"; + public static final String ASYNC_KEY = "async"; - public static final String ASYNC_KEY = "async"; + public static final String RETURN_KEY = "return"; - public static final String RETURN_KEY = "return"; + public static final String TOKEN_KEY = "token"; - public static final String TOKEN_KEY = "token"; + public static final String METHOD_KEY = "method"; - public static final String METHOD_KEY = "method"; + public static final String METHODS_KEY = "methods"; - public static final String METHODS_KEY = "methods"; + public static final String CHARSET_KEY = "charset"; - public static final String CHARSET_KEY = "charset"; + public static final String RECONNECT_KEY = "reconnect"; - public static final String RECONNECT_KEY = "reconnect"; + public static final String SEND_RECONNECT_KEY = "send.reconnect"; - public static final String SEND_RECONNECT_KEY = "send.reconnect"; + public static final int DEFAULT_RECONNECT_PERIOD = 2000; - public static final int DEFAULT_RECONNECT_PERIOD = 2000; + public static final String SHUTDOWN_TIMEOUT_KEY = "shutdown.timeout"; - public static final String SHUTDOWN_TIMEOUT_KEY = "shutdown.timeout"; + public static final int DEFAULT_SHUTDOWN_TIMEOUT = 1000 * 60 * 15; - public static final int DEFAULT_SHUTDOWN_TIMEOUT = 1000 * 60 * 15; + public static final String PID_KEY = "pid"; - public static final String PID_KEY = "pid"; + public static final String TIMESTAMP_KEY = "timestamp"; - public static final String TIMESTAMP_KEY = "timestamp"; - - public static final String WARMUP_KEY = "warmup"; + public static final String WARMUP_KEY = "warmup"; - public static final int DEFAULT_WARMUP = 10 * 60 * 1000; + public static final int DEFAULT_WARMUP = 10 * 60 * 1000; - public static final String CHECK_KEY = "check"; + public static final String CHECK_KEY = "check"; - public static final String REGISTER_KEY = "register"; + public static final String REGISTER_KEY = "register"; - public static final String SUBSCRIBE_KEY = "subscribe"; + public static final String SUBSCRIBE_KEY = "subscribe"; - public static final String GROUP_KEY = "group"; + public static final String GROUP_KEY = "group"; - public static final String PATH_KEY = "path"; + public static final String PATH_KEY = "path"; - public static final String INTERFACE_KEY = "interface"; + public static final String INTERFACE_KEY = "interface"; - public static final String GENERIC_KEY = "generic"; + public static final String GENERIC_KEY = "generic"; - public static final String FILE_KEY = "file"; + public static final String FILE_KEY = "file"; - public static final String WAIT_KEY = "wait"; + public static final String WAIT_KEY = "wait"; - public static final String CLASSIFIER_KEY = "classifier"; + public static final String CLASSIFIER_KEY = "classifier"; - public static final String VERSION_KEY = "version"; + public static final String VERSION_KEY = "version"; - public static final String REVISION_KEY = "revision"; + public static final String REVISION_KEY = "revision"; - public static final String DUBBO_VERSION_KEY = "dubbo"; + public static final String DUBBO_VERSION_KEY = "dubbo"; - public static final String HESSIAN_VERSION_KEY = "hessian.version"; + public static final String HESSIAN_VERSION_KEY = "hessian.version"; - public static final String DISPATCHER_KEY = "dispatcher"; + public static final String DISPATCHER_KEY = "dispatcher"; - public static final String CHANNEL_HANDLER_KEY = "channel.handler"; + public static final String CHANNEL_HANDLER_KEY = "channel.handler"; - public static final String DEFAULT_CHANNEL_HANDLER = "default"; + public static final String DEFAULT_CHANNEL_HANDLER = "default"; - public static final String ANY_VALUE = "*"; + public static final String ANY_VALUE = "*"; - public static final String COMMA_SEPARATOR = ","; + public static final String COMMA_SEPARATOR = ","; - public static final Pattern COMMA_SPLIT_PATTERN = Pattern - .compile("\\s*[,]+\\s*"); + public static final Pattern COMMA_SPLIT_PATTERN = Pattern + .compile("\\s*[,]+\\s*"); - public final static String PATH_SEPARATOR = "/"; + public final static String PATH_SEPARATOR = "/"; - public static final String REGISTRY_SEPARATOR = "|"; + public static final String REGISTRY_SEPARATOR = "|"; - public static final Pattern REGISTRY_SPLIT_PATTERN = Pattern - .compile("\\s*[|;]+\\s*"); + public static final Pattern REGISTRY_SPLIT_PATTERN = Pattern + .compile("\\s*[|;]+\\s*"); - public static final String SEMICOLON_SEPARATOR = ";"; + public static final String SEMICOLON_SEPARATOR = ";"; - public static final Pattern SEMICOLON_SPLIT_PATTERN = Pattern - .compile("\\s*[;]+\\s*"); + public static final Pattern SEMICOLON_SPLIT_PATTERN = Pattern + .compile("\\s*[;]+\\s*"); - public static final String CONNECT_QUEUE_CAPACITY = "connect.queue.capacity"; + public static final String CONNECT_QUEUE_CAPACITY = "connect.queue.capacity"; - public static final String CONNECT_QUEUE_WARNING_SIZE = "connect.queue.warning.size"; + public static final String CONNECT_QUEUE_WARNING_SIZE = "connect.queue.warning.size"; - public static final int DEFAULT_CONNECT_QUEUE_WARNING_SIZE = 1000; + public static final int DEFAULT_CONNECT_QUEUE_WARNING_SIZE = 1000; - public static final String CHANNEL_ATTRIBUTE_READONLY_KEY = "channel.readonly"; + public static final String CHANNEL_ATTRIBUTE_READONLY_KEY = "channel.readonly"; - public static final String CHANNEL_READONLYEVENT_SENT_KEY = "channel.readonly.sent"; + public static final String CHANNEL_READONLYEVENT_SENT_KEY = "channel.readonly.sent"; - public static final String CHANNEL_SEND_READONLYEVENT_KEY = "channel.readonly.send"; + public static final String CHANNEL_SEND_READONLYEVENT_KEY = "channel.readonly.send"; - public static final String COUNT_PROTOCOL = "count"; + public static final String COUNT_PROTOCOL = "count"; - public static final String TRACE_PROTOCOL = "trace"; + public static final String TRACE_PROTOCOL = "trace"; - public static final String EMPTY_PROTOCOL = "empty"; + public static final String EMPTY_PROTOCOL = "empty"; - public static final String ADMIN_PROTOCOL = "admin"; + public static final String ADMIN_PROTOCOL = "admin"; - public static final String PROVIDER_PROTOCOL = "provider"; + public static final String PROVIDER_PROTOCOL = "provider"; - public static final String CONSUMER_PROTOCOL = "consumer"; + public static final String CONSUMER_PROTOCOL = "consumer"; - public static final String ROUTE_PROTOCOL = "route"; + public static final String ROUTE_PROTOCOL = "route"; - public static final String SCRIPT_PROTOCOL = "script"; + public static final String SCRIPT_PROTOCOL = "script"; - public static final String CONDITION_PROTOCOL = "condition"; + public static final String CONDITION_PROTOCOL = "condition"; - public static final String MOCK_PROTOCOL = "mock"; + public static final String MOCK_PROTOCOL = "mock"; - public static final String RETURN_PREFIX = "return "; + public static final String RETURN_PREFIX = "return "; - public static final String THROW_PREFIX = "throw"; + public static final String THROW_PREFIX = "throw"; - public static final String FAIL_PREFIX = "fail:"; + public static final String FAIL_PREFIX = "fail:"; - public static final String FORCE_PREFIX = "force:"; + public static final String FORCE_PREFIX = "force:"; - public static final String FORCE_KEY = "force"; + public static final String FORCE_KEY = "force"; - public static final String MERGER_KEY = "merger"; + public static final String MERGER_KEY = "merger"; /** * 集群时是否排除非available的invoker */ - public static final String CLUSTER_AVAILABLE_CHECK_KEY = "cluster.availablecheck"; + public static final String CLUSTER_AVAILABLE_CHECK_KEY = "cluster.availablecheck"; /** */ - public static final boolean DEFAULT_CLUSTER_AVAILABLE_CHECK = true; + public static final boolean DEFAULT_CLUSTER_AVAILABLE_CHECK = true; /** * 集群时是否启用sticky策略 */ - public static final String CLUSTER_STICKY_KEY = "sticky"; + public static final String CLUSTER_STICKY_KEY = "sticky"; /** * sticky默认值. */ - public static final boolean DEFAULT_CLUSTER_STICKY = false; + public static final boolean DEFAULT_CLUSTER_STICKY = false; /** * 创建client时,是否先要建立连接。 */ - public static final String LAZY_CONNECT_KEY = "lazy"; + public static final String LAZY_CONNECT_KEY = "lazy"; /** * lazy连接的初始状态是连接状态还是非连接状态? */ - public static final String LAZY_CONNECT_INITIAL_STATE_KEY = "connect.lazy.initial.state"; + public static final String LAZY_CONNECT_INITIAL_STATE_KEY = "connect.lazy.initial.state"; /** * lazy连接的初始状态默认是连接状态. @@ -448,153 +448,153 @@ public class Constants { /** * 注册中心是否同步存储文件,默认异步 */ - public static final String REGISTRY_FILESAVE_SYNC_KEY = "save.file"; + public static final String REGISTRY_FILESAVE_SYNC_KEY = "save.file"; /** * 注册中心失败事件重试事件 */ - public static final String REGISTRY_RETRY_PERIOD_KEY = "retry.period"; + public static final String REGISTRY_RETRY_PERIOD_KEY = "retry.period"; /** * 重试周期 */ - public static final int DEFAULT_REGISTRY_RETRY_PERIOD = 5 * 1000; - + public static final int DEFAULT_REGISTRY_RETRY_PERIOD = 5 * 1000; + /** * 注册中心自动重连时间 */ - public static final String REGISTRY_RECONNECT_PERIOD_KEY = "reconnect.period"; + public static final String REGISTRY_RECONNECT_PERIOD_KEY = "reconnect.period"; + + public static final int DEFAULT_REGISTRY_RECONNECT_PERIOD = 3 * 1000; - public static final int DEFAULT_REGISTRY_RECONNECT_PERIOD = 3 * 1000; - - public static final String SESSION_TIMEOUT_KEY = "session"; + public static final String SESSION_TIMEOUT_KEY = "session"; - public static final int DEFAULT_SESSION_TIMEOUT = 60 * 1000; + public static final int DEFAULT_SESSION_TIMEOUT = 60 * 1000; /** * 注册中心导出URL参数的KEY */ - public static final String EXPORT_KEY = "export"; + public static final String EXPORT_KEY = "export"; /** * 注册中心引用URL参数的KEY */ - public static final String REFER_KEY = "refer"; + public static final String REFER_KEY = "refer"; /** * callback inst id */ - public static final String CALLBACK_SERVICE_KEY = "callback.service.instid"; + public static final String CALLBACK_SERVICE_KEY = "callback.service.instid"; /** * 每个客户端同一个接口 callback服务实例的限制 */ - public static final String CALLBACK_INSTANCES_LIMIT_KEY = "callbacks"; + public static final String CALLBACK_INSTANCES_LIMIT_KEY = "callbacks"; /** * 每个客户端同一个接口 callback服务实例的限制 */ - public static final int DEFAULT_CALLBACK_INSTANCES = 1; + public static final int DEFAULT_CALLBACK_INSTANCES = 1; - public static final String CALLBACK_SERVICE_PROXY_KEY = "callback.service.proxy"; + public static final String CALLBACK_SERVICE_PROXY_KEY = "callback.service.proxy"; - public static final String IS_CALLBACK_SERVICE = "is_callback_service"; + public static final String IS_CALLBACK_SERVICE = "is_callback_service"; /** * channel中callback的invokers */ - public static final String CHANNEL_CALLBACK_KEY = "channel.callback.invokers.key"; + public static final String CHANNEL_CALLBACK_KEY = "channel.callback.invokers.key"; @Deprecated - public static final String SHUTDOWN_WAIT_SECONDS_KEY = "dubbo.service.shutdown.wait.seconds"; + public static final String SHUTDOWN_WAIT_SECONDS_KEY = "dubbo.service.shutdown.wait.seconds"; - public static final String SHUTDOWN_WAIT_KEY = "dubbo.service.shutdown.wait"; + public static final String SHUTDOWN_WAIT_KEY = "dubbo.service.shutdown.wait"; - public static final String IS_SERVER_KEY = "isserver"; + public static final String IS_SERVER_KEY = "isserver"; /** * 默认值毫秒,避免重新计算. */ - public static final int DEFAULT_SERVER_SHUTDOWN_TIMEOUT = 10000; + public static final int DEFAULT_SERVER_SHUTDOWN_TIMEOUT = 10000; - public static final String ON_CONNECT_KEY = "onconnect"; + public static final String ON_CONNECT_KEY = "onconnect"; - public static final String ON_DISCONNECT_KEY = "ondisconnect"; + public static final String ON_DISCONNECT_KEY = "ondisconnect"; - public static final String ON_INVOKE_METHOD_KEY = "oninvoke.method"; + public static final String ON_INVOKE_METHOD_KEY = "oninvoke.method"; - public static final String ON_RETURN_METHOD_KEY = "onreturn.method"; + public static final String ON_RETURN_METHOD_KEY = "onreturn.method"; - public static final String ON_THROW_METHOD_KEY = "onthrow.method"; + public static final String ON_THROW_METHOD_KEY = "onthrow.method"; - public static final String ON_INVOKE_INSTANCE_KEY = "oninvoke.instance"; + public static final String ON_INVOKE_INSTANCE_KEY = "oninvoke.instance"; - public static final String ON_RETURN_INSTANCE_KEY = "onreturn.instance"; + public static final String ON_RETURN_INSTANCE_KEY = "onreturn.instance"; - public static final String ON_THROW_INSTANCE_KEY = "onthrow.instance"; + public static final String ON_THROW_INSTANCE_KEY = "onthrow.instance"; - public static final String OVERRIDE_PROTOCOL = "override"; + public static final String OVERRIDE_PROTOCOL = "override"; - public static final String PRIORITY_KEY = "priority"; - - public static final String RULE_KEY = "rule"; + public static final String PRIORITY_KEY = "priority"; - public static final String TYPE_KEY = "type"; + public static final String RULE_KEY = "rule"; - public static final String RUNTIME_KEY = "runtime"; + public static final String TYPE_KEY = "type"; + + public static final String RUNTIME_KEY = "runtime"; // when ROUTER_KEY's value is set to ROUTER_TYPE_CLEAR, RegistryDirectory will clean all current routers - public static final String ROUTER_TYPE_CLEAR = "clean"; + public static final String ROUTER_TYPE_CLEAR = "clean"; - public static final String DEFAULT_SCRIPT_TYPE_KEY = "javascript"; + public static final String DEFAULT_SCRIPT_TYPE_KEY = "javascript"; - public static final String STUB_EVENT_KEY = "dubbo.stub.event"; + public static final String STUB_EVENT_KEY = "dubbo.stub.event"; - public static final boolean DEFAULT_STUB_EVENT = false; + public static final boolean DEFAULT_STUB_EVENT = false; - public static final String STUB_EVENT_METHODS_KEY = "dubbo.stub.event.methods"; + public static final String STUB_EVENT_METHODS_KEY = "dubbo.stub.event.methods"; //invocation attachment属性中如果有此值,则选择mock invoker - public static final String INVOCATION_NEED_MOCK = "invocation.need.mock"; + public static final String INVOCATION_NEED_MOCK = "invocation.need.mock"; - public static final String LOCAL_PROTOCOL = "injvm"; + public static final String LOCAL_PROTOCOL = "injvm"; - public static final String AUTO_ATTACH_INVOCATIONID_KEY = "invocationid.autoattach"; - - public static final String SCOPE_KEY = "scope"; - - public static final String SCOPE_LOCAL = "local"; - - public static final String SCOPE_REMOTE = "remote"; - - public static final String SCOPE_NONE = "none"; - - public static final String RELIABLE_PROTOCOL = "napoli"; - - public static final String TPS_LIMIT_RATE_KEY = "tps"; + public static final String AUTO_ATTACH_INVOCATIONID_KEY = "invocationid.autoattach"; - public static final String TPS_LIMIT_INTERVAL_KEY = "tps.interval"; + public static final String SCOPE_KEY = "scope"; - public static final long DEFAULT_TPS_LIMIT_INTERVAL = 60 * 1000; + public static final String SCOPE_LOCAL = "local"; - public static final String DECODE_IN_IO_THREAD_KEY = "decode.in.io"; + public static final String SCOPE_REMOTE = "remote"; - public static final boolean DEFAULT_DECODE_IN_IO_THREAD = true; - - public static final String INPUT_KEY = "input"; - - public static final String OUTPUT_KEY = "output"; + public static final String SCOPE_NONE = "none"; - public static final String EXECUTOR_SERVICE_COMPONENT_KEY = ExecutorService.class.getName(); + public static final String RELIABLE_PROTOCOL = "napoli"; - public static final String GENERIC_SERIALIZATION_NATIVE_JAVA = "nativejava"; + public static final String TPS_LIMIT_RATE_KEY = "tps"; - public static final String GENERIC_SERIALIZATION_DEFAULT = "true"; + public static final String TPS_LIMIT_INTERVAL_KEY = "tps.interval"; - public static final String GENERIC_SERIALIZATION_BEAN = "bean"; + public static final long DEFAULT_TPS_LIMIT_INTERVAL = 60 * 1000; - /* - * private Constants(){ } - */ + public static final String DECODE_IN_IO_THREAD_KEY = "decode.in.io"; + + public static final boolean DEFAULT_DECODE_IN_IO_THREAD = true; + + public static final String INPUT_KEY = "input"; + + public static final String OUTPUT_KEY = "output"; + + public static final String EXECUTOR_SERVICE_COMPONENT_KEY = ExecutorService.class.getName(); + + public static final String GENERIC_SERIALIZATION_NATIVE_JAVA = "nativejava"; + + public static final String GENERIC_SERIALIZATION_DEFAULT = "true"; + + public static final String GENERIC_SERIALIZATION_BEAN = "bean"; + + //--------------------------------tracker-------------------------------------------------------// + + public static final String TRACKER_KEY = "tracker"; } diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/URL.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/URL.java index 6a275e314c8..b2a531d22c5 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/URL.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/URL.java @@ -15,29 +15,22 @@ */ package com.alibaba.dubbo.common; +import com.alibaba.dubbo.common.utils.CollectionUtils; +import com.alibaba.dubbo.common.utils.NetUtils; +import com.alibaba.dubbo.common.utils.StringUtils; + import java.io.Serializable; import java.io.UnsupportedEncodingException; import java.net.InetSocketAddress; import java.net.MalformedURLException; import java.net.URLDecoder; import java.net.URLEncoder; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.Collection; -import java.util.Collections; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.TreeMap; +import java.util.*; import java.util.concurrent.ConcurrentHashMap; -import com.alibaba.dubbo.common.utils.CollectionUtils; -import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.common.utils.StringUtils; - /** * URL - Uniform Resource Locator (Immutable, ThreadSafe) - *

+ *

* url example: *

    *
  • http://www.facebook.com/friends?param1=value1&param2=value2 @@ -45,7 +38,7 @@ *
  • ftp://username:password@192.168.1.7:21/1/read.txt *
  • registry://192.168.1.7:9090/com.alibaba.service1?param1=value1&param2=value2 *
- *

+ *

* Some strange example below: *

    *
  • 192.168.1.3:20880
    @@ -57,13 +50,13 @@ *
  • file:///D:/1/router.js?type=script
    * for this case, url protocol = file, url host = null, url path = D:/1/router.js *
  • file:/D:/1/router.js?type=script
    - * same as above file:///D:/1/router.js?type=script + * same as above file:///D:/1/router.js?type=script *
  • /home/user1/router.js?type=script
    * for this case, url protocol = null, url host = null, url path = home/user1/router.js *
  • home/user1/router.js?type=script
    * for this case, url protocol = null, url host = home, url path = user1/router.js *
- * + * * @author william.liangf * @author ding.lid * @see java.net.URL @@ -75,20 +68,20 @@ public final class URL implements Serializable { private final String protocol; - private final String username; + private final String username; - private final String password; + private final String password; - private final String host; + private final String host; - private final int port; + private final int port; - private final String path; + private final String path; private final Map parameters; - + // ==== cache ==== - + private volatile transient Map numbers; private volatile transient Map urls; @@ -98,11 +91,11 @@ public final class URL implements Serializable { private volatile transient String full; private volatile transient String identity; - + private volatile transient String parameter; private volatile transient String string; - + protected URL() { this.protocol = null; this.username = null; @@ -112,65 +105,65 @@ protected URL() { this.path = null; this.parameters = null; } - - public URL(String protocol, String host, int port) { - this(protocol, null, null, host, port, null, (Map) null); - } - - public URL(String protocol, String host, int port, String[] pairs) { // 变长参数...与下面的path参数冲突,改为数组 + + public URL(String protocol, String host, int port) { + this(protocol, null, null, host, port, null, (Map) null); + } + + public URL(String protocol, String host, int port, String[] pairs) { // 变长参数...与下面的path参数冲突,改为数组 this(protocol, null, null, host, port, null, CollectionUtils.toStringMap(pairs)); } - - public URL(String protocol, String host, int port, Map parameters) { + + public URL(String protocol, String host, int port, Map parameters) { this(protocol, null, null, host, port, null, parameters); } - - public URL(String protocol, String host, int port, String path) { - this(protocol, null, null, host, port, path, (Map) null); - } - public URL(String protocol, String host, int port, String path, String... pairs) { + public URL(String protocol, String host, int port, String path) { + this(protocol, null, null, host, port, path, (Map) null); + } + + public URL(String protocol, String host, int port, String path, String... pairs) { this(protocol, null, null, host, port, path, CollectionUtils.toStringMap(pairs)); } - - public URL(String protocol, String host, int port, String path, Map parameters) { - this(protocol, null, null, host, port, path, parameters); - } - - public URL(String protocol, String username, String password, String host, int port, String path) { + + public URL(String protocol, String host, int port, String path, Map parameters) { + this(protocol, null, null, host, port, path, parameters); + } + + public URL(String protocol, String username, String password, String host, int port, String path) { this(protocol, username, password, host, port, path, (Map) null); } - - public URL(String protocol, String username, String password, String host, int port, String path, String... pairs) { - this(protocol, username, password, host, port, path, CollectionUtils.toStringMap(pairs)); - } - - public URL(String protocol, String username, String password, String host, int port, String path, Map parameters) { - if ((username == null || username.length() == 0) - && password != null && password.length() > 0) { - throw new IllegalArgumentException("Invalid url, password without username!"); - } - this.protocol = protocol; - this.username = username; - this.password = password; - this.host = host; - this.port = (port < 0 ? 0 : port); - this.path = path; - // trim the beginning "/" - while(path != null && path.startsWith("/")) { - path = path.substring(1); - } - if (parameters == null) { - parameters = new HashMap(); - } else { - parameters = new HashMap(parameters); - } - this.parameters = Collections.unmodifiableMap(parameters); - } + + public URL(String protocol, String username, String password, String host, int port, String path, String... pairs) { + this(protocol, username, password, host, port, path, CollectionUtils.toStringMap(pairs)); + } + + public URL(String protocol, String username, String password, String host, int port, String path, Map parameters) { + if ((username == null || username.length() == 0) + && password != null && password.length() > 0) { + throw new IllegalArgumentException("Invalid url, password without username!"); + } + this.protocol = protocol; + this.username = username; + this.password = password; + this.host = host; + this.port = (port < 0 ? 0 : port); + this.path = path; + // trim the beginning "/" + while (path != null && path.startsWith("/")) { + path = path.substring(1); + } + if (parameters == null) { + parameters = new HashMap(); + } else { + parameters = new HashMap(parameters); + } + this.parameters = Collections.unmodifiableMap(parameters); + } /** * Parse url string - * + * * @param url URL string * @return URL instance * @see URL @@ -205,20 +198,19 @@ public static URL valueOf(String url) { } i = url.indexOf("://"); if (i >= 0) { - if(i == 0) throw new IllegalStateException("url missing protocol: \"" + url + "\""); + if (i == 0) throw new IllegalStateException("url missing protocol: \"" + url + "\""); protocol = url.substring(0, i); url = url.substring(i + 3); - } - else { + } else { // case: file:/path/to/file.txt i = url.indexOf(":/"); - if(i>=0) { - if(i == 0) throw new IllegalStateException("url missing protocol: \"" + url + "\""); + if (i >= 0) { + if (i == 0) throw new IllegalStateException("url missing protocol: \"" + url + "\""); protocol = url.substring(0, i); url = url.substring(i + 1); } } - + i = url.indexOf("/"); if (i >= 0) { path = url.substring(i + 1); @@ -239,71 +231,71 @@ public static URL valueOf(String url) { port = Integer.parseInt(url.substring(i + 1)); url = url.substring(0, i); } - if(url.length() > 0) host = url; + if (url.length() > 0) host = url; return new URL(protocol, username, password, host, port, path, parameters); } - public String getProtocol() { - return protocol; - } - - public String getUsername() { - return username; - } - - public String getPassword() { - return password; - } - - public String getAuthority() { - if ((username == null || username.length() == 0) - && (password == null || password.length() == 0)) { - return null; - } - return (username == null ? "" : username) - + ":" + (password == null ? "" : password); - } - - public String getHost() { - return host; - } - - /** - * 获取IP地址. - * - * 请注意: - * 如果和Socket的地址对比, - * 或用地址作为Map的Key查找, - * 请使用IP而不是Host, - * 否则配置域名会有问题 - * - * @return ip - */ - public String getIp() { - if (ip == null) { - ip = NetUtils.getIpByHost(host); - } - return ip; - } - - public int getPort() { - return port; - } + public String getProtocol() { + return protocol; + } + + public String getUsername() { + return username; + } + + public String getPassword() { + return password; + } + + public String getAuthority() { + if ((username == null || username.length() == 0) + && (password == null || password.length() == 0)) { + return null; + } + return (username == null ? "" : username) + + ":" + (password == null ? "" : password); + } + + public String getHost() { + return host; + } + + /** + * 获取IP地址. + *

+ * 请注意: + * 如果和Socket的地址对比, + * 或用地址作为Map的Key查找, + * 请使用IP而不是Host, + * 否则配置域名会有问题 + * + * @return ip + */ + public String getIp() { + if (ip == null) { + ip = NetUtils.getIpByHost(host); + } + return ip; + } + + public int getPort() { + return port; + } public int getPort(int defaultPort) { return port <= 0 ? defaultPort : port; } - public String getAddress() { - return port <= 0 ? host : host + ":" + port; - } - - public String getBackupAddress() { - return getBackupAddress(0); - } - - public String getBackupAddress(int defaultPort) { - StringBuilder address = new StringBuilder(appendDefaultPort(getAddress(), defaultPort)); + public String getAddress() { + return port <= 0 ? host : host + ":" + port; + } + + public String getBackupAddress() { + return getBackupAddress(0); + } + + public String getBackupAddress(int defaultPort) { + StringBuilder address = new StringBuilder(appendDefaultPort(getAddress(), defaultPort)); String[] backups = getParameter(Constants.BACKUP_KEY, new String[0]); if (backups != null && backups.length > 0) { for (String backup : backups) { @@ -312,11 +304,11 @@ public String getBackupAddress(int defaultPort) { } } return address.toString(); - } - - public List getBackupUrls() { - List urls = new ArrayList(); - urls.add(this); + } + + public List getBackupUrls() { + List urls = new ArrayList(); + urls.add(this); String[] backups = getParameter(Constants.BACKUP_KEY, new String[0]); if (backups != null && backups.length > 0) { for (String backup : backups) { @@ -324,11 +316,11 @@ public List getBackupUrls() { } } return urls; - } + } private String appendDefaultPort(String address, int defaultPort) { if (address != null && address.length() > 0 - && defaultPort > 0) { + && defaultPort > 0) { int i = address.indexOf(':'); if (i < 0) { return address + ":" + defaultPort; @@ -339,20 +331,20 @@ private String appendDefaultPort(String address, int defaultPort) { return address; } - public String getPath() { - return path; - } - - public String getAbsolutePath() { + public String getPath() { + return path; + } + + public String getAbsolutePath() { if (path != null && !path.startsWith("/")) { return "/" + path; } return path; - } - - public URL setProtocol(String protocol) { - return new URL(protocol, username, password, host, port, path, getParameters()); - } + } + + public URL setProtocol(String protocol) { + return new URL(protocol, username, password, host, port, path, getParameters()); + } public URL setUsername(String username) { return new URL(protocol, username, password, host, port, path, getParameters()); @@ -361,7 +353,7 @@ public URL setUsername(String username) { public URL setPassword(String password) { return new URL(protocol, username, password, host, port, path, getParameters()); } - + public URL setAddress(String address) { int i = address.lastIndexOf(':'); String host; @@ -394,7 +386,7 @@ public Map getParameters() { public String getParameterAndDecoded(String key) { return getParameterAndDecoded(key, null); } - + public String getParameterAndDecoded(String key, String defaultValue) { return decode(getParameter(key, defaultValue)); } @@ -422,7 +414,7 @@ public String[] getParameter(String key, String[] defaultValue) { } return Constants.COMMA_SPLIT_PATTERN.split(value); } - + private Map getNumbers() { if (numbers == null) { // 允许并发重复创建 numbers = new ConcurrentHashMap(); @@ -464,7 +456,7 @@ public double getParameter(String key, double defaultValue) { getNumbers().put(key, d); return d; } - + public float getParameter(String key, float defaultValue) { Number n = getNumbers().get(key); if (n != null) { @@ -768,7 +760,7 @@ public long getMethodPositiveParameter(String method, String key, long defaultVa } return value; } - + public int getMethodPositiveParameter(String method, String key, int defaultValue) { if (defaultValue <= 0) { throw new IllegalArgumentException("defaultValue <= 0"); @@ -840,22 +832,22 @@ public boolean hasMethodParameter(String method, String key) { String value = getMethodParameter(method, key); return value != null && value.length() > 0; } - + public boolean isLocalHost() { return NetUtils.isLocalHost(host) || getParameter(Constants.LOCALHOST_KEY, false); } - + public boolean isAnyHost() { return Constants.ANYHOST_VALUE.equals(host) || getParameter(Constants.ANYHOST_KEY, false); } - + public URL addParameterAndEncoded(String key, String value) { - if(value == null || value.length() == 0) { + if (value == null || value.length() == 0) { return this; } return addParameter(key, encode(value)); } - + public URL addParameter(String key, boolean value) { return addParameter(key, String.valueOf(value)); } @@ -867,15 +859,15 @@ public URL addParameter(String key, char value) { public URL addParameter(String key, byte value) { return addParameter(key, String.valueOf(value)); } - + public URL addParameter(String key, short value) { return addParameter(key, String.valueOf(value)); } - + public URL addParameter(String key, int value) { return addParameter(key, String.valueOf(value)); } - + public URL addParameter(String key, long value) { return addParameter(key, String.valueOf(value)); } @@ -883,33 +875,33 @@ public URL addParameter(String key, long value) { public URL addParameter(String key, float value) { return addParameter(key, String.valueOf(value)); } - + public URL addParameter(String key, double value) { return addParameter(key, String.valueOf(value)); } - + public URL addParameter(String key, Enum value) { - if(value == null) return this; + if (value == null) return this; return addParameter(key, String.valueOf(value)); } - + public URL addParameter(String key, Number value) { - if(value == null) return this; + if (value == null) return this; return addParameter(key, String.valueOf(value)); } public URL addParameter(String key, CharSequence value) { - if(value == null || value.length() == 0) return this; + if (value == null || value.length() == 0) return this; return addParameter(key, String.valueOf(value)); } - + public URL addParameter(String key, String value) { if (key == null || key.length() == 0 || value == null || value.length() == 0) { return this; } // 如果没有修改,直接返回。 - if(value.equals(getParameters().get(key))) { // value != null + if (value.equals(getParameters().get(key))) { // value != null return this; } @@ -917,7 +909,7 @@ public URL addParameter(String key, String value) { map.put(key, value); return new URL(protocol, username, password, host, port, path, map); } - + public URL addParameterIfAbsent(String key, String value) { if (key == null || key.length() == 0 || value == null || value.length() == 0) { @@ -930,42 +922,42 @@ public URL addParameterIfAbsent(String key, String value) { map.put(key, value); return new URL(protocol, username, password, host, port, path, map); } - - /** - * Add parameters to a new url. - * - * @param parameters - * @return A new URL - */ + + /** + * Add parameters to a new url. + * + * @param parameters + * @return A new URL + */ public URL addParameters(Map parameters) { if (parameters == null || parameters.size() == 0) { return this; } boolean hasAndEqual = true; - for(Map.Entry entry : parameters.entrySet()) { + for (Map.Entry entry : parameters.entrySet()) { String value = getParameters().get(entry.getKey()); - if(value == null && entry.getValue() != null || !value.equals(entry.getValue())) { + if (!entry.getValue().equals(value)) { hasAndEqual = false; break; } } // 如果没有修改,直接返回。 - if(hasAndEqual) return this; + if (hasAndEqual) return this; Map map = new HashMap(getParameters()); map.putAll(parameters); return new URL(protocol, username, password, host, port, path, map); } - - public URL addParametersIfAbsent(Map parameters) { - if (parameters == null || parameters.size() == 0) { - return this; - } - Map map = new HashMap(parameters); - map.putAll(getParameters()); - return new URL(protocol, username, password, host, port, path, map); - } + + public URL addParametersIfAbsent(Map parameters) { + if (parameters == null || parameters.size() == 0) { + return this; + } + Map map = new HashMap(parameters); + map.putAll(getParameters()); + return new URL(protocol, username, password, host, port, path, map); + } public URL addParameters(String... pairs) { if (pairs == null || pairs.length == 0) { @@ -976,35 +968,35 @@ public URL addParameters(String... pairs) { } Map map = new HashMap(); int len = pairs.length / 2; - for (int i = 0; i < len; i ++) { + for (int i = 0; i < len; i++) { map.put(pairs[2 * i], pairs[2 * i + 1]); } return addParameters(map); } - + public URL addParameterString(String query) { if (query == null || query.length() == 0) { return this; } return addParameters(StringUtils.parseQueryString(query)); } - + public URL removeParameter(String key) { if (key == null || key.length() == 0) { return this; } return removeParameters(key); } - + public URL removeParameters(Collection keys) { if (keys == null || keys.size() == 0) { return this; } - return removeParameters(keys.toArray(new String[0])); + return removeParameters(keys.toArray(new String[keys.size()])); } - public URL removeParameters(String... keys) { - if (keys == null || keys.length == 0) { + public URL removeParameters(String... keys) { + if (keys == null || keys.length == 0) { return this; } Map map = new HashMap(getParameters()); @@ -1015,27 +1007,27 @@ public URL removeParameters(String... keys) { return this; } return new URL(protocol, username, password, host, port, path, map); - } - - public URL clearParameters() { + } + + public URL clearParameters() { return new URL(protocol, username, password, host, port, path, new HashMap()); } - - public String getRawParameter(String key) { - if ("protocol".equals(key)) + + public String getRawParameter(String key) { + if ("protocol".equals(key)) return protocol; - if ("username".equals(key)) + if ("username".equals(key)) return username; - if ("password".equals(key)) + if ("password".equals(key)) return password; - if ("host".equals(key)) + if ("host".equals(key)) return host; - if ("port".equals(key)) + if ("port".equals(key)) return String.valueOf(port); - if ("path".equals(key)) + if ("path".equals(key)) return path; return getParameter(key); - } + } public Map toMap() { Map map = new HashMap(parameters); @@ -1054,8 +1046,8 @@ public Map toMap() { return map; } - public String toString() { - if (string != null) { + public String toString() { + if (string != null) { return string; } return string = buildString(false, true); // no show username and password @@ -1064,44 +1056,44 @@ public String toString() { public String toString(String... parameters) { return buildString(false, true, parameters); // no show username and password } - + public String toIdentityString() { if (identity != null) { return identity; } return identity = buildString(true, false); // only return identity message, see the method "equals" and "hashCode" - } + } public String toIdentityString(String... parameters) { return buildString(true, false, parameters); // only return identity message, see the method "equals" and "hashCode" } - - public String toFullString() { - if (full != null) { - return full; - } - return full = buildString(true, true); - } + + public String toFullString() { + if (full != null) { + return full; + } + return full = buildString(true, true); + } public String toFullString(String... parameters) { return buildString(true, true, parameters); } - + public String toParameterString() { if (parameter != null) { return parameter; } return parameter = toParameterString(new String[0]); } - - public String toParameterString(String... parameters) { - StringBuilder buf = new StringBuilder(); - buildParameters(buf, false, parameters); - return buf.toString(); - } - - private void buildParameters(StringBuilder buf, boolean concat, String[] parameters) { - if (getParameters() !=null && getParameters().size() > 0) { + + public String toParameterString(String... parameters) { + StringBuilder buf = new StringBuilder(); + buildParameters(buf, false, parameters); + return buf.toString(); + } + + private void buildParameters(StringBuilder buf, boolean concat, String[] parameters) { + if (getParameters() != null && getParameters().size() > 0) { List includes = (parameters == null || parameters.length == 0 ? null : Arrays.asList(parameters)); boolean first = true; for (Map.Entry entry : new TreeMap(getParameters()).entrySet()) { @@ -1121,54 +1113,54 @@ private void buildParameters(StringBuilder buf, boolean concat, String[] paramet } } } - } - - private String buildString(boolean appendUser, boolean appendParameter, String... parameters) { - return buildString(appendUser, appendParameter, false, false, parameters); - } - - private String buildString(boolean appendUser, boolean appendParameter, boolean useIP, boolean useService, String... parameters) { - StringBuilder buf = new StringBuilder(); - if (protocol != null && protocol.length() > 0) { - buf.append(protocol); - buf.append("://"); - } - if (appendUser && username != null && username.length() > 0) { - buf.append(username); - if (password != null && password.length() > 0) { - buf.append(":"); - buf.append(password); - } - buf.append("@"); - } - String host; - if (useIP) { - host = getIp(); - } else { - host = getHost(); - } - if(host != null && host.length() > 0) { - buf.append(host); - if (port > 0) { - buf.append(":"); - buf.append(port); - } - } - String path; - if (useService) { - path = getServiceKey(); - } else { - path = getPath(); - } - if (path != null && path.length() > 0) { - buf.append("/"); - buf.append(path); - } - if (appendParameter) { - buildParameters(buf, true, parameters); - } - return buf.toString(); - } + } + + private String buildString(boolean appendUser, boolean appendParameter, String... parameters) { + return buildString(appendUser, appendParameter, false, false, parameters); + } + + private String buildString(boolean appendUser, boolean appendParameter, boolean useIP, boolean useService, String... parameters) { + StringBuilder buf = new StringBuilder(); + if (protocol != null && protocol.length() > 0) { + buf.append(protocol); + buf.append("://"); + } + if (appendUser && username != null && username.length() > 0) { + buf.append(username); + if (password != null && password.length() > 0) { + buf.append(":"); + buf.append(password); + } + buf.append("@"); + } + String host; + if (useIP) { + host = getIp(); + } else { + host = getHost(); + } + if (host != null && host.length() > 0) { + buf.append(host); + if (port > 0) { + buf.append(":"); + buf.append(port); + } + } + String path; + if (useService) { + path = getServiceKey(); + } else { + path = getPath(); + } + if (path != null && path.length() > 0) { + buf.append("/"); + buf.append(path); + } + if (appendParameter) { + buildParameters(buf, true, parameters); + } + return buf.toString(); + } public java.net.URL toJavaURL() { try { @@ -1199,7 +1191,7 @@ public String getServiceKey() { } public String toServiceString() { - return buildString(true, false, true, true); + return buildString(true, false, true, true); } @Deprecated @@ -1216,8 +1208,8 @@ public URL setServiceInterface(String service) { } /** - * @deprecated Replace to getParameter(String, int) * @see #getParameter(String, int) + * @deprecated Replace to getParameter(String, int) */ @Deprecated public int getIntParameter(String key) { @@ -1225,8 +1217,8 @@ public int getIntParameter(String key) { } /** - * @deprecated Replace to getParameter(String, int) * @see #getParameter(String, int) + * @deprecated Replace to getParameter(String, int) */ @Deprecated public int getIntParameter(String key, int defaultValue) { @@ -1234,8 +1226,8 @@ public int getIntParameter(String key, int defaultValue) { } /** - * @deprecated Replace to getPositiveParameter(String, int) * @see #getPositiveParameter(String, int) + * @deprecated Replace to getPositiveParameter(String, int) */ @Deprecated public int getPositiveIntParameter(String key, int defaultValue) { @@ -1243,8 +1235,8 @@ public int getPositiveIntParameter(String key, int defaultValue) { } /** - * @deprecated Replace to getParameter(String, boolean) * @see #getParameter(String, boolean) + * @deprecated Replace to getParameter(String, boolean) */ @Deprecated public boolean getBooleanParameter(String key) { @@ -1252,17 +1244,17 @@ public boolean getBooleanParameter(String key) { } /** - * @deprecated Replace to getParameter(String, boolean) * @see #getParameter(String, boolean) + * @deprecated Replace to getParameter(String, boolean) */ - @Deprecated - public boolean getBooleanParameter(String key, boolean defaultValue) { - return getParameter(key, defaultValue); - } + @Deprecated + public boolean getBooleanParameter(String key, boolean defaultValue) { + return getParameter(key, defaultValue); + } - /** - * @deprecated Replace to getMethodParameter(String, String, int) + /** * @see #getMethodParameter(String, String, int) + * @deprecated Replace to getMethodParameter(String, String, int) */ @Deprecated public int getMethodIntParameter(String method, String key) { @@ -1270,8 +1262,8 @@ public int getMethodIntParameter(String method, String key) { } /** - * @deprecated Replace to getMethodParameter(String, String, int) * @see #getMethodParameter(String, String, int) + * @deprecated Replace to getMethodParameter(String, String, int) */ @Deprecated public int getMethodIntParameter(String method, String key, int defaultValue) { @@ -1279,8 +1271,8 @@ public int getMethodIntParameter(String method, String key, int defaultValue) { } /** - * @deprecated Replace to getMethodPositiveParameter(String, String, int) * @see #getMethodPositiveParameter(String, String, int) + * @deprecated Replace to getMethodPositiveParameter(String, String, int) */ @Deprecated public int getMethodPositiveIntParameter(String method, String key, int defaultValue) { @@ -1288,8 +1280,8 @@ public int getMethodPositiveIntParameter(String method, String key, int defaultV } /** - * @deprecated Replace to getMethodParameter(String, String, boolean) * @see #getMethodParameter(String, String, boolean) + * @deprecated Replace to getMethodParameter(String, String, boolean) */ @Deprecated public boolean getMethodBooleanParameter(String method, String key) { @@ -1297,8 +1289,8 @@ public boolean getMethodBooleanParameter(String method, String key) { } /** - * @deprecated Replace to getMethodParameter(String, String, boolean) * @see #getMethodParameter(String, String, boolean) + * @deprecated Replace to getMethodParameter(String, String, boolean) */ @Deprecated public boolean getMethodBooleanParameter(String method, String key, boolean defaultValue) { @@ -1306,7 +1298,7 @@ public boolean getMethodBooleanParameter(String method, String key, boolean defa } public static String encode(String value) { - if (value == null || value.length() == 0) { + if (value == null || value.length() == 0) { return ""; } try { @@ -1315,9 +1307,9 @@ public static String encode(String value) { throw new RuntimeException(e.getMessage(), e); } } - + public static String decode(String value) { - if (value == null || value.length() == 0) { + if (value == null || value.length() == 0) { return ""; } try { diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/Version.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/Version.java index 80ee7a65249..4063a5f1272 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/Version.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/Version.java @@ -36,7 +36,7 @@ private Version() {} private static final Logger logger = LoggerFactory.getLogger(Version.class); - private static final String VERSION = getVersion(Version.class, "2.0.0"); + private static final String VERSION = getVersion(Version.class, "3.0.1"); private static final boolean INTERNAL = hasResource("com/alibaba/dubbo/registry/internal/RemoteRegistry.class"); diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/ClassGenerator.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/ClassGenerator.java index 84b78e50d01..860fd0b98a9 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/ClassGenerator.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/ClassGenerator.java @@ -15,377 +15,311 @@ */ package com.alibaba.dubbo.common.bytecode; +import com.alibaba.dubbo.common.utils.ReflectUtils; +import javassist.*; + import java.lang.reflect.Constructor; import java.lang.reflect.Method; import java.lang.reflect.Modifier; import java.security.ProtectionDomain; -import java.util.ArrayList; -import java.util.HashSet; -import java.util.LinkedList; -import java.util.List; -import java.util.Map; -import java.util.Set; +import java.util.*; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.atomic.AtomicLong; -import javassist.CannotCompileException; -import javassist.ClassPool; -import javassist.CtClass; -import javassist.CtConstructor; -import javassist.CtField; -import javassist.CtMethod; -import javassist.CtNewConstructor; -import javassist.CtNewMethod; -import javassist.LoaderClassPath; -import javassist.NotFoundException; - -import com.alibaba.dubbo.common.utils.ReflectUtils; - /** * ClassGenerator - * + * * @author qian.lei */ -public final class ClassGenerator -{ - public static interface DC{} // dynamic class tag interface. +public final class ClassGenerator { + public static interface DC { + } // dynamic class tag interface. + + private static final AtomicLong CLASS_NAME_COUNTER = new AtomicLong(0); + + private static final String SIMPLE_NAME_TAG = ""; + + private static final Map POOL_MAP = new ConcurrentHashMap(); //ClassLoader - ClassPool + + public static ClassGenerator newInstance() { + return new ClassGenerator(getClassPool(Thread.currentThread().getContextClassLoader())); + } - private static final AtomicLong CLASS_NAME_COUNTER = new AtomicLong(0); + public static ClassGenerator newInstance(ClassLoader loader) { + return new ClassGenerator(getClassPool(loader)); + } - private static final String SIMPLE_NAME_TAG = ""; + public static boolean isDynamicClass(Class cl) { + return ClassGenerator.DC.class.isAssignableFrom(cl); + } - private static final Map POOL_MAP = new ConcurrentHashMap(); //ClassLoader - ClassPool + public static ClassPool getClassPool(ClassLoader loader) { + if (loader == null) + return ClassPool.getDefault(); - public static ClassGenerator newInstance() - { - return new ClassGenerator(getClassPool(Thread.currentThread().getContextClassLoader())); - } - - public static ClassGenerator newInstance(ClassLoader loader) - { - return new ClassGenerator(getClassPool(loader)); - } - - public static boolean isDynamicClass(Class cl) - { - return ClassGenerator.DC.class.isAssignableFrom(cl); - } - - public static ClassPool getClassPool(ClassLoader loader) - { - if( loader == null ) - return ClassPool.getDefault(); - - ClassPool pool = POOL_MAP.get(loader); - if( pool == null ) - { - pool = new ClassPool(true); - pool.appendClassPath(new LoaderClassPath(loader)); - POOL_MAP.put(loader, pool); - } - return pool; - } - - private ClassPool mPool; - - private CtClass mCtc; - - private String mClassName, mSuperClass; - - private Set mInterfaces; - - private List mFields, mConstructors, mMethods; - - private Map mCopyMethods; // - - private Map> mCopyConstructors; // - - private boolean mDefaultConstructor = false; - - private ClassGenerator(){} - - private ClassGenerator(ClassPool pool) - { - mPool = pool; - } - - public String getClassName() - { - return mClassName; - } - - public ClassGenerator setClassName(String name) - { - mClassName = name; - return this; - } - - public ClassGenerator addInterface(String cn) - { - if( mInterfaces == null ) - mInterfaces = new HashSet(); - mInterfaces.add(cn); - return this; - } - - public ClassGenerator addInterface(Class cl) - { - return addInterface(cl.getName()); - } - - public ClassGenerator setSuperClass(String cn) - { - mSuperClass = cn; - return this; - } - - public ClassGenerator setSuperClass(Class cl) - { - mSuperClass = cl.getName(); - return this; - } - - public ClassGenerator addField(String code) - { - if( mFields == null ) - mFields = new ArrayList(); - mFields.add(code); - return this; - } - - public ClassGenerator addField(String name, int mod, Class type) - { - return addField(name, mod, type, null); - } - - public ClassGenerator addField(String name, int mod, Class type, String def) - { - StringBuilder sb = new StringBuilder(); - sb.append(modifier(mod)).append(' ').append(ReflectUtils.getName(type)).append(' '); - sb.append(name); - if( def != null && def.length() > 0 ) - { - sb.append('='); - sb.append(def); - } - sb.append(';'); - return addField(sb.toString()); - } - - public ClassGenerator addMethod(String code) - { - if( mMethods == null ) - mMethods = new ArrayList(); - mMethods.add(code); - return this; - } - - public ClassGenerator addMethod(String name, int mod, Class rt, Class[] pts, String body) - { - return addMethod(name, mod, rt, pts, null, body); - } - - public ClassGenerator addMethod(String name, int mod, Class rt, Class[] pts, Class[] ets, String body) - { - StringBuilder sb = new StringBuilder(); - sb.append(modifier(mod)).append(' ').append(ReflectUtils.getName(rt)).append(' ').append(name); - sb.append('('); - for(int i=0;i 0 ) - sb.append(','); - sb.append(ReflectUtils.getName(pts[i])); - sb.append(" arg").append(i); - } - sb.append(')'); - if( ets != null && ets.length > 0 ) - { - sb.append(" throws "); - for(int i=0;i 0 ) - sb.append(','); - sb.append(ReflectUtils.getName(ets[i])); - } - } - sb.append('{').append(body).append('}'); - return addMethod(sb.toString()); - } - - public ClassGenerator addMethod(Method m) - { - addMethod(m.getName(), m); - return this; - } - - public ClassGenerator addMethod(String name, Method m) - { - String desc = name + ReflectUtils.getDescWithoutMethodName(m); - addMethod(':' + desc); - if( mCopyMethods == null ) - mCopyMethods = new ConcurrentHashMap(8); - mCopyMethods.put(desc, m); - return this; - } - - public ClassGenerator addConstructor(String code) - { - if( mConstructors == null ) - mConstructors = new LinkedList(); - mConstructors.add(code); - return this; - } - - public ClassGenerator addConstructor(int mod, Class[] pts, String body) - { - return addConstructor(mod, pts, null, body); - } - - public ClassGenerator addConstructor(int mod, Class[] pts, Class[] ets, String body) - { - StringBuilder sb = new StringBuilder(); - sb.append(modifier(mod)).append(' ').append(SIMPLE_NAME_TAG); - sb.append('('); - for(int i=0;i 0 ) - sb.append(','); - sb.append(ReflectUtils.getName(pts[i])); - sb.append(" arg").append(i); - } - sb.append(')'); - if( ets != null && ets.length > 0 ) - { - sb.append(" throws "); - for(int i=0;i 0 ) - sb.append(','); - sb.append(ReflectUtils.getName(ets[i])); - } - } - sb.append('{').append(body).append('}'); - return addConstructor(sb.toString()); - } - - public ClassGenerator addConstructor(Constructor c) - { - String desc = ReflectUtils.getDesc(c); - addConstructor(":"+desc); - if( mCopyConstructors == null ) - mCopyConstructors = new ConcurrentHashMap>(4); - mCopyConstructors.put(desc, c); - return this; - } - - public ClassGenerator addDefaultConstructor() - { - mDefaultConstructor = true; - return this; - } - - public ClassPool getClassPool() { - return mPool; - } - - public Class toClass(){ - return toClass(getClass().getClassLoader(), getClass().getProtectionDomain()); - } - - public Class toClass(ClassLoader loader, ProtectionDomain pd) - { - if( mCtc != null ) - mCtc.detach(); - long id = CLASS_NAME_COUNTER.getAndIncrement(); - try - { - CtClass ctcs = mSuperClass == null ? null : mPool.get(mSuperClass); - if( mClassName == null ) - mClassName = ( mSuperClass == null || javassist.Modifier.isPublic(ctcs.getModifiers()) - ? ClassGenerator.class.getName() : mSuperClass + "$sc" ) + id; - mCtc = mPool.makeClass(mClassName); - if( mSuperClass != null ) - mCtc.setSuperclass(ctcs); - mCtc.addInterface(mPool.get(DC.class.getName())); // add dynamic class tag. - if( mInterfaces != null ) - for( String cl : mInterfaces ) mCtc.addInterface(mPool.get(cl)); - if( mFields != null ) - for( String code : mFields ) mCtc.addField(CtField.make(code, mCtc)); - if( mMethods != null ) - { - for( String code : mMethods ) - { - if( code.charAt(0) == ':' ) - mCtc.addMethod(CtNewMethod.copy(getCtMethod(mCopyMethods.get(code.substring(1))), code.substring(1, code.indexOf('(')), mCtc, null)); - else - mCtc.addMethod(CtNewMethod.make(code, mCtc)); - } - } - if( mDefaultConstructor ) - mCtc.addConstructor(CtNewConstructor.defaultConstructor(mCtc)); - if( mConstructors != null ) - { - for( String code : mConstructors ) - { - if( code.charAt(0) == ':' ) - { - mCtc.addConstructor(CtNewConstructor.copy(getCtConstructor(mCopyConstructors.get(code.substring(1))), mCtc, null)); - } - else - { - String[] sn = mCtc.getSimpleName().split("\\$+"); // inner class name include $. - mCtc.addConstructor(CtNewConstructor.make(code.replaceFirst(SIMPLE_NAME_TAG, sn[sn.length-1]), mCtc)); - } - } - } - return mCtc.toClass(loader, pd); - } - catch(RuntimeException e) - { - throw e; - } - catch(NotFoundException e) - { - throw new RuntimeException(e.getMessage(), e); - } - catch(CannotCompileException e) - { - throw new RuntimeException(e.getMessage(), e); - } - } - - public void release() - { - if( mCtc != null ) mCtc.detach(); - if( mInterfaces != null ) mInterfaces.clear(); - if( mFields != null ) mFields.clear(); - if( mMethods != null ) mMethods.clear(); - if( mConstructors != null ) mConstructors.clear(); - if( mCopyMethods != null ) mCopyMethods.clear(); - if( mCopyConstructors != null ) mCopyConstructors.clear(); - } - - private CtClass getCtClass(Class c) throws NotFoundException - { - return mPool.get(c.getName()); - } - - private CtMethod getCtMethod(Method m) throws NotFoundException - { - return getCtClass(m.getDeclaringClass()).getMethod(m.getName(),ReflectUtils.getDescWithoutMethodName(m)); - } - - private CtConstructor getCtConstructor(Constructor c) throws NotFoundException - { - return getCtClass(c.getDeclaringClass()).getConstructor(ReflectUtils.getDesc(c)); - } - - private static String modifier(int mod) - { - if( Modifier.isPublic(mod) ) return "public"; - if( Modifier.isProtected(mod) ) return "protected"; - if( Modifier.isPrivate(mod) ) return "private"; - return ""; - } + ClassPool pool = POOL_MAP.get(loader); + if (pool == null) { + pool = new ClassPool(true); + pool.appendClassPath(new LoaderClassPath(loader)); + POOL_MAP.put(loader, pool); + } + return pool; + } + + private ClassPool mPool; + + private CtClass mCtc; + + private String mClassName, mSuperClass; + + private Set mInterfaces; + + private List mFields, mConstructors, mMethods; + + private Map mCopyMethods; // + + private Map> mCopyConstructors; // + + private boolean mDefaultConstructor = false; + + private ClassGenerator() { + } + + private ClassGenerator(ClassPool pool) { + mPool = pool; + } + + public String getClassName() { + return mClassName; + } + + public ClassGenerator setClassName(String name) { + mClassName = name; + return this; + } + + public ClassGenerator addInterface(String cn) { + if (mInterfaces == null) + mInterfaces = new HashSet(); + mInterfaces.add(cn); + return this; + } + + public ClassGenerator addInterface(Class cl) { + return addInterface(cl.getName()); + } + + public ClassGenerator setSuperClass(String cn) { + mSuperClass = cn; + return this; + } + + public ClassGenerator setSuperClass(Class cl) { + mSuperClass = cl.getName(); + return this; + } + + public ClassGenerator addField(String code) { + if (mFields == null) + mFields = new ArrayList(); + mFields.add(code); + return this; + } + + public ClassGenerator addField(String name, int mod, Class type) { + return addField(name, mod, type, null); + } + + public ClassGenerator addField(String name, int mod, Class type, String def) { + StringBuilder sb = new StringBuilder(); + sb.append(modifier(mod)).append(' ').append(ReflectUtils.getName(type)).append(' '); + sb.append(name); + if (def != null && def.length() > 0) { + sb.append('='); + sb.append(def); + } + sb.append(';'); + return addField(sb.toString()); + } + + public ClassGenerator addMethod(String code) { + if (mMethods == null) + mMethods = new ArrayList(); + mMethods.add(code); + return this; + } + + public ClassGenerator addMethod(String name, int mod, Class rt, Class[] pts, String body) { + return addMethod(name, mod, rt, pts, null, body); + } + + public ClassGenerator addMethod(String name, int mod, Class rt, Class[] pts, Class[] ets, String body) { + StringBuilder sb = new StringBuilder(); + sb.append(modifier(mod)).append(' ').append(ReflectUtils.getName(rt)).append(' ').append(name); + sb.append('('); + for (int i = 0; i < pts.length; i++) { + if (i > 0) + sb.append(','); + sb.append(ReflectUtils.getName(pts[i])); + sb.append(" arg").append(i); + } + sb.append(')'); + if (ets != null && ets.length > 0) { + sb.append(" throws "); + for (int i = 0; i < ets.length; i++) { + if (i > 0) + sb.append(','); + sb.append(ReflectUtils.getName(ets[i])); + } + } + sb.append('{').append(body).append('}'); + return addMethod(sb.toString()); + } + + public ClassGenerator addMethod(Method m) { + addMethod(m.getName(), m); + return this; + } + + public ClassGenerator addMethod(String name, Method m) { + String desc = name + ReflectUtils.getDescWithoutMethodName(m); + addMethod(':' + desc); + if (mCopyMethods == null) + mCopyMethods = new ConcurrentHashMap(8); + mCopyMethods.put(desc, m); + return this; + } + + public ClassGenerator addConstructor(String code) { + if (mConstructors == null) + mConstructors = new LinkedList(); + mConstructors.add(code); + return this; + } + + public ClassGenerator addConstructor(int mod, Class[] pts, String body) { + return addConstructor(mod, pts, null, body); + } + + public ClassGenerator addConstructor(int mod, Class[] pts, Class[] ets, String body) { + StringBuilder sb = new StringBuilder(); + sb.append(modifier(mod)).append(' ').append(SIMPLE_NAME_TAG); + sb.append('('); + for (int i = 0; i < pts.length; i++) { + if (i > 0) + sb.append(','); + sb.append(ReflectUtils.getName(pts[i])); + sb.append(" arg").append(i); + } + sb.append(')'); + if (ets != null && ets.length > 0) { + sb.append(" throws "); + for (int i = 0; i < ets.length; i++) { + if (i > 0) + sb.append(','); + sb.append(ReflectUtils.getName(ets[i])); + } + } + sb.append('{').append(body).append('}'); + return addConstructor(sb.toString()); + } + + public ClassGenerator addConstructor(Constructor c) { + String desc = ReflectUtils.getDesc(c); + addConstructor(":" + desc); + if (mCopyConstructors == null) + mCopyConstructors = new ConcurrentHashMap>(4); + mCopyConstructors.put(desc, c); + return this; + } + + public ClassGenerator addDefaultConstructor() { + mDefaultConstructor = true; + return this; + } + + public ClassPool getClassPool() { + return mPool; + } + + public Class toClass() { + return toClass(getClass().getClassLoader(), getClass().getProtectionDomain()); + } + + public Class toClass(ClassLoader loader, ProtectionDomain pd) { + if (mCtc != null) + mCtc.detach(); + long id = CLASS_NAME_COUNTER.getAndIncrement(); + try { + CtClass ctcs = mSuperClass == null ? null : mPool.get(mSuperClass); + if (mClassName == null) + mClassName = (mSuperClass == null || javassist.Modifier.isPublic(ctcs.getModifiers()) + ? ClassGenerator.class.getName() : mSuperClass + "$sc") + id; + mCtc = mPool.makeClass(mClassName); + if (mSuperClass != null) + mCtc.setSuperclass(ctcs); + mCtc.addInterface(mPool.get(DC.class.getName())); // add dynamic class tag. + if (mInterfaces != null) + for (String cl : mInterfaces) mCtc.addInterface(mPool.get(cl)); + if (mFields != null) + for (String code : mFields) mCtc.addField(CtField.make(code, mCtc)); + if (mMethods != null) { + for (String code : mMethods) { + if (code.charAt(0) == ':') + mCtc.addMethod(CtNewMethod.copy(getCtMethod(mCopyMethods.get(code.substring(1))), code.substring(1, code.indexOf('(')), mCtc, null)); + else + mCtc.addMethod(CtNewMethod.make(code, mCtc)); + } + } + if (mDefaultConstructor) + mCtc.addConstructor(CtNewConstructor.defaultConstructor(mCtc)); + if (mConstructors != null) { + for (String code : mConstructors) { + if (code.charAt(0) == ':') { + mCtc.addConstructor(CtNewConstructor.copy(getCtConstructor(mCopyConstructors.get(code.substring(1))), mCtc, null)); + } else { + String[] sn = mCtc.getSimpleName().split("\\$+"); // inner class name include $. + mCtc.addConstructor(CtNewConstructor.make(code.replaceFirst(SIMPLE_NAME_TAG, sn[sn.length - 1]), mCtc)); + } + } + } + return mCtc.toClass(loader, pd); + } catch (RuntimeException e) { + throw e; + } catch (NotFoundException e) { + throw new RuntimeException(e.getMessage(), e); + } catch (CannotCompileException e) { + throw new RuntimeException(e.getMessage(), e); + } + } + + public void release() { + if (mCtc != null) mCtc.detach(); + if (mInterfaces != null) mInterfaces.clear(); + if (mFields != null) mFields.clear(); + if (mMethods != null) mMethods.clear(); + if (mConstructors != null) mConstructors.clear(); + if (mCopyMethods != null) mCopyMethods.clear(); + if (mCopyConstructors != null) mCopyConstructors.clear(); + } + + private CtClass getCtClass(Class c) throws NotFoundException { + return mPool.get(c.getName()); + } + + private CtMethod getCtMethod(Method m) throws NotFoundException { + return getCtClass(m.getDeclaringClass()).getMethod(m.getName(), ReflectUtils.getDescWithoutMethodName(m)); + } + + private CtConstructor getCtConstructor(Constructor c) throws NotFoundException { + return getCtClass(c.getDeclaringClass()).getConstructor(ReflectUtils.getDesc(c)); + } + + private static String modifier(int mod) { + if (Modifier.isPublic(mod)) return "public"; + if (Modifier.isProtected(mod)) return "protected"; + if (Modifier.isPrivate(mod)) return "private"; + return ""; + } } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/Proxy.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/Proxy.java index a65e7b2aabe..75b7b0398db 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/Proxy.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/Proxy.java @@ -15,273 +15,244 @@ */ package com.alibaba.dubbo.common.bytecode; +import com.alibaba.dubbo.common.utils.ClassHelper; +import com.alibaba.dubbo.common.utils.ReflectUtils; + import java.lang.ref.Reference; import java.lang.ref.WeakReference; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Modifier; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.Set; -import java.util.WeakHashMap; +import java.util.*; import java.util.concurrent.atomic.AtomicLong; -import com.alibaba.dubbo.common.utils.ClassHelper; -import com.alibaba.dubbo.common.utils.ReflectUtils; - /** * Proxy. - * + * * @author qian.lei */ -public abstract class Proxy -{ - private static final AtomicLong PROXY_CLASS_COUNTER = new AtomicLong(0); - - private static final String PACKAGE_NAME = Proxy.class.getPackage().getName(); - - public static final InvocationHandler RETURN_NULL_INVOKER = new InvocationHandler(){ - public Object invoke(Object proxy, Method method, Object[] args){ return null; } - }; - - public static final InvocationHandler THROW_UNSUPPORTED_INVOKER = new InvocationHandler(){ - public Object invoke(Object proxy, Method method, Object[] args){ throw new UnsupportedOperationException("Method [" + ReflectUtils.getName(method) + "] unimplemented."); } - }; - - private static final Map> ProxyCacheMap = new WeakHashMap>(); - - private static final Object PendingGenerationMarker = new Object(); - - /** - * Get proxy. - * - * @param ics interface class array. - * @return Proxy instance. - */ - public static Proxy getProxy(Class... ics) - { - return getProxy(ClassHelper.getCallerClassLoader(Proxy.class), ics); - } - - /** - * Get proxy. - * @param cl class loader. - * @param ics interface class array. - * - * @return Proxy instance. - */ - public static Proxy getProxy(ClassLoader cl, Class... ics) - { - if( ics.length > 65535 ) - throw new IllegalArgumentException("interface limit exceeded"); - - StringBuilder sb = new StringBuilder(); - for(int i=0;i tmp = null; - try - { - tmp = Class.forName(itf, false, cl); - } - catch(ClassNotFoundException e) - {} - - if( tmp != ics[i] ) - throw new IllegalArgumentException(ics[i] + " is not visible from class loader"); - - sb.append(itf).append(';'); - } - - // use interface class name list as key. - String key = sb.toString(); - - // get cache by class loader. - Map cache; - synchronized( ProxyCacheMap ) - { - cache = ProxyCacheMap.get(cl); - if( cache == null ) - { - cache = new HashMap(); - ProxyCacheMap.put(cl, cache); - } - } - - Proxy proxy = null; - synchronized( cache ) - { - do - { - Object value = cache.get(key); - if( value instanceof Reference ) - { - proxy = (Proxy)((Reference)value).get(); - if( proxy != null ) - return proxy; - } - - if( value == PendingGenerationMarker ) - { - try{ cache.wait(); }catch(InterruptedException e){} - } - else - { - cache.put(key, PendingGenerationMarker); - break; - } - } - while( true ); - } - - long id = PROXY_CLASS_COUNTER.getAndIncrement(); - String pkg = null; - ClassGenerator ccp = null, ccm = null; - try - { - ccp = ClassGenerator.newInstance(cl); - - Set worked = new HashSet(); - List methods = new ArrayList(); - - for(int i=0;i rt = method.getReturnType(); - Class[] pts = method.getParameterTypes(); - - StringBuilder code = new StringBuilder("Object[] args = new Object[").append(pts.length).append("];"); - for(int j=0;j[]{ InvocationHandler.class }, new Class[0], "handler=$1;"); +public abstract class Proxy { + private static final AtomicLong PROXY_CLASS_COUNTER = new AtomicLong(0); + + private static final String PACKAGE_NAME = Proxy.class.getPackage().getName(); + + public static final InvocationHandler RETURN_NULL_INVOKER = new InvocationHandler() { + public Object invoke(Object proxy, Method method, Object[] args) { + return null; + } + }; + + public static final InvocationHandler THROW_UNSUPPORTED_INVOKER = new InvocationHandler() { + public Object invoke(Object proxy, Method method, Object[] args) { + throw new UnsupportedOperationException("Method [" + ReflectUtils.getName(method) + "] unimplemented."); + } + }; + + private static final Map> ProxyCacheMap = new WeakHashMap>(); + + private static final Object PendingGenerationMarker = new Object(); + + /** + * Get proxy. + * + * @param ics interface class array. + * @return Proxy instance. + */ + public static Proxy getProxy(Class... ics) { + return getProxy(ClassHelper.getCallerClassLoader(Proxy.class), ics); + } + + /** + * Get proxy. + * + * @param cl class loader. + * @param ics interface class array. + * @return Proxy instance. + */ + public static Proxy getProxy(ClassLoader cl, Class... ics) { + if (ics.length > 65535) + throw new IllegalArgumentException("interface limit exceeded"); + + StringBuilder sb = new StringBuilder(); + for (Class ic : ics) { + String itf = ic.getName(); + if (!ic.isInterface()) + throw new RuntimeException(itf + " is not a interface."); + + Class tmp = null; + try { + tmp = Class.forName(itf, false, cl); + } catch (ClassNotFoundException ignored) { + } + + if (tmp != ic) + throw new IllegalArgumentException(ic + " is not visible from class loader"); + + sb.append(itf).append(';'); + } + + // use interface class name list as key. + String key = sb.toString(); + + // get cache by class loader. + Map cache; + synchronized (ProxyCacheMap) { + cache = ProxyCacheMap.get(cl); + if (cache == null) { + cache = new HashMap(); + ProxyCacheMap.put(cl, cache); + } + } + + Proxy proxy = null; + synchronized (cache) { + do { + Object value = cache.get(key); + if (value instanceof Reference) { + proxy = (Proxy) ((Reference) value).get(); + if (proxy != null) + return proxy; + } + + if (value == PendingGenerationMarker) { + try { + cache.wait(); + } catch (InterruptedException ignored) { + } + } else { + cache.put(key, PendingGenerationMarker); + break; + } + } + while (true); + } + + long id = PROXY_CLASS_COUNTER.getAndIncrement(); + String pkg = null; + ClassGenerator ccp = null, ccm = null; + try { + ccp = ClassGenerator.newInstance(cl); + + Set worked = new HashSet(); + List methods = new ArrayList(); + + for (Class ic : ics) { + if (!Modifier.isPublic(ic.getModifiers())) { + String npkg = ic.getPackage().getName(); + if (pkg == null) { + pkg = npkg; + } else { + if (!pkg.equals(npkg)) + throw new IllegalArgumentException("non-public interfaces from different packages"); + } + } + ccp.addInterface(ic); + + for (Method method : ic.getMethods()) { + String desc = ReflectUtils.getDesc(method); + if (worked.contains(desc)) + continue; + worked.add(desc); + + int ix = methods.size(); + Class rt = method.getReturnType(); + Class[] pts = method.getParameterTypes(); + + StringBuilder code = new StringBuilder("Object[] args = new Object[").append(pts.length).append("];"); + for (int j = 0; j < pts.length; j++) + code.append(" args[").append(j).append("] = ($w)$").append(j + 1).append(";"); + code.append(" Object ret = handler.invoke(this, methods[" + ix + "], args);"); + if (!Void.TYPE.equals(rt)) + code.append(" return ").append(asArgument(rt, "ret")).append(";"); + + methods.add(method); + ccp.addMethod(method.getName(), method.getModifiers(), rt, pts, method.getExceptionTypes(), code.toString()); + } + } + + if (pkg == null) + pkg = PACKAGE_NAME; + + // create ProxyInstance class. + String pcn = pkg + ".proxy" + id; + ccp.setClassName(pcn); + ccp.addField("public static java.lang.reflect.Method[] methods;"); + ccp.addField("private " + InvocationHandler.class.getName() + " handler;"); + ccp.addConstructor(Modifier.PUBLIC, new Class[]{InvocationHandler.class}, new Class[0], "handler=$1;"); ccp.addDefaultConstructor(); - Class clazz = ccp.toClass(); - clazz.getField("methods").set(null, methods.toArray(new Method[0])); - - // create Proxy class. - String fcn = Proxy.class.getName() + id; - ccm = ClassGenerator.newInstance(cl); - ccm.setClassName(fcn); - ccm.addDefaultConstructor(); - ccm.setSuperClass(Proxy.class); - ccm.addMethod("public Object newInstance(" + InvocationHandler.class.getName() + " h){ return new " + pcn + "($1); }"); - Class pc = ccm.toClass(); - proxy = (Proxy)pc.newInstance(); - } - catch(RuntimeException e) - { - throw e; - } - catch(Exception e) - { - throw new RuntimeException(e.getMessage(), e); - } - finally - { - // release ClassGenerator - if( ccp != null ) - ccp.release(); - if( ccm != null ) - ccm.release(); - synchronized( cache ) - { - if( proxy == null ) - cache.remove(key); - else - cache.put(key, new WeakReference(proxy)); - cache.notifyAll(); - } - } - return proxy; - } - - /** - * get instance with default handler. - * - * @return instance. - */ - public Object newInstance() - { - return newInstance(THROW_UNSUPPORTED_INVOKER); - } - - /** - * get instance with special handler. - * - * @return instance. - */ - abstract public Object newInstance(InvocationHandler handler); - - protected Proxy(){} - - private static String asArgument(Class cl, String name) - { - if( cl.isPrimitive() ) - { - if( Boolean.TYPE == cl ) - return name + "==null?false:((Boolean)" + name + ").booleanValue()"; - if( Byte.TYPE == cl ) - return name + "==null?(byte)0:((Byte)" + name + ").byteValue()"; - if( Character.TYPE == cl ) - return name + "==null?(char)0:((Character)" + name + ").charValue()"; - if( Double.TYPE == cl ) - return name + "==null?(double)0:((Double)" + name + ").doubleValue()"; - if( Float.TYPE == cl ) - return name + "==null?(float)0:((Float)" + name + ").floatValue()"; - if( Integer.TYPE == cl ) - return name + "==null?(int)0:((Integer)" + name + ").intValue()"; - if( Long.TYPE == cl ) - return name + "==null?(long)0:((Long)" + name + ").longValue()"; - if( Short.TYPE == cl ) - return name + "==null?(short)0:((Short)" + name + ").shortValue()"; - throw new RuntimeException(name+" is unknown primitive type."); - } - return "(" + ReflectUtils.getName(cl) + ")"+name; - } + Class clazz = ccp.toClass(); + clazz.getField("methods").set(null, methods.toArray(new Method[0])); + + // create Proxy class. + String fcn = Proxy.class.getName() + id; + ccm = ClassGenerator.newInstance(cl); + ccm.setClassName(fcn); + ccm.addDefaultConstructor(); + ccm.setSuperClass(Proxy.class); + ccm.addMethod("public Object newInstance(" + InvocationHandler.class.getName() + " h){ return new " + pcn + "($1); }"); + Class pc = ccm.toClass(); + proxy = (Proxy) pc.newInstance(); + } catch (RuntimeException e) { + throw e; + } catch (Exception e) { + throw new RuntimeException(e.getMessage(), e); + } finally { + // release ClassGenerator + if (ccp != null) + ccp.release(); + if (ccm != null) + ccm.release(); + synchronized (cache) { + if (proxy == null) + cache.remove(key); + else + cache.put(key, new WeakReference(proxy)); + cache.notifyAll(); + } + } + return proxy; + } + + /** + * get instance with default handler. + * + * @return instance. + */ + public Object newInstance() { + return newInstance(THROW_UNSUPPORTED_INVOKER); + } + + /** + * get instance with special handler. + * + * @return instance. + */ + abstract public Object newInstance(InvocationHandler handler); + + protected Proxy() { + } + + private static String asArgument(Class cl, String name) { + if (cl.isPrimitive()) { + if (Boolean.TYPE == cl) + return name + "==null?false:((Boolean)" + name + ").booleanValue()"; + if (Byte.TYPE == cl) + return name + "==null?(byte)0:((Byte)" + name + ").byteValue()"; + if (Character.TYPE == cl) + return name + "==null?(char)0:((Character)" + name + ").charValue()"; + if (Double.TYPE == cl) + return name + "==null?(double)0:((Double)" + name + ").doubleValue()"; + if (Float.TYPE == cl) + return name + "==null?(float)0:((Float)" + name + ").floatValue()"; + if (Integer.TYPE == cl) + return name + "==null?(int)0:((Integer)" + name + ").intValue()"; + if (Long.TYPE == cl) + return name + "==null?(long)0:((Long)" + name + ").longValue()"; + if (Short.TYPE == cl) + return name + "==null?(short)0:((Short)" + name + ").shortValue()"; + throw new RuntimeException(name + " is unknown primitive type."); + } + return "(" + ReflectUtils.getName(cl) + ")" + name; + } } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/Wrapper.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/Wrapper.java index 653e30e6425..ee0ca79bbd7 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/Wrapper.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/bytecode/Wrapper.java @@ -15,415 +15,404 @@ */ package com.alibaba.dubbo.common.bytecode; +import com.alibaba.dubbo.common.utils.ClassHelper; +import com.alibaba.dubbo.common.utils.ReflectUtils; + import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.lang.reflect.Modifier; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.LinkedHashMap; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.atomic.AtomicLong; import java.util.regex.Matcher; -import com.alibaba.dubbo.common.utils.ClassHelper; -import com.alibaba.dubbo.common.utils.ReflectUtils; - /** * Wrapper. - * + * * @author qian.lei */ -public abstract class Wrapper -{ - private static AtomicLong WRAPPER_CLASS_COUNTER = new AtomicLong(0); - - private static final Map, Wrapper> WRAPPER_MAP = new ConcurrentHashMap, Wrapper>(); //class wrapper map - - private static final String[] EMPTY_STRING_ARRAY = new String[0]; - - private static final String[] OBJECT_METHODS = new String[]{"getClass", "hashCode", "toString", "equals"}; - - private static final Wrapper OBJECT_WRAPPER = new Wrapper(){ - public String[] getMethodNames(){ return OBJECT_METHODS; } - public String[] getDeclaredMethodNames(){ return OBJECT_METHODS; } - public String[] getPropertyNames(){ return EMPTY_STRING_ARRAY; } - public Class getPropertyType(String pn){ return null; } - public Object getPropertyValue(Object instance, String pn) throws NoSuchPropertyException{ throw new NoSuchPropertyException("Property [" + pn + "] not found."); } - public void setPropertyValue(Object instance, String pn, Object pv) throws NoSuchPropertyException{ throw new NoSuchPropertyException("Property [" + pn + "] not found."); } - public boolean hasProperty(String name){ return false; } - public Object invokeMethod(Object instance, String mn, Class[] types, Object[] args) throws NoSuchMethodException - { - if( "getClass".equals(mn) ) return instance.getClass(); - if( "hashCode".equals(mn) ) return instance.hashCode(); - if( "toString".equals(mn) ) return instance.toString(); - if( "equals".equals(mn) ) - { - if( args.length == 1 ) return instance.equals(args[0]); - throw new IllegalArgumentException("Invoke method [" + mn + "] argument number error."); - } - throw new NoSuchMethodException("Method [" + mn + "] not found."); - } - }; - - /** - * get wrapper. - * - * @param c Class instance. - * @return Wrapper instance(not null). - */ - public static Wrapper getWrapper(Class c) - { - while( ClassGenerator.isDynamicClass(c) ) // can not wrapper on dynamic class. +public abstract class Wrapper { + private static AtomicLong WRAPPER_CLASS_COUNTER = new AtomicLong(0); + + private static final Map, Wrapper> WRAPPER_MAP = new ConcurrentHashMap, Wrapper>(); //class wrapper map + + private static final String[] EMPTY_STRING_ARRAY = new String[0]; + + private static final String[] OBJECT_METHODS = new String[]{"getClass", "hashCode", "toString", "equals"}; + + private static final Wrapper OBJECT_WRAPPER = new Wrapper() { + public String[] getMethodNames() { + return OBJECT_METHODS; + } + + public String[] getDeclaredMethodNames() { + return OBJECT_METHODS; + } + + public String[] getPropertyNames() { + return EMPTY_STRING_ARRAY; + } + + public Class getPropertyType(String pn) { + return null; + } + + public Object getPropertyValue(Object instance, String pn) throws NoSuchPropertyException { + throw new NoSuchPropertyException("Property [" + pn + "] not found."); + } + + public void setPropertyValue(Object instance, String pn, Object pv) throws NoSuchPropertyException { + throw new NoSuchPropertyException("Property [" + pn + "] not found."); + } + + public boolean hasProperty(String name) { + return false; + } + + public Object invokeMethod(Object instance, String mn, Class[] types, Object[] args) throws NoSuchMethodException { + if ("getClass".equals(mn)) return instance.getClass(); + if ("hashCode".equals(mn)) return instance.hashCode(); + if ("toString".equals(mn)) return instance.toString(); + if ("equals".equals(mn)) { + if (args.length == 1) return instance.equals(args[0]); + throw new IllegalArgumentException("Invoke method [" + mn + "] argument number error."); + } + throw new NoSuchMethodException("Method [" + mn + "] not found."); + } + }; + + /** + * get wrapper. + * + * @param c Class instance. + * @return Wrapper instance(not null). + */ + public static Wrapper getWrapper(Class c) { + while (ClassGenerator.isDynamicClass(c)) // can not wrapper on dynamic class. c = c.getSuperclass(); - if( c == Object.class ) + if (c == Object.class) return OBJECT_WRAPPER; Wrapper ret = WRAPPER_MAP.get(c); - if( ret == null ) - { + if (ret == null) { ret = makeWrapper(c); - WRAPPER_MAP.put(c,ret); + WRAPPER_MAP.put(c, ret); } return ret; } - /** - * get property name array. - * - * @return property name array. - */ - abstract public String[] getPropertyNames(); - - /** - * get property type. - * - * @param pn property name. - * @return Property type or nul. - */ - abstract public Class getPropertyType(String pn); - - /** - * has property. - * - * @param name property name. - * @return has or has not. - */ - abstract public boolean hasProperty(String name); - - /** - * get property value. - * - * @param instance instance. - * @param pn property name. - * @return value. - */ - abstract public Object getPropertyValue(Object instance, String pn) throws NoSuchPropertyException, IllegalArgumentException; - - /** - * set property value. - * - * @param instance instance. - * @param pn property name. - * @param pv property value. - */ - abstract public void setPropertyValue(Object instance, String pn, Object pv) throws NoSuchPropertyException, IllegalArgumentException; - - /** - * get property value. - * - * @param instance instance. - * @param pns property name array. - * @return value array. - */ - public Object[] getPropertyValues(Object instance, String[] pns) throws NoSuchPropertyException, IllegalArgumentException - { - Object[] ret = new Object[pns.length]; - for(int i=0;i[] types, Object[] args) throws NoSuchMethodException, InvocationTargetException; - - private static Wrapper makeWrapper(Class c) - { - if( c.isPrimitive() ) - throw new IllegalArgumentException("Can not create wrapper for primitive type: " + c); - - String name = c.getName(); - ClassLoader cl = ClassHelper.getClassLoader(c); - - StringBuilder c1 = new StringBuilder("public void setPropertyValue(Object o, String n, Object v){ "); - StringBuilder c2 = new StringBuilder("public Object getPropertyValue(Object o, String n){ "); - StringBuilder c3 = new StringBuilder("public Object invokeMethod(Object o, String n, Class[] p, Object[] v) throws " + InvocationTargetException.class.getName() + "{ "); - - c1.append(name).append(" w; try{ w = ((").append(name).append(")$1); }catch(Throwable e){ throw new IllegalArgumentException(e); }"); - c2.append(name).append(" w; try{ w = ((").append(name).append(")$1); }catch(Throwable e){ throw new IllegalArgumentException(e); }"); - c3.append(name).append(" w; try{ w = ((").append(name).append(")$1); }catch(Throwable e){ throw new IllegalArgumentException(e); }"); - - Map> pts = new HashMap>(); // - Map ms = new LinkedHashMap(); // - List mns = new ArrayList(); // method names. - List dmns = new ArrayList(); // declaring method names. - - // get all public field. - for( Field f : c.getFields() ) - { - String fn = f.getName(); - Class ft = f.getType(); - if( Modifier.isStatic(f.getModifiers()) || Modifier.isTransient(f.getModifiers()) ) - continue; - - c1.append(" if( $2.equals(\"").append(fn).append("\") ){ w.").append(fn).append("=").append(arg(ft, "$3")).append("; return; }"); - c2.append(" if( $2.equals(\"").append(fn).append("\") ){ return ($w)w.").append(fn).append("; }"); - pts.put(fn, ft); - } - - Method[] methods = c.getMethods(); - // get all public method. - boolean hasMethod = hasMethods(methods); - if( hasMethod ){ - c3.append(" try{"); - } - for( Method m : methods ) - { - if( m.getDeclaringClass() == Object.class ) //ignore Object's method. - continue; - - String mn = m.getName(); - c3.append(" if( \"").append(mn).append("\".equals( $2 ) "); + + /** + * get property name array. + * + * @return property name array. + */ + abstract public String[] getPropertyNames(); + + /** + * get property type. + * + * @param pn property name. + * @return Property type or nul. + */ + abstract public Class getPropertyType(String pn); + + /** + * has property. + * + * @param name property name. + * @return has or has not. + */ + abstract public boolean hasProperty(String name); + + /** + * get property value. + * + * @param instance instance. + * @param pn property name. + * @return value. + */ + abstract public Object getPropertyValue(Object instance, String pn) throws NoSuchPropertyException, IllegalArgumentException; + + /** + * set property value. + * + * @param instance instance. + * @param pn property name. + * @param pv property value. + */ + abstract public void setPropertyValue(Object instance, String pn, Object pv) throws NoSuchPropertyException, IllegalArgumentException; + + /** + * get property value. + * + * @param instance instance. + * @param pns property name array. + * @return value array. + */ + public Object[] getPropertyValues(Object instance, String[] pns) throws NoSuchPropertyException, IllegalArgumentException { + Object[] ret = new Object[pns.length]; + for (int i = 0; i < ret.length; i++) + ret[i] = getPropertyValue(instance, pns[i]); + return ret; + } + + /** + * set property value. + * + * @param instance instance. + * @param pns property name array. + * @param pvs property value array. + */ + public void setPropertyValues(Object instance, String[] pns, Object[] pvs) throws NoSuchPropertyException, IllegalArgumentException { + if (pns.length != pvs.length) + throw new IllegalArgumentException("pns.length != pvs.length"); + + for (int i = 0; i < pns.length; i++) + setPropertyValue(instance, pns[i], pvs[i]); + } + + /** + * get method name array. + * + * @return method name array. + */ + abstract public String[] getMethodNames(); + + /** + * get method name array. + * + * @return method name array. + */ + abstract public String[] getDeclaredMethodNames(); + + /** + * has method. + * + * @param name method name. + * @return has or has not. + */ + public boolean hasMethod(String name) { + for (String mn : getMethodNames()) + if (mn.equals(name)) return true; + return false; + } + + /** + * invoke method. + * + * @param instance instance. + * @param mn method name. + * @param types + * @param args argument array. + * @return return value. + */ + abstract public Object invokeMethod(Object instance, String mn, Class[] types, Object[] args) throws NoSuchMethodException, InvocationTargetException; + + private static Wrapper makeWrapper(Class c) { + if (c.isPrimitive()) + throw new IllegalArgumentException("Can not create wrapper for primitive type: " + c); + + String name = c.getName(); + ClassLoader cl = ClassHelper.getClassLoader(c); + + StringBuilder c1 = new StringBuilder("public void setPropertyValue(Object o, String n, Object v){ "); + StringBuilder c2 = new StringBuilder("public Object getPropertyValue(Object o, String n){ "); + StringBuilder c3 = new StringBuilder("public Object invokeMethod(Object o, String n, Class[] p, Object[] v) throws " + InvocationTargetException.class.getName() + "{ "); + + c1.append(name).append(" w; try{ w = ((").append(name).append(")$1); }catch(Throwable e){ throw new IllegalArgumentException(e); }"); + c2.append(name).append(" w; try{ w = ((").append(name).append(")$1); }catch(Throwable e){ throw new IllegalArgumentException(e); }"); + c3.append(name).append(" w; try{ w = ((").append(name).append(")$1); }catch(Throwable e){ throw new IllegalArgumentException(e); }"); + + Map> pts = new HashMap>(); // + Map ms = new LinkedHashMap(); // + List mns = new ArrayList(); // method names. + List dmns = new ArrayList(); // declaring method names. + + // get all public field. + for (Field f : c.getFields()) { + String fn = f.getName(); + Class ft = f.getType(); + if (Modifier.isStatic(f.getModifiers()) || Modifier.isTransient(f.getModifiers())) + continue; + + c1.append(" if( $2.equals(\"").append(fn).append("\") ){ w.").append(fn).append("=").append(arg(ft, "$3")).append("; return; }"); + c2.append(" if( $2.equals(\"").append(fn).append("\") ){ return ($w)w.").append(fn).append("; }"); + pts.put(fn, ft); + } + + Method[] methods = c.getMethods(); + // get all public method. + boolean hasMethod = hasMethods(methods); + if (hasMethod) { + c3.append(" try{"); + } + for (Method m : methods) { + if (m.getDeclaringClass() == Object.class) //ignore Object's method. + continue; + + String mn = m.getName(); + c3.append(" if( \"").append(mn).append("\".equals( $2 ) "); int len = m.getParameterTypes().length; c3.append(" && ").append(" $3.length == ").append(len); - - boolean override = false; - for( Method m2 : methods ) { - if (m != m2 && m.getName().equals(m2.getName())) { - override = true; - break; - } - } - if (override) { - if (len > 0) { - for (int l = 0; l < len; l ++) { - c3.append(" && ").append(" $3[").append(l).append("].getName().equals(\"") - .append(m.getParameterTypes()[l].getName()).append("\")"); - } - } - } - - c3.append(" ) { "); - - if( m.getReturnType() == Void.TYPE ) - c3.append(" w.").append(mn).append('(').append(args(m.getParameterTypes(), "$4")).append(");").append(" return null;"); - else - c3.append(" return ($w)w.").append(mn).append('(').append(args(m.getParameterTypes(), "$4")).append(");"); - - c3.append(" }"); - - mns.add(mn); - if( m.getDeclaringClass() == c ) - dmns.add(mn); - ms.put(ReflectUtils.getDesc(m), m); - } - if( hasMethod ){ - c3.append(" } catch(Throwable e) { " ); - c3.append(" throw new java.lang.reflect.InvocationTargetException(e); " ); - c3.append(" }"); + + boolean override = false; + for (Method m2 : methods) { + if (m != m2 && m.getName().equals(m2.getName())) { + override = true; + break; + } + } + if (override) { + if (len > 0) { + for (int l = 0; l < len; l++) { + c3.append(" && ").append(" $3[").append(l).append("].getName().equals(\"") + .append(m.getParameterTypes()[l].getName()).append("\")"); + } + } + } + + c3.append(" ) { "); + + if (m.getReturnType() == Void.TYPE) + c3.append(" w.").append(mn).append('(').append(args(m.getParameterTypes(), "$4")).append(");").append(" return null;"); + else + c3.append(" return ($w)w.").append(mn).append('(').append(args(m.getParameterTypes(), "$4")).append(");"); + + c3.append(" }"); + + mns.add(mn); + if (m.getDeclaringClass() == c) + dmns.add(mn); + ms.put(ReflectUtils.getDesc(m), m); + } + if (hasMethod) { + c3.append(" } catch(Throwable e) { "); + c3.append(" throw new java.lang.reflect.InvocationTargetException(e); "); + c3.append(" }"); + } + + c3.append(" throw new " + NoSuchMethodException.class.getName() + "(\"Not found method \\\"\"+$2+\"\\\" in class " + c.getName() + ".\"); }"); + + // deal with get/set method. + Matcher matcher; + for (Map.Entry entry : ms.entrySet()) { + String md = entry.getKey(); + Method method = entry.getValue(); + if ((matcher = ReflectUtils.GETTER_METHOD_DESC_PATTERN.matcher(md)).matches()) { + String pn = propertyName(matcher.group(1)); + c2.append(" if( $2.equals(\"").append(pn).append("\") ){ return ($w)w.").append(method.getName()).append("(); }"); + pts.put(pn, method.getReturnType()); + } else if ((matcher = ReflectUtils.IS_HAS_CAN_METHOD_DESC_PATTERN.matcher(md)).matches()) { + String pn = propertyName(matcher.group(1)); + c2.append(" if( $2.equals(\"").append(pn).append("\") ){ return ($w)w.").append(method.getName()).append("(); }"); + pts.put(pn, method.getReturnType()); + } else if ((matcher = ReflectUtils.SETTER_METHOD_DESC_PATTERN.matcher(md)).matches()) { + Class pt = method.getParameterTypes()[0]; + String pn = propertyName(matcher.group(1)); + c1.append(" if( $2.equals(\"").append(pn).append("\") ){ w.").append(method.getName()).append("(").append(arg(pt, "$3")).append("); return; }"); + pts.put(pn, pt); + } + } + c1.append(" throw new " + NoSuchPropertyException.class.getName() + "(\"Not found property \\\"\"+$2+\"\\\" filed or setter method in class " + c.getName() + ".\"); }"); + c2.append(" throw new " + NoSuchPropertyException.class.getName() + "(\"Not found property \\\"\"+$2+\"\\\" filed or setter method in class " + c.getName() + ".\"); }"); + + // make class + long id = WRAPPER_CLASS_COUNTER.getAndIncrement(); + ClassGenerator cc = ClassGenerator.newInstance(cl); + cc.setClassName((Modifier.isPublic(c.getModifiers()) ? Wrapper.class.getName() : c.getName() + "$sw") + id); + cc.setSuperClass(Wrapper.class); + + cc.addDefaultConstructor(); + cc.addField("public static String[] pns;"); // property name array. + cc.addField("public static " + Map.class.getName() + " pts;"); // property type map. + cc.addField("public static String[] mns;"); // all method name array. + cc.addField("public static String[] dmns;"); // declared method name array. + for (int i = 0, len = ms.size(); i < len; i++) + cc.addField("public static Class[] mts" + i + ";"); + + cc.addMethod("public String[] getPropertyNames(){ return pns; }"); + cc.addMethod("public boolean hasProperty(String n){ return pts.containsKey($1); }"); + cc.addMethod("public Class getPropertyType(String n){ return (Class)pts.get($1); }"); + cc.addMethod("public String[] getMethodNames(){ return mns; }"); + cc.addMethod("public String[] getDeclaredMethodNames(){ return dmns; }"); + cc.addMethod(c1.toString()); + cc.addMethod(c2.toString()); + cc.addMethod(c3.toString()); + + try { + Class wc = cc.toClass(); + // setup static field. + wc.getField("pts").set(null, pts); + wc.getField("pns").set(null, pts.keySet().toArray(new String[0])); + wc.getField("mns").set(null, mns.toArray(new String[0])); + wc.getField("dmns").set(null, dmns.toArray(new String[0])); + int ix = 0; + for (Method m : ms.values()) + wc.getField("mts" + ix++).set(null, m.getParameterTypes()); + return (Wrapper) wc.newInstance(); + } catch (RuntimeException e) { + throw e; + } catch (Throwable e) { + throw new RuntimeException(e.getMessage(), e); + } finally { + cc.release(); + ms.clear(); + mns.clear(); + dmns.clear(); } - - c3.append(" throw new " + NoSuchMethodException.class.getName() + "(\"Not found method \\\"\"+$2+\"\\\" in class " + c.getName() + ".\"); }"); - - // deal with get/set method. - Matcher matcher; - for( Map.Entry entry : ms.entrySet() ) - { - String md = entry.getKey(); - Method method = (Method)entry.getValue(); - if( ( matcher = ReflectUtils.GETTER_METHOD_DESC_PATTERN.matcher(md) ).matches() ) - { - String pn = propertyName(matcher.group(1)); - c2.append(" if( $2.equals(\"").append(pn).append("\") ){ return ($w)w.").append(method.getName()).append("(); }"); - pts.put(pn, method.getReturnType()); - } - else if( ( matcher = ReflectUtils.IS_HAS_CAN_METHOD_DESC_PATTERN.matcher(md) ).matches() ) - { - String pn = propertyName(matcher.group(1)); - c2.append(" if( $2.equals(\"").append(pn).append("\") ){ return ($w)w.").append(method.getName()).append("(); }"); - pts.put(pn, method.getReturnType()); - } - else if( ( matcher = ReflectUtils.SETTER_METHOD_DESC_PATTERN.matcher(md) ).matches() ) - { - Class pt = method.getParameterTypes()[0]; - String pn = propertyName(matcher.group(1)); - c1.append(" if( $2.equals(\"").append(pn).append("\") ){ w.").append(method.getName()).append("(").append(arg(pt,"$3")).append("); return; }"); - pts.put(pn, pt); - } - } - c1.append(" throw new " + NoSuchPropertyException.class.getName() + "(\"Not found property \\\"\"+$2+\"\\\" filed or setter method in class " + c.getName() + ".\"); }"); - c2.append(" throw new " + NoSuchPropertyException.class.getName() + "(\"Not found property \\\"\"+$2+\"\\\" filed or setter method in class " + c.getName() + ".\"); }"); - - // make class - long id = WRAPPER_CLASS_COUNTER.getAndIncrement(); - ClassGenerator cc = ClassGenerator.newInstance(cl); - cc.setClassName( ( Modifier.isPublic(c.getModifiers()) ? Wrapper.class.getName() : c.getName() + "$sw" ) + id ); - cc.setSuperClass(Wrapper.class); - - cc.addDefaultConstructor(); - cc.addField("public static String[] pns;"); // property name array. - cc.addField("public static " + Map.class.getName() + " pts;"); // property type map. - cc.addField("public static String[] mns;"); // all method name array. - cc.addField("public static String[] dmns;"); // declared method name array. - for(int i=0,len=ms.size();i wc = cc.toClass(); - // setup static field. - wc.getField("pts").set(null, pts); - wc.getField("pns").set(null, pts.keySet().toArray(new String[0])); - wc.getField("mns").set(null, mns.toArray(new String[0])); - wc.getField("dmns").set(null, dmns.toArray(new String[0])); - int ix = 0; - for( Method m : ms.values() ) - wc.getField("mts" + ix++).set(null, m.getParameterTypes()); - return (Wrapper)wc.newInstance(); - } - catch(RuntimeException e) - { - throw e; - } - catch(Throwable e) - { - throw new RuntimeException(e.getMessage(), e); - } - finally - { - cc.release(); - ms.clear(); - mns.clear(); - dmns.clear(); - } - } - - private static String arg(Class cl, String name) - { - if( cl.isPrimitive() ) - { - if( cl == Boolean.TYPE ) - return "((Boolean)" + name + ").booleanValue()"; - if( cl == Byte.TYPE ) - return "((Byte)" + name + ").byteValue()"; - if( cl == Character.TYPE ) - return "((Character)" + name + ").charValue()"; - if( cl == Double.TYPE ) - return "((Number)" + name + ").doubleValue()"; - if( cl == Float.TYPE ) - return "((Number)" + name + ").floatValue()"; - if( cl == Integer.TYPE ) - return "((Number)" + name + ").intValue()"; - if( cl == Long.TYPE ) - return "((Number)" + name + ").longValue()"; - if( cl == Short.TYPE ) - return "((Number)" + name + ").shortValue()"; - throw new RuntimeException("Unknown primitive type: " + cl.getName()); - } - return "(" + ReflectUtils.getName(cl) + ")" + name; - } - - private static String args(Class[] cs,String name) - { - int len = cs.length; - if( len == 0 ) return ""; - StringBuilder sb = new StringBuilder(); - for(int i=0;i 0 ) - sb.append(','); - sb.append(arg(cs[i],name+"["+i+"]")); - } - return sb.toString(); - } - - private static String propertyName(String pn) - { - return pn.length() == 1 || Character.isLowerCase(pn.charAt(1)) ? Character.toLowerCase(pn.charAt(0)) + pn.substring(1) : pn; - } - - private static boolean hasMethods(Method[] methods){ - if(methods == null || methods.length == 0){ - return false; - } - for(Method m : methods){ - if(m.getDeclaringClass() != Object.class){ - return true; - } - } - return false; - } + } + + private static String arg(Class cl, String name) { + if (cl.isPrimitive()) { + if (cl == Boolean.TYPE) + return "((Boolean)" + name + ").booleanValue()"; + if (cl == Byte.TYPE) + return "((Byte)" + name + ").byteValue()"; + if (cl == Character.TYPE) + return "((Character)" + name + ").charValue()"; + if (cl == Double.TYPE) + return "((Number)" + name + ").doubleValue()"; + if (cl == Float.TYPE) + return "((Number)" + name + ").floatValue()"; + if (cl == Integer.TYPE) + return "((Number)" + name + ").intValue()"; + if (cl == Long.TYPE) + return "((Number)" + name + ").longValue()"; + if (cl == Short.TYPE) + return "((Number)" + name + ").shortValue()"; + throw new RuntimeException("Unknown primitive type: " + cl.getName()); + } + return "(" + ReflectUtils.getName(cl) + ")" + name; + } + + private static String args(Class[] cs, String name) { + int len = cs.length; + if (len == 0) return ""; + StringBuilder sb = new StringBuilder(); + for (int i = 0; i < len; i++) { + if (i > 0) + sb.append(','); + sb.append(arg(cs[i], name + "[" + i + "]")); + } + return sb.toString(); + } + + private static String propertyName(String pn) { + return pn.length() == 1 || Character.isLowerCase(pn.charAt(1)) ? Character.toLowerCase(pn.charAt(0)) + pn.substring(1) : pn; + } + + private static boolean hasMethods(Method[] methods) { + if (methods == null || methods.length == 0) { + return false; + } + for (Method m : methods) { + if (m.getDeclaringClass() != Object.class) { + return true; + } + } + return false; + } } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/compiler/support/JdkCompiler.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/compiler/support/JdkCompiler.java index 5f6bcfcef88..f8754114686 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/compiler/support/JdkCompiler.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/compiler/support/JdkCompiler.java @@ -103,8 +103,8 @@ public Class doCompile(String name, String sourceCode) throws Throwable { javaFileManager.putFileForInput(StandardLocation.SOURCE_PATH, packageName, className + ClassUtils.JAVA_EXTENSION, javaFileObject); Boolean result = compiler.getTask(null, javaFileManager, diagnosticCollector, options, - null, Arrays.asList(new JavaFileObject[]{javaFileObject})).call(); - if (result == null || ! result.booleanValue()) { + null, Collections.singletonList(javaFileObject)).call(); + if (result == null || !result) { throw new IllegalStateException("Compilation failed. class: " + name + ", diagnostics: " + diagnosticCollector); } return classLoader.loadClass(name); diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/extension/ExtensionLoader.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/extension/ExtensionLoader.java index 89080bf64fc..7c4a35caef9 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/extension/ExtensionLoader.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/extension/ExtensionLoader.java @@ -15,23 +15,6 @@ */ package com.alibaba.dubbo.common.extension; -import java.io.BufferedReader; -import java.io.InputStreamReader; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.Collections; -import java.util.Enumeration; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.Set; -import java.util.TreeSet; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; -import java.util.regex.Pattern; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.support.ActivateComparator; @@ -42,6 +25,15 @@ import com.alibaba.dubbo.common.utils.Holder; import com.alibaba.dubbo.common.utils.StringUtils; +import java.io.BufferedReader; +import java.io.InputStreamReader; +import java.lang.reflect.Method; +import java.lang.reflect.Modifier; +import java.util.*; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; +import java.util.regex.Pattern; + /** * Dubbo使用的扩展点获取。

*

    @@ -49,12 +41,10 @@ *
  • 自动Wrap上扩展点的Wrap类。
  • *
  • 缺省获得的的扩展点是一个Adaptive Instance。 *
- * - * @see JDK5.0的自动发现机制实现 - * + * * @author william.liangf * @author ding.lid - * + * @see JDK5.0的自动发现机制实现 * @see com.alibaba.dubbo.common.extension.SPI * @see com.alibaba.dubbo.common.extension.Adaptive * @see com.alibaba.dubbo.common.extension.Activate @@ -62,28 +52,26 @@ public class ExtensionLoader { private static final Logger logger = LoggerFactory.getLogger(ExtensionLoader.class); - + private static final String SERVICES_DIRECTORY = "META-INF/services/"; private static final String DUBBO_DIRECTORY = "META-INF/dubbo/"; - + private static final String DUBBO_INTERNAL_DIRECTORY = DUBBO_DIRECTORY + "internal/"; private static final Pattern NAME_SEPARATOR = Pattern.compile("\\s*[,]+\\s*"); - + private static final ConcurrentMap, ExtensionLoader> EXTENSION_LOADERS = new ConcurrentHashMap, ExtensionLoader>(); private static final ConcurrentMap, Object> EXTENSION_INSTANCES = new ConcurrentHashMap, Object>(); - // ============================== - private final Class type; private final ExtensionFactory objectFactory; private final ConcurrentMap, String> cachedNames = new ConcurrentHashMap, String>(); - - private final Holder>> cachedClasses = new Holder>>(); + + private final Holder>> cachedClasses = new Holder>>(); private final Map cachedActivates = new ConcurrentHashMap(); @@ -97,25 +85,25 @@ public class ExtensionLoader { private volatile Throwable createAdaptiveInstanceError; private Set> cachedWrapperClasses; - + private Map exceptions = new ConcurrentHashMap(); - + private static boolean withExtensionAnnotation(Class type) { return type.isAnnotationPresent(SPI.class); } - + @SuppressWarnings("unchecked") public static ExtensionLoader getExtensionLoader(Class type) { if (type == null) throw new IllegalArgumentException("Extension type == null"); - if(!type.isInterface()) { + if (!type.isInterface()) { throw new IllegalArgumentException("Extension type(" + type + ") is not interface!"); } - if(!withExtensionAnnotation(type)) { - throw new IllegalArgumentException("Extension type(" + type + + if (!withExtensionAnnotation(type)) { + throw new IllegalArgumentException("Extension type(" + type + ") is not extension, because WITHOUT @" + SPI.class.getSimpleName() + " Annotation!"); } - + ExtensionLoader loader = (ExtensionLoader) EXTENSION_LOADERS.get(type); if (loader == null) { EXTENSION_LOADERS.putIfAbsent(type, new ExtensionLoader(type)); @@ -128,7 +116,7 @@ private ExtensionLoader(Class type) { this.type = type; objectFactory = (type == ExtensionFactory.class ? null : ExtensionLoader.getExtensionLoader(ExtensionFactory.class).getAdaptiveExtension()); } - + public String getExtensionName(T extensionInstance) { return getExtensionName(extensionInstance.getClass()); } @@ -156,10 +144,10 @@ public List getActivateExtension(URL url, String key) { * getActivateExtension(url, values, null); * * - * @see #getActivateExtension(com.alibaba.dubbo.common.URL, String[], String) - * @param url url + * @param url url * @param values extension point names * @return extension list which are activated + * @see #getActivateExtension(com.alibaba.dubbo.common.URL, String[], String) */ public List getActivateExtension(URL url, String[] values) { return getActivateExtension(url, values, null); @@ -170,11 +158,11 @@ public List getActivateExtension(URL url, String[] values) { * getActivateExtension(url, url.getParameter(key).split(","), null); * * - * @see #getActivateExtension(com.alibaba.dubbo.common.URL, String[], String) - * @param url url - * @param key url parameter key which used to get extension point names + * @param url url + * @param key url parameter key which used to get extension point names * @param group group * @return extension list which are activated. + * @see #getActivateExtension(com.alibaba.dubbo.common.URL, String[], String) */ public List getActivateExtension(URL url, String key, String group) { String value = url.getParameter(key); @@ -184,24 +172,24 @@ public List getActivateExtension(URL url, String key, String group) { /** * Get activate extensions. * - * @see com.alibaba.dubbo.common.extension.Activate - * @param url url + * @param url url * @param values extension point names - * @param group group + * @param group group * @return extension list which are activated + * @see com.alibaba.dubbo.common.extension.Activate */ public List getActivateExtension(URL url, String[] values, String group) { List exts = new ArrayList(); List names = values == null ? new ArrayList(0) : Arrays.asList(values); - if (! names.contains(Constants.REMOVE_VALUE_PREFIX + Constants.DEFAULT_KEY)) { + if (!names.contains(Constants.REMOVE_VALUE_PREFIX + Constants.DEFAULT_KEY)) { getExtensionClasses(); for (Map.Entry entry : cachedActivates.entrySet()) { String name = entry.getKey(); Activate activate = entry.getValue(); if (isMatchGroup(group, activate.group())) { T ext = getExtension(name); - if (! names.contains(name) - && ! names.contains(Constants.REMOVE_VALUE_PREFIX + name) + if (!names.contains(name) + && !names.contains(Constants.REMOVE_VALUE_PREFIX + name) && isActive(activate, url)) { exts.add(ext); } @@ -210,27 +198,27 @@ && isActive(activate, url)) { Collections.sort(exts, ActivateComparator.COMPARATOR); } List usrs = new ArrayList(); - for (int i = 0; i < names.size(); i ++) { - String name = names.get(i); - if (! name.startsWith(Constants.REMOVE_VALUE_PREFIX) - && ! names.contains(Constants.REMOVE_VALUE_PREFIX + name)) { - if (Constants.DEFAULT_KEY.equals(name)) { - if (usrs.size() > 0) { - exts.addAll(0, usrs); - usrs.clear(); - } - } else { - T ext = getExtension(name); - usrs.add(ext); - } + for (int i = 0; i < names.size(); i++) { + String name = names.get(i); + if (!name.startsWith(Constants.REMOVE_VALUE_PREFIX) + && !names.contains(Constants.REMOVE_VALUE_PREFIX + name)) { + if (Constants.DEFAULT_KEY.equals(name)) { + if (usrs.size() > 0) { + exts.addAll(0, usrs); + usrs.clear(); + } + } else { + T ext = getExtension(name); + usrs.add(ext); + } } } if (usrs.size() > 0) { - exts.addAll(usrs); + exts.addAll(usrs); } return exts; } - + private boolean isMatchGroup(String group, String[] groups) { if (group == null || group.length() == 0) { return true; @@ -244,7 +232,7 @@ private boolean isMatchGroup(String group, String[] groups) { } return false; } - + private boolean isActive(Activate activate, URL url) { String[] keys = activate.value(); if (keys == null || keys.length == 0) { @@ -265,7 +253,7 @@ private boolean isActive(Activate activate, URL url) { /** * 返回扩展点实例,如果没有指定的扩展点或是还没加载(即实例化)则返回null。注意:此方法不会触发扩展点的加载。 - *

+ *

* 一般应该调用{@link #getExtension(String)}方法获得扩展,这个方法会触发扩展点加载。 * * @see #getExtension(String) @@ -284,7 +272,7 @@ public T getLoadedExtension(String name) { /** * 返回已经加载的扩展点的名字。 - *

+ *

* 一般应该调用{@link #getSupportedExtensions()}方法获得扩展,这个方法会返回所有的扩展点。 * * @see #getSupportedExtensions() @@ -299,99 +287,98 @@ public Set getLoadedExtensions() { * @param name * @return */ - @SuppressWarnings("unchecked") - public T getExtension(String name) { - if (name == null || name.length() == 0) - throw new IllegalArgumentException("Extension name == null"); - if ("true".equals(name)) { - return getDefaultExtension(); - } - Holder holder = cachedInstances.get(name); - if (holder == null) { - cachedInstances.putIfAbsent(name, new Holder()); - holder = cachedInstances.get(name); - } - Object instance = holder.get(); - if (instance == null) { - synchronized (holder) { - instance = holder.get(); - if (instance == null) { - instance = createExtension(name); - holder.set(instance); - } - } - } - return (T) instance; - } - - /** - * 返回缺省的扩展,如果没有设置则返回null。 - */ - public T getDefaultExtension() { - getExtensionClasses(); - if(null == cachedDefaultName || cachedDefaultName.length() == 0 + @SuppressWarnings("unchecked") + public T getExtension(String name) { + if (name == null || name.length() == 0) + throw new IllegalArgumentException("Extension name == null"); + if ("true".equals(name)) { + return getDefaultExtension(); + } + Holder holder = cachedInstances.get(name); + if (holder == null) { + cachedInstances.putIfAbsent(name, new Holder()); + holder = cachedInstances.get(name); + } + Object instance = holder.get(); + if (instance == null) { + synchronized (cachedInstances) { + instance = holder.get(); + if (instance == null) { + instance = createExtension(name); + holder.set(instance); + } + } + } + return (T) instance; + } + + /** + * 返回缺省的扩展,如果没有设置则返回null。 + */ + public T getDefaultExtension() { + getExtensionClasses(); + if (null == cachedDefaultName || cachedDefaultName.length() == 0 || "true".equals(cachedDefaultName)) { return null; } return getExtension(cachedDefaultName); - } - - public boolean hasExtension(String name) { - if (name == null || name.length() == 0) - throw new IllegalArgumentException("Extension name == null"); - try { - return getExtensionClass(name) != null; - } catch (Throwable t) { - return false; - } - } - - public Set getSupportedExtensions() { + } + + public boolean hasExtension(String name) { + if (name == null || name.length() == 0) + throw new IllegalArgumentException("Extension name == null"); + try { + return getExtensionClass(name) != null; + } catch (Throwable t) { + return false; + } + } + + public Set getSupportedExtensions() { Map> clazzes = getExtensionClasses(); return Collections.unmodifiableSet(new TreeSet(clazzes.keySet())); } - - /** - * 返回缺省的扩展点名,如果没有设置缺省则返回null。 - */ - public String getDefaultExtensionName() { - getExtensionClasses(); - return cachedDefaultName; - } + + /** + * 返回缺省的扩展点名,如果没有设置缺省则返回null。 + */ + public String getDefaultExtensionName() { + getExtensionClasses(); + return cachedDefaultName; + } /** * 编程方式添加新扩展点。 * - * @param name 扩展点名 + * @param name 扩展点名 * @param clazz 扩展点类 * @throws IllegalStateException 要添加扩展点名已经存在。 */ public void addExtension(String name, Class clazz) { getExtensionClasses(); // load classes - if(!type.isAssignableFrom(clazz)) { + if (!type.isAssignableFrom(clazz)) { throw new IllegalStateException("Input type " + clazz + "not implement Extension " + type); } - if(clazz.isInterface()) { + if (clazz.isInterface()) { throw new IllegalStateException("Input type " + clazz + "can not be interface!"); } - if(!clazz.isAnnotationPresent(Adaptive.class)) { - if(StringUtils.isBlank(name)) { + if (!clazz.isAnnotationPresent(Adaptive.class)) { + if (StringUtils.isBlank(name)) { throw new IllegalStateException("Extension name is blank (Extension " + type + ")!"); } - if(cachedClasses.get().containsKey(name)) { + if (cachedClasses.get().containsKey(name)) { throw new IllegalStateException("Extension name " + name + " already existed(Extension " + type + ")!"); } cachedNames.put(clazz, name); cachedClasses.get().put(name, clazz); - } - else { - if(cachedAdaptiveClass != null) { + } else { + if (cachedAdaptiveClass != null) { throw new IllegalStateException("Adaptive Extension already existed(Extension " + type + ")!"); } @@ -402,7 +389,7 @@ public void addExtension(String name, Class clazz) { /** * 编程方式添加替换已有扩展点。 * - * @param name 扩展点名 + * @param name 扩展点名 * @param clazz 扩展点类 * @throws IllegalStateException 要添加扩展点名已经存在。 * @deprecated 不推荐应用使用,一般只在测试时可以使用 @@ -411,20 +398,20 @@ public void addExtension(String name, Class clazz) { public void replaceExtension(String name, Class clazz) { getExtensionClasses(); // load classes - if(!type.isAssignableFrom(clazz)) { + if (!type.isAssignableFrom(clazz)) { throw new IllegalStateException("Input type " + clazz + "not implement Extension " + type); } - if(clazz.isInterface()) { + if (clazz.isInterface()) { throw new IllegalStateException("Input type " + clazz + "can not be interface!"); } - if(!clazz.isAnnotationPresent(Adaptive.class)) { - if(StringUtils.isBlank(name)) { + if (!clazz.isAnnotationPresent(Adaptive.class)) { + if (StringUtils.isBlank(name)) { throw new IllegalStateException("Extension name is blank (Extension " + type + ")!"); } - if(!cachedClasses.get().containsKey(name)) { + if (!cachedClasses.get().containsKey(name)) { throw new IllegalStateException("Extension name " + name + " not existed(Extension " + type + ")!"); } @@ -432,9 +419,8 @@ public void replaceExtension(String name, Class clazz) { cachedNames.put(clazz, name); cachedClasses.get().put(name, clazz); cachedInstances.remove(name); - } - else { - if(cachedAdaptiveClass == null) { + } else { + if (cachedAdaptiveClass == null) { throw new IllegalStateException("Adaptive Extension not existed(Extension " + type + ")!"); } @@ -447,7 +433,7 @@ public void replaceExtension(String name, Class clazz) { public T getAdaptiveExtension() { Object instance = cachedAdaptiveInstance.get(); if (instance == null) { - if(createAdaptiveInstanceError == null) { + if (createAdaptiveInstanceError == null) { synchronized (cachedAdaptiveInstance) { instance = cachedAdaptiveInstance.get(); if (instance == null) { @@ -460,8 +446,7 @@ public T getAdaptiveExtension() { } } } - } - else { + } else { throw new IllegalStateException("fail to create adaptive instance: " + createAdaptiveInstanceError.toString(), createAdaptiveInstanceError); } } @@ -480,12 +465,12 @@ private IllegalStateException findException(String name) { int i = 1; for (Map.Entry entry : exceptions.entrySet()) { - if(i == 1) { + if (i == 1) { buf.append(", possible causes: "); } buf.append("\r\n("); - buf.append(i ++); + buf.append(i++); buf.append(") "); buf.append(entry.getKey()); buf.append(":\r\n"); @@ -519,7 +504,7 @@ private T createExtension(String name) { type + ") could not be instantiated: " + t.getMessage(), t); } } - + private T injectExtension(T instance) { try { if (objectFactory != null) { @@ -546,19 +531,19 @@ private T injectExtension(T instance) { } return instance; } - - private Class getExtensionClass(String name) { - if (type == null) - throw new IllegalArgumentException("Extension type == null"); - if (name == null) - throw new IllegalArgumentException("Extension name == null"); - Class clazz = getExtensionClasses().get(name); - if (clazz == null) - throw new IllegalStateException("No such extension \"" + name + "\" for " + type.getName() + "!"); - return clazz; - } - - private Map> getExtensionClasses() { + + private Class getExtensionClass(String name) { + if (type == null) + throw new IllegalArgumentException("Extension type == null"); + if (name == null) + throw new IllegalArgumentException("Extension name == null"); + Class clazz = getExtensionClasses().get(name); + if (clazz == null) + throw new IllegalStateException("No such extension \"" + name + "\" for " + type.getName() + "!"); + return clazz; + } + + private Map> getExtensionClasses() { Map> classes = cachedClasses.get(); if (classes == null) { synchronized (cachedClasses) { @@ -570,30 +555,30 @@ private Map> getExtensionClasses() { } } return classes; - } + } // 此方法已经getExtensionClasses方法同步过。 private Map> loadExtensionClasses() { final SPI defaultAnnotation = type.getAnnotation(SPI.class); - if(defaultAnnotation != null) { + if (defaultAnnotation != null) { String value = defaultAnnotation.value(); - if(value != null && (value = value.trim()).length() > 0) { + if (value != null && (value = value.trim()).length() > 0) { String[] names = NAME_SEPARATOR.split(value); - if(names.length > 1) { + if (names.length > 1) { throw new IllegalStateException("more than 1 default extension name on extension " + type.getName() + ": " + Arrays.toString(names)); } - if(names.length == 1) cachedDefaultName = names[0]; + if (names.length == 1) cachedDefaultName = names[0]; } } - + Map> extensionClasses = new HashMap>(); loadFile(extensionClasses, DUBBO_INTERNAL_DIRECTORY); loadFile(extensionClasses, DUBBO_DIRECTORY); loadFile(extensionClasses, SERVICES_DIRECTORY); return extensionClasses; } - + private void loadFile(Map> extensionClasses, String dir) { String fileName = dir + type.getName(); try { @@ -625,15 +610,15 @@ private void loadFile(Map> extensionClasses, String dir) { } if (line.length() > 0) { Class clazz = Class.forName(line, true, classLoader); - if (! type.isAssignableFrom(clazz)) { + if (!type.isAssignableFrom(clazz)) { throw new IllegalStateException("Error when load extension class(interface: " + - type + ", class line: " + clazz.getName() + "), class " + type + ", class line: " + clazz.getName() + "), class " + clazz.getName() + "is not subtype of interface."); } if (clazz.isAnnotationPresent(Adaptive.class)) { - if(cachedAdaptiveClass == null) { + if (cachedAdaptiveClass == null) { cachedAdaptiveClass = clazz; - } else if (! cachedAdaptiveClass.equals(clazz)) { + } else if (!cachedAdaptiveClass.equals(clazz)) { throw new IllegalStateException("More than 1 adaptive class found: " + cachedAdaptiveClass.getClass().getName() + ", " + clazz.getClass().getName()); @@ -667,7 +652,7 @@ private void loadFile(Map> extensionClasses, String dir) { cachedActivates.put(names[0], activate); } for (String n : names) { - if (! cachedNames.containsKey(clazz)) { + if (!cachedNames.containsKey(clazz)) { cachedNames.put(clazz, n); } Class c = extensionClasses.get(n); @@ -692,7 +677,7 @@ private void loadFile(Map> extensionClasses, String dir) { } } catch (Throwable t) { logger.error("Exception when load extension class(interface: " + - type + ", class file: " + url + ") in " + url, t); + type + ", class file: " + url + ") in " + url, t); } } // end of while urls } @@ -701,7 +686,7 @@ private void loadFile(Map> extensionClasses, String dir) { type + ", description file: " + fileName + ").", t); } } - + @SuppressWarnings("deprecation") private String findAnnotationName(Class clazz) { com.alibaba.dubbo.common.Extension extension = clazz.getAnnotation(com.alibaba.dubbo.common.Extension.class); @@ -714,7 +699,7 @@ private String findAnnotationName(Class clazz) { } return extension.value(); } - + @SuppressWarnings("unchecked") private T createAdaptiveExtension() { try { @@ -723,7 +708,7 @@ private T createAdaptiveExtension() { throw new IllegalStateException("Can not create adaptive extenstion " + type + ", cause: " + e.getMessage(), e); } } - + private Class getAdaptiveExtensionClass() { getExtensionClasses(); if (cachedAdaptiveClass != null) { @@ -731,32 +716,32 @@ private Class getAdaptiveExtensionClass() { } return cachedAdaptiveClass = createAdaptiveExtensionClass(); } - + private Class createAdaptiveExtensionClass() { String code = createAdaptiveExtensionClassCode(); ClassLoader classLoader = findClassLoader(); com.alibaba.dubbo.common.compiler.Compiler compiler = ExtensionLoader.getExtensionLoader(com.alibaba.dubbo.common.compiler.Compiler.class).getAdaptiveExtension(); return compiler.compile(code, classLoader); } - + private String createAdaptiveExtensionClassCode() { - StringBuilder codeBuidler = new StringBuilder(); + StringBuilder codeBuilder = new StringBuilder(); Method[] methods = type.getMethods(); boolean hasAdaptiveAnnotation = false; - for(Method m : methods) { - if(m.isAnnotationPresent(Adaptive.class)) { + for (Method m : methods) { + if (m.isAnnotationPresent(Adaptive.class)) { hasAdaptiveAnnotation = true; break; } } // 完全没有Adaptive方法,则不需要生成Adaptive类 - if(! hasAdaptiveAnnotation) + if (!hasAdaptiveAnnotation) throw new IllegalStateException("No adaptive method on extension " + type.getName() + ", refuse to create the adaptive class!"); - - codeBuidler.append("package " + type.getPackage().getName() + ";"); - codeBuidler.append("\nimport " + ExtensionLoader.class.getName() + ";"); - codeBuidler.append("\npublic class " + type.getSimpleName() + "$Adpative" + " implements " + type.getCanonicalName() + " {"); - + + codeBuilder.append("package " + type.getPackage().getName() + ";"); + codeBuilder.append("\nimport " + ExtensionLoader.class.getName() + ";"); + codeBuilder.append("\npublic class " + type.getSimpleName() + "$Adpative" + " implements " + type.getCanonicalName() + " {"); + for (Method method : methods) { Class rt = method.getReturnType(); Class[] pts = method.getParameterTypes(); @@ -780,16 +765,15 @@ private String createAdaptiveExtensionClassCode() { if (urlTypeIndex != -1) { // Null Point check String s = String.format("\nif (arg%d == null) throw new IllegalArgumentException(\"url == null\");", - urlTypeIndex); + urlTypeIndex); code.append(s); - - s = String.format("\n%s url = arg%d;", URL.class.getName(), urlTypeIndex); + + s = String.format("\n%s url = arg%d;", URL.class.getName(), urlTypeIndex); code.append(s); } // 参数没有URL类型 else { String attribMethod = null; - // 找到参数的URL属性 LBL_PTS: for (int i = 0; i < pts.length; ++i) { @@ -807,81 +791,78 @@ private String createAdaptiveExtensionClassCode() { } } } - if(attribMethod == null) { + if (attribMethod == null) { throw new IllegalStateException("fail to create adative class for interface " + type.getName() - + ": not found url parameter or url attribute in parameters of method " + method.getName()); + + ": not found url parameter or url attribute in parameters of method " + method.getName()); } - + // Null point check String s = String.format("\nif (arg%d == null) throw new IllegalArgumentException(\"%s argument == null\");", - urlTypeIndex, pts[urlTypeIndex].getName()); + urlTypeIndex, pts[urlTypeIndex].getName()); code.append(s); s = String.format("\nif (arg%d.%s() == null) throw new IllegalArgumentException(\"%s argument %s() == null\");", - urlTypeIndex, attribMethod, pts[urlTypeIndex].getName(), attribMethod); + urlTypeIndex, attribMethod, pts[urlTypeIndex].getName(), attribMethod); code.append(s); - s = String.format("%s url = arg%d.%s();",URL.class.getName(), urlTypeIndex, attribMethod); + s = String.format("%s url = arg%d.%s();", URL.class.getName(), urlTypeIndex, attribMethod); code.append(s); } - + String[] value = adaptiveAnnotation.value(); // 没有设置Key,则使用“扩展点接口名的点分隔 作为Key - if(value.length == 0) { + if (value.length == 0) { char[] charArray = type.getSimpleName().toCharArray(); StringBuilder sb = new StringBuilder(128); for (int i = 0; i < charArray.length; i++) { - if(Character.isUpperCase(charArray[i])) { - if(i != 0) { + if (Character.isUpperCase(charArray[i])) { + if (i != 0) { sb.append("."); } sb.append(Character.toLowerCase(charArray[i])); - } - else { + } else { sb.append(charArray[i]); } } - value = new String[] {sb.toString()}; + value = new String[]{sb.toString()}; } - + boolean hasInvocation = false; for (int i = 0; i < pts.length; ++i) { if (pts[i].getName().equals("com.alibaba.dubbo.rpc.Invocation")) { // Null Point check String s = String.format("\nif (arg%d == null) throw new IllegalArgumentException(\"invocation == null\");", i); code.append(s); - s = String.format("\nString methodName = arg%d.getMethodName();", i); + s = String.format("\nString methodName = arg%d.getMethodName();", i); code.append(s); hasInvocation = true; break; } } - + String defaultExtName = cachedDefaultName; String getNameCode = null; for (int i = value.length - 1; i >= 0; --i) { - if(i == value.length - 1) { - if(null != defaultExtName) { - if(!"protocol".equals(value[i])) - if (hasInvocation) + if (i == value.length - 1) { + if (null != defaultExtName) { + if (!"protocol".equals(value[i])) + if (hasInvocation) getNameCode = String.format("url.getMethodParameter(methodName, \"%s\", \"%s\")", value[i], defaultExtName); else getNameCode = String.format("url.getParameter(\"%s\", \"%s\")", value[i], defaultExtName); else getNameCode = String.format("( url.getProtocol() == null ? \"%s\" : url.getProtocol() )", defaultExtName); - } - else { - if(!"protocol".equals(value[i])) - if (hasInvocation) + } else { + if (!"protocol".equals(value[i])) + if (hasInvocation) getNameCode = String.format("url.getMethodParameter(methodName, \"%s\", \"%s\")", value[i], defaultExtName); else getNameCode = String.format("url.getParameter(\"%s\")", value[i]); else getNameCode = "url.getProtocol()"; } - } - else { - if(!"protocol".equals(value[i])) - if (hasInvocation) + } else { + if (!"protocol".equals(value[i])) + if (hasInvocation) getNameCode = String.format("url.getMethodParameter(methodName, \"%s\", \"%s\")", value[i], defaultExtName); else getNameCode = String.format("url.getParameter(\"%s\", %s)", value[i], getNameCode); @@ -892,14 +873,14 @@ private String createAdaptiveExtensionClassCode() { code.append("\nString extName = ").append(getNameCode).append(";"); // check extName == null? String s = String.format("\nif(extName == null) " + - "throw new IllegalStateException(\"Fail to get extension(%s) name from url(\" + url.toString() + \") use keys(%s)\");", + "throw new IllegalStateException(\"Fail to get extension(%s) name from url(\" + url.toString() + \") use keys(%s)\");", type.getName(), Arrays.toString(value)); code.append(s); - + s = String.format("\n%s extension = (% 0) { - codeBuidler.append(", "); + codeBuilder.append(", "); } - codeBuidler.append(pts[i].getCanonicalName()); - codeBuidler.append(" "); - codeBuidler.append("arg" + i); + codeBuilder.append(pts[i].getCanonicalName()); + codeBuilder.append(" "); + codeBuilder.append("arg" + i); } - codeBuidler.append(")"); + codeBuilder.append(")"); if (ets.length > 0) { - codeBuidler.append(" throws "); - for (int i = 0; i < ets.length; i ++) { + codeBuilder.append(" throws "); + for (int i = 0; i < ets.length; i++) { if (i > 0) { - codeBuidler.append(", "); + codeBuilder.append(", "); } - codeBuidler.append(pts[i].getCanonicalName()); + codeBuilder.append(pts[i].getCanonicalName()); } } - codeBuidler.append(" {"); - codeBuidler.append(code.toString()); - codeBuidler.append("\n}"); + codeBuilder.append(" {"); + codeBuilder.append(code.toString()); + codeBuilder.append("\n}"); } - codeBuidler.append("\n}"); + codeBuilder.append("\n}"); if (logger.isDebugEnabled()) { - logger.debug(codeBuidler.toString()); + logger.debug(codeBuilder.toString()); } - return codeBuidler.toString(); + return codeBuilder.toString(); } private static ClassLoader findClassLoader() { - return ExtensionLoader.class.getClassLoader(); + return ExtensionLoader.class.getClassLoader(); } - + @Override public String toString() { return this.getClass().getName() + "[" + type.getName() + "]"; } - + } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/extension/support/ActivateComparator.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/extension/support/ActivateComparator.java index 16351fbbbec..edb5de16dc1 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/extension/support/ActivateComparator.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/extension/support/ActivateComparator.java @@ -22,7 +22,7 @@ import com.alibaba.dubbo.common.extension.SPI; /** - * OrderComparetor + * OrderComparator * * @author william.liangf */ diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/logger/LoggerFactory.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/logger/LoggerFactory.java index 3bb6addc10e..274bac892ea 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/logger/LoggerFactory.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/logger/LoggerFactory.java @@ -1,31 +1,31 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.common.logger; -import java.io.File; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; - -import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.common.logger.jcl.JclLoggerAdapter; -import com.alibaba.dubbo.common.logger.jdk.JdkLoggerAdapter; -import com.alibaba.dubbo.common.logger.log4j.Log4jLoggerAdapter; -import com.alibaba.dubbo.common.logger.slf4j.Slf4jLoggerAdapter; -import com.alibaba.dubbo.common.logger.support.FailsafeLogger; +import java.io.File; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; + +import com.alibaba.dubbo.common.extension.ExtensionLoader; +import com.alibaba.dubbo.common.logger.jcl.JclLoggerAdapter; +import com.alibaba.dubbo.common.logger.jdk.JdkLoggerAdapter; +import com.alibaba.dubbo.common.logger.log4j.Log4jLoggerAdapter; +import com.alibaba.dubbo.common.logger.slf4j.Slf4jLoggerAdapter; +import com.alibaba.dubbo.common.logger.support.FailsafeLogger; /** * 日志输出器工厂 @@ -37,42 +37,41 @@ public class LoggerFactory { private LoggerFactory() { } - private static volatile LoggerAdapter LOGGER_ADAPTER; - + private static volatile LoggerAdapter LOGGER_ADAPTER; + private static final ConcurrentMap LOGGERS = new ConcurrentHashMap(); - // 查找常用的日志框架 - static { - String logger = System.getProperty("dubbo.application.logger"); - if ("slf4j".equals(logger)) { - setLoggerAdapter(new Slf4jLoggerAdapter()); - } else if ("jcl".equals(logger)) { - setLoggerAdapter(new JclLoggerAdapter()); - } else if ("log4j".equals(logger)) { - setLoggerAdapter(new Log4jLoggerAdapter()); - } else if ("jdk".equals(logger)) { - setLoggerAdapter(new JdkLoggerAdapter()); - } else { - try { - setLoggerAdapter(new Log4jLoggerAdapter()); - } catch (Throwable e1) { - try { - setLoggerAdapter(new Slf4jLoggerAdapter()); - } catch (Throwable e2) { - try { - setLoggerAdapter(new JclLoggerAdapter()); - } catch (Throwable e3) { - setLoggerAdapter(new JdkLoggerAdapter()); - } - } - } + static { + String logger = System.getProperty("dubbo.application.logger"); + if ("slf4j".equals(logger)) { + setLoggerAdapter(new Slf4jLoggerAdapter()); + } else if ("jcl".equals(logger)) { + setLoggerAdapter(new JclLoggerAdapter()); + } else if ("log4j".equals(logger)) { + setLoggerAdapter(new Log4jLoggerAdapter()); + } else if ("jdk".equals(logger)) { + setLoggerAdapter(new JdkLoggerAdapter()); + } else { + try { + setLoggerAdapter(new Log4jLoggerAdapter()); + } catch (Throwable e1) { + try { + setLoggerAdapter(new Slf4jLoggerAdapter()); + } catch (Throwable e2) { + try { + setLoggerAdapter(new JclLoggerAdapter()); + } catch (Throwable e3) { + setLoggerAdapter(new JdkLoggerAdapter()); + } + } + } } - } - - public static void setLoggerAdapter(String loggerAdapter) { - if (loggerAdapter != null && loggerAdapter.length() > 0) { - setLoggerAdapter(ExtensionLoader.getExtensionLoader(LoggerAdapter.class).getExtension(loggerAdapter)); - } + } + + public static void setLoggerAdapter(String loggerAdapter) { + if (loggerAdapter != null && loggerAdapter.length() > 0) { + setLoggerAdapter(ExtensionLoader.getExtensionLoader(LoggerAdapter.class).getExtension(loggerAdapter)); + } } /** @@ -85,9 +84,9 @@ public static void setLoggerAdapter(LoggerAdapter loggerAdapter) { if (loggerAdapter != null) { Logger logger = loggerAdapter.getLogger(LoggerFactory.class.getName()); logger.info("using logger: " + loggerAdapter.getClass().getName()); - LoggerFactory.LOGGER_ADAPTER = loggerAdapter; - for (Map.Entry entry : LOGGERS.entrySet()) { - entry.getValue().setLogger(LOGGER_ADAPTER.getLogger(entry.getKey())); + LoggerFactory.LOGGER_ADAPTER = loggerAdapter; + for (Map.Entry entry : LOGGERS.entrySet()) { + entry.getValue().setLogger(LOGGER_ADAPTER.getLogger(entry.getKey())); } } } @@ -99,12 +98,12 @@ public static void setLoggerAdapter(LoggerAdapter loggerAdapter) { * 分类键 * @return 日志输出器, 后验条件: 不返回null. */ - public static Logger getLogger(Class key) { - FailsafeLogger logger = LOGGERS.get(key.getName()); - if (logger == null) { - LOGGERS.putIfAbsent(key.getName(), new FailsafeLogger(LOGGER_ADAPTER.getLogger(key))); - logger = LOGGERS.get(key.getName()); - } + public static Logger getLogger(Class key) { + FailsafeLogger logger = LOGGERS.get(key.getName()); + if (logger == null) { + LOGGERS.putIfAbsent(key.getName(), new FailsafeLogger(LOGGER_ADAPTER.getLogger(key))); + logger = LOGGERS.get(key.getName()); + } return logger; } @@ -116,11 +115,11 @@ public static Logger getLogger(Class key) { * @return 日志输出器, 后验条件: 不返回null. */ public static Logger getLogger(String key) { - FailsafeLogger logger = LOGGERS.get(key); - if (logger == null) { - LOGGERS.putIfAbsent(key, new FailsafeLogger(LOGGER_ADAPTER.getLogger(key))); - logger = LOGGERS.get(key); - } + FailsafeLogger logger = LOGGERS.get(key); + if (logger == null) { + LOGGERS.putIfAbsent(key, new FailsafeLogger(LOGGER_ADAPTER.getLogger(key))); + logger = LOGGERS.get(key); + } return logger; } diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/serialize/support/hessian/Hessian2ObjectInput.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/serialize/support/hessian/Hessian2ObjectInput.java index c3db30038af..534a8859099 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/serialize/support/hessian/Hessian2ObjectInput.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/serialize/support/hessian/Hessian2ObjectInput.java @@ -1,102 +1,89 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.common.serialize.support.hessian; -import java.io.IOException; -import java.io.InputStream; -import java.lang.reflect.Type; - import com.alibaba.com.caucho.hessian.io.Hessian2Input; import com.alibaba.dubbo.common.serialize.ObjectInput; +import java.io.IOException; +import java.io.InputStream; +import java.lang.reflect.Type; + /** * Hessian2 Object input. - * + * * @author qian.lei */ -public class Hessian2ObjectInput implements ObjectInput -{ - private final Hessian2Input mH2i; - - public Hessian2ObjectInput(InputStream is) - { - mH2i = new Hessian2Input(is); - mH2i.setSerializerFactory(Hessian2SerializerFactory.SERIALIZER_FACTORY); - } - - public boolean readBool() throws IOException - { - return mH2i.readBoolean(); - } - - public byte readByte() throws IOException - { - return (byte)mH2i.readInt(); - } - - public short readShort() throws IOException - { - return (short)mH2i.readInt(); - } - - public int readInt() throws IOException - { - return mH2i.readInt(); - } - - public long readLong() throws IOException - { - return mH2i.readLong(); - } - - public float readFloat() throws IOException - { - return (float)mH2i.readDouble(); - } - - public double readDouble() throws IOException - { - return mH2i.readDouble(); - } - - public byte[] readBytes() throws IOException - { - return mH2i.readBytes(); - } - - public String readUTF() throws IOException - { - return mH2i.readString(); - } - - public Object readObject() throws IOException - { - return mH2i.readObject(); - } - - @SuppressWarnings("unchecked") - public T readObject(Class cls) throws IOException, - ClassNotFoundException { - return (T) mH2i.readObject(cls); - } - - public T readObject(Class cls, Type type) throws IOException,ClassNotFoundException - { - return readObject(cls); - } +public class Hessian2ObjectInput implements ObjectInput { + private final Hessian2Input mH2i; + + public Hessian2ObjectInput(InputStream is) { + mH2i = new Hessian2Input(is); + mH2i.setSerializerFactory(Hessian2SerializerFactory.SERIALIZER_FACTORY); + } + + public boolean readBool() throws IOException { + return mH2i.readBoolean(); + } + + public byte readByte() throws IOException { + return (byte) mH2i.readInt(); + } + + public short readShort() throws IOException { + return (short) mH2i.readInt(); + } + + public int readInt() throws IOException { + return mH2i.readInt(); + } + + public long readLong() throws IOException { + return mH2i.readLong(); + } + + public float readFloat() throws IOException { + return (float) mH2i.readDouble(); + } + + public double readDouble() throws IOException { + return mH2i.readDouble(); + } + + public byte[] readBytes() throws IOException { + return mH2i.readBytes(); + } + + public String readUTF() throws IOException { + return mH2i.readString(); + } + + public Object readObject() throws IOException { + return mH2i.readObject(); + } + + @SuppressWarnings("unchecked") + public T readObject(Class cls) throws IOException, + ClassNotFoundException { + return (T) mH2i.readObject(cls); + } + + public T readObject(Class cls, Type type) throws IOException, ClassNotFoundException { + return readObject(cls); + } } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/threadpool/support/fixed/FixedThreadPool.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/threadpool/support/fixed/FixedThreadPool.java index cdd2dce1759..a5a6925e905 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/threadpool/support/fixed/FixedThreadPool.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/threadpool/support/fixed/FixedThreadPool.java @@ -15,23 +15,19 @@ */ package com.alibaba.dubbo.common.threadpool.support.fixed; -import java.util.concurrent.Executor; -import java.util.concurrent.LinkedBlockingQueue; -import java.util.concurrent.SynchronousQueue; -import java.util.concurrent.ThreadPoolExecutor; -import java.util.concurrent.TimeUnit; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.threadpool.ThreadPool; import com.alibaba.dubbo.common.threadpool.support.AbortPolicyWithReport; import com.alibaba.dubbo.common.utils.NamedThreadFactory; +import java.util.concurrent.*; + /** * 此线程池启动时即创建固定大小的线程数,不做任何伸缩,来源于:Executors.newFixedThreadPool() - * - * @see java.util.concurrent.Executors#newFixedThreadPool(int) + * * @author william.liangf + * @see java.util.concurrent.Executors#newFixedThreadPool(int) */ public class FixedThreadPool implements ThreadPool { @@ -39,11 +35,10 @@ public Executor getExecutor(URL url) { String name = url.getParameter(Constants.THREAD_NAME_KEY, Constants.DEFAULT_THREAD_NAME); int threads = url.getParameter(Constants.THREADS_KEY, Constants.DEFAULT_THREADS); int queues = url.getParameter(Constants.QUEUES_KEY, Constants.DEFAULT_QUEUES); - return new ThreadPoolExecutor(threads, threads, 0, TimeUnit.MILLISECONDS, - queues == 0 ? new SynchronousQueue() : - (queues < 0 ? new LinkedBlockingQueue() - : new LinkedBlockingQueue(queues)), - new NamedThreadFactory(name, true), new AbortPolicyWithReport(name, url)); + return new ThreadPoolExecutor(threads, threads, 0, TimeUnit.MILLISECONDS, + queues == 0 ? new SynchronousQueue() : + (queues < 0 ? new LinkedBlockingQueue() + : new LinkedBlockingQueue(queues)), + new NamedThreadFactory(name, true), new AbortPolicyWithReport(name, url)); } - } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/MethodCache.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/MethodCache.java new file mode 100644 index 00000000000..307c4ce673b --- /dev/null +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/MethodCache.java @@ -0,0 +1,43 @@ +package com.alibaba.dubbo.common.utils; + +import java.lang.reflect.Method; +import java.util.Arrays; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; + +public class MethodCache { + + private final Map cachedMethods = new ConcurrentHashMap(32); + + private final Object lock = new Object(); + + private MethodCache() { + } + + public static MethodCache newCache() { + return new MethodCache(); + } + + private Integer methodKey(Class targetClass, String methodName, Class[] parameterTypes) { + return methodName.hashCode() + Arrays.hashCode(parameterTypes) + targetClass.hashCode(); + } + + public Method get(Class targetClass, String methodName, Class[] parameterTypes) throws Exception { + Assert.notNull(targetClass, "object must not be null!"); + if (StringUtils.isEmpty(methodName)) { + throw new IllegalArgumentException("methodName must not be null or empty"); + } + Integer methodKey = methodKey(targetClass, methodName, parameterTypes); + Method previouslyCached = cachedMethods.get(methodKey); + if (previouslyCached != null) { + return previouslyCached; + } + synchronized (lock) { + if (!cachedMethods.containsKey(methodKey)) { + Method method = targetClass.getDeclaredMethod(methodName, parameterTypes); + cachedMethods.put(methodKey, method); + } + } + return cachedMethods.get(methodKey); + } +} diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/NamedThreadFactory.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/NamedThreadFactory.java index b9da491d56f..ad9ee5439ac 100755 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/NamedThreadFactory.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/NamedThreadFactory.java @@ -20,50 +20,45 @@ /** * InternalThreadFactory. - * + * * @author qian.lei */ -public class NamedThreadFactory implements ThreadFactory -{ - private static final AtomicInteger POOL_SEQ = new AtomicInteger(1); +public class NamedThreadFactory implements ThreadFactory { - private final AtomicInteger mThreadNum = new AtomicInteger(1); + private static final AtomicInteger POOL_SEQ = new AtomicInteger(1); - private final String mPrefix; + private final AtomicInteger mThreadNum = new AtomicInteger(1); - private final boolean mDaemo; + private final String mPrefix; - private final ThreadGroup mGroup; + private final boolean mDaemo; - public NamedThreadFactory() - { - this("pool-" + POOL_SEQ.getAndIncrement(),false); - } + private final ThreadGroup mGroup; - public NamedThreadFactory(String prefix) - { - this(prefix,false); - } + public NamedThreadFactory() { + this("pool-" + POOL_SEQ.getAndIncrement(), false); + } - public NamedThreadFactory(String prefix,boolean daemo) - { - mPrefix = prefix + "-thread-"; - mDaemo = daemo; + public NamedThreadFactory(String prefix) { + this(prefix, false); + } + + public NamedThreadFactory(String prefix, boolean daemon) { + mPrefix = prefix + "-thread-"; + mDaemo = daemon; SecurityManager s = System.getSecurityManager(); - mGroup = ( s == null ) ? Thread.currentThread().getThreadGroup() : s.getThreadGroup(); - } + mGroup = (s == null) ? Thread.currentThread().getThreadGroup() : s.getThreadGroup(); + } - public Thread newThread(Runnable runnable) - { - String name = mPrefix + mThreadNum.getAndIncrement(); - Thread ret = new Thread(mGroup,runnable,name,0); + public Thread newThread(Runnable runnable) { + String name = mPrefix + mThreadNum.getAndIncrement(); + Thread ret = new Thread(mGroup, runnable, name, 0); ret.setDaemon(mDaemo); return ret; - } + } - public ThreadGroup getThreadGroup() - { - return mGroup; - } + public ThreadGroup getThreadGroup() { + return mGroup; + } } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/NetUtils.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/NetUtils.java index a037544e5ab..4cadb5648a4 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/NetUtils.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/NetUtils.java @@ -15,29 +15,25 @@ */ package com.alibaba.dubbo.common.utils; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.logger.Logger; +import com.alibaba.dubbo.common.logger.LoggerFactory; + import java.io.IOException; -import java.net.InetAddress; -import java.net.InetSocketAddress; -import java.net.NetworkInterface; -import java.net.ServerSocket; -import java.net.UnknownHostException; +import java.net.*; import java.util.Enumeration; import java.util.Map; import java.util.Random; import java.util.regex.Pattern; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; - /** - * IP and Port Helper for RPC, - * + * IP and Port Helper for RPC, + * * @author shawn.qianx */ public class NetUtils { - + private static final Logger logger = LoggerFactory.getLogger(NetUtils.class); public static final String LOCALHOST = "127.0.0.1"; @@ -45,11 +41,11 @@ public class NetUtils { public static final String ANYHOST = "0.0.0.0"; private static final int RND_PORT_START = 30000; - + private static final int RND_PORT_RANGE = 10000; - + private static final Random RANDOM = new Random(System.currentTimeMillis()); - + public static int getRandomPort() { return RND_PORT_START + RANDOM.nextInt(RND_PORT_RANGE); } @@ -66,76 +62,76 @@ public static int getAvailablePort() { if (ss != null) { try { ss.close(); - } catch (IOException e) { + } catch (IOException ignored) { } } } } - + public static int getAvailablePort(int port) { - if (port <= 0) { - return getAvailablePort(); - } - for(int i = port; i < MAX_PORT; i ++) { - ServerSocket ss = null; + if (port <= 0) { + return getAvailablePort(); + } + for (int i = port; i < MAX_PORT; i++) { + ServerSocket ss = null; try { ss = new ServerSocket(i); return i; } catch (IOException e) { - // continue + // continue } finally { if (ss != null) { try { ss.close(); - } catch (IOException e) { + } catch (IOException ignored) { } } } - } - return port; + } + return port; } private static final int MIN_PORT = 0; - + private static final int MAX_PORT = 65535; - - public static boolean isInvalidPort(int port){ + + public static boolean isInvalidPort(int port) { return port > MIN_PORT || port <= MAX_PORT; } private static final Pattern ADDRESS_PATTERN = Pattern.compile("^\\d{1,3}(\\.\\d{1,3}){3}\\:\\d{1,5}$"); - public static boolean isValidAddress(String address){ - return ADDRESS_PATTERN.matcher(address).matches(); + public static boolean isValidAddress(String address) { + return ADDRESS_PATTERN.matcher(address).matches(); } private static final Pattern LOCAL_IP_PATTERN = Pattern.compile("127(\\.\\d{1,3}){3}$"); - + public static boolean isLocalHost(String host) { - return host != null - && (LOCAL_IP_PATTERN.matcher(host).matches() - || host.equalsIgnoreCase("localhost")); + return host != null + && (LOCAL_IP_PATTERN.matcher(host).matches() + || host.equalsIgnoreCase("localhost")); } public static boolean isAnyHost(String host) { return "0.0.0.0".equals(host); } - + public static boolean isInvalidLocalHost(String host) { - return host == null - || host.length() == 0 - || host.equalsIgnoreCase("localhost") - || host.equals("0.0.0.0") - || (LOCAL_IP_PATTERN.matcher(host).matches()); + return host == null + || host.length() == 0 + || host.equalsIgnoreCase("localhost") + || host.equals("0.0.0.0") + || (LOCAL_IP_PATTERN.matcher(host).matches()); } - + public static boolean isValidLocalHost(String host) { - return ! isInvalidLocalHost(host); + return !isInvalidLocalHost(host); } public static InetSocketAddress getLocalSocketAddress(String host, int port) { - return isInvalidLocalHost(host) ? - new InetSocketAddress(port) : new InetSocketAddress(host, port); + return isInvalidLocalHost(host) ? + new InetSocketAddress(port) : new InetSocketAddress(host, port); } private static final Pattern IP_PATTERN = Pattern.compile("\\d{1,3}(\\.\\d{1,3}){3,5}$"); @@ -144,17 +140,17 @@ private static boolean isValidAddress(InetAddress address) { if (address == null || address.isLoopbackAddress()) return false; String name = address.getHostAddress(); - return (name != null - && ! ANYHOST.equals(name) - && ! LOCALHOST.equals(name) + return (name != null + && !ANYHOST.equals(name) + && !LOCALHOST.equals(name) && IP_PATTERN.matcher(name).matches()); } - - public static String getLocalHost(){ + + public static String getLocalHost() { InetAddress address = getLocalAddress(); return address == null ? LOCALHOST : address.getHostAddress(); } - + public static String filterLocalHost(String host) { if (host == null || host.length() == 0) { return host; @@ -171,17 +167,17 @@ public static String filterLocalHost(String host) { } } else { if (NetUtils.isInvalidLocalHost(host)) { - return NetUtils.getLocalHost(); - } + return NetUtils.getLocalHost(); + } } - return host; + return host; } - + private static volatile InetAddress LOCAL_ADDRESS = null; /** * 遍历本地网卡,返回第一个合理的IP。 - * + * * @return 本地网卡IP */ public static InetAddress getLocalAddress() { @@ -191,12 +187,12 @@ public static InetAddress getLocalAddress() { LOCAL_ADDRESS = localAddress; return localAddress; } - + public static String getLogHost() { InetAddress address = LOCAL_ADDRESS; return address == null ? LOCALHOST : address.getHostAddress(); } - + private static InetAddress getLocalAddress0() { InetAddress localAddress = null; try { @@ -214,16 +210,14 @@ private static InetAddress getLocalAddress0() { try { NetworkInterface network = interfaces.nextElement(); Enumeration addresses = network.getInetAddresses(); - if (addresses != null) { - while (addresses.hasMoreElements()) { - try { - InetAddress address = addresses.nextElement(); - if (isValidAddress(address)) { - return address; - } - } catch (Throwable e) { - logger.warn("Failed to retriving ip address, " + e.getMessage(), e); + while (addresses.hasMoreElements()) { + try { + InetAddress address = addresses.nextElement(); + if (isValidAddress(address)) { + return address; } + } catch (Throwable e) { + logger.warn("Failed to retriving ip address, " + e.getMessage(), e); } } } catch (Throwable e) { @@ -237,39 +231,39 @@ private static InetAddress getLocalAddress0() { logger.error("Could not get local host ip address, will use 127.0.0.1 instead."); return localAddress; } - + private static final Map hostNameCache = new LRUCache(1000); public static String getHostName(String address) { - try { - int i = address.indexOf(':'); - if (i > -1) { - address = address.substring(0, i); - } - String hostname = hostNameCache.get(address); - if (hostname != null && hostname.length() > 0) { - return hostname; - } - InetAddress inetAddress = InetAddress.getByName(address); - if (inetAddress != null) { - hostname = inetAddress.getHostName(); - hostNameCache.put(address, hostname); - return hostname; - } - } catch (Throwable e) { - // ignore - } - return address; + try { + int i = address.indexOf(':'); + if (i > -1) { + address = address.substring(0, i); + } + String hostname = hostNameCache.get(address); + if (hostname != null && hostname.length() > 0) { + return hostname; + } + InetAddress inetAddress = InetAddress.getByName(address); + if (inetAddress != null) { + hostname = inetAddress.getHostName(); + hostNameCache.put(address, hostname); + return hostname; + } + } catch (Throwable e) { + // ignore + } + return address; } - + /** * @param hostName - * @return ip address or hostName if UnknownHostException + * @return ip address or hostName if UnknownHostException */ public static String getIpByHost(String hostName) { - try{ + try { return InetAddress.getByName(hostName).getHostAddress(); - }catch (UnknownHostException e) { + } catch (UnknownHostException e) { return hostName; } } @@ -277,7 +271,7 @@ public static String getIpByHost(String hostName) { public static String toAddressString(InetSocketAddress address) { return address.getAddress().getHostAddress() + ":" + address.getPort(); } - + public static InetSocketAddress toAddress(String address) { int i = address.indexOf(':'); String host; @@ -291,15 +285,30 @@ public static InetSocketAddress toAddress(String address) { } return new InetSocketAddress(host, port); } - + + public static int toAddressInt(String address) { + if (StringUtils.isEmpty(address)) { + throw new IllegalArgumentException("address must not be null!"); + } + int reVal = 0; + String[] strs = address.split("\\."); + if (strs.length != 4) { + throw new IllegalArgumentException("address is illegal: " + address); + } + for (int i = 0; i < strs.length; i++) { + reVal |= Integer.valueOf(strs[i]) << ((3 - i) * 8); + } + return reVal; + } + public static String toURL(String protocol, String host, int port, String path) { - StringBuilder sb = new StringBuilder(); - sb.append(protocol).append("://"); - sb.append(host).append(':').append(port); - if( path.charAt(0) != '/' ) - sb.append('/'); - sb.append(path); - return sb.toString(); - } - + StringBuilder sb = new StringBuilder(); + sb.append(protocol).append("://"); + sb.append(host).append(':').append(port); + if (path.charAt(0) != '/') + sb.append('/'); + sb.append(path); + return sb.toString(); + } + } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/StringUtils.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/StringUtils.java index 01186b9cf3c..4412dc62c67 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/StringUtils.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/StringUtils.java @@ -15,26 +15,21 @@ */ package com.alibaba.dubbo.common.utils; -import java.io.IOException; -import java.io.PrintWriter; -import java.util.ArrayList; -import java.util.Collection; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.TreeMap; -import java.util.regex.Matcher; -import java.util.regex.Pattern; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.io.UnsafeStringWriter; import com.alibaba.dubbo.common.json.JSON; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; +import java.io.IOException; +import java.io.PrintWriter; +import java.util.*; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + /** * StringUtils - * + * * @author qian.lei */ @@ -42,45 +37,41 @@ public final class StringUtils { private static final Logger logger = LoggerFactory.getLogger(StringUtils.class); - public static final String[] EMPTY_STRING_ARRAY = new String[0]; - - private static final Pattern KVP_PATTERN = Pattern.compile("([_.a-zA-Z0-9][-_.a-zA-Z0-9]*)[=](.*)"); //key value pair pattern. - - private static final Pattern INT_PATTERN = Pattern.compile("^\\d+$"); - - public static boolean isBlank(String str) - { - if( str == null || str.length() == 0 ) - return true; - return false; - } - - /** - * is empty string. - * - * @param str source string. - * @return is empty. - */ - public static boolean isEmpty(String str) - { - if( str == null || str.length() == 0 ) - return true; - return false; - } - - /** - * is not empty string. - * - * @param str source string. - * @return is not empty. - */ - public static boolean isNotEmpty(String str) - { + public static final String[] EMPTY_STRING_ARRAY = new String[0]; + + private static final Pattern KVP_PATTERN = Pattern.compile("([_.a-zA-Z0-9][-_.a-zA-Z0-9]*)[=](.*)"); //key value pair pattern. + + private static final Pattern INT_PATTERN = Pattern.compile("^\\d+$"); + + public static boolean isBlank(String str) { + if (str == null || str.length() == 0) + return true; + return false; + } + + /** + * is empty string. + * + * @param str source string. + * @return is empty. + */ + public static boolean isEmpty(String str) { + if (str == null || str.length() == 0) + return true; + return false; + } + + /** + * is not empty string. + * + * @param str source string. + * @return is not empty. + */ + public static boolean isNotEmpty(String str) { return str != null && str.length() > 0; } - + /** - * * @param s1 * @param s2 * @return equals @@ -92,22 +83,22 @@ public static boolean isEquals(String s1, String s2) { return false; return s1.equals(s2); } - + /** * is integer string. - * + * * @param str * @return is integer */ public static boolean isInteger(String str) { - if (str == null || str.length() == 0) - return false; + if (str == null || str.length() == 0) + return false; return INT_PATTERN.matcher(str).matches(); } - + public static int parseInteger(String str) { - if (! isInteger(str)) - return 0; + if (!isInteger(str)) + return 0; return Integer.parseInt(str); } @@ -119,23 +110,22 @@ public static boolean isJavaIdentifier(String s) { if (s.length() == 0 || !Character.isJavaIdentifierStart(s.charAt(0))) { return false; } - for (int i=1; i list = null; + /** + * translat. + * + * @param src source string. + * @param from src char table. + * @param to target char table. + * @return String. + */ + public static String translat(String src, String from, String to) { + if (isEmpty(src)) return src; + StringBuilder sb = null; + int ix; + char c; + for (int i = 0, len = src.length(); i < len; i++) { + c = src.charAt(i); + ix = from.indexOf(c); + if (ix == -1) { + if (sb != null) + sb.append(c); + } else { + if (sb == null) { + sb = new StringBuilder(len); + sb.append(src, 0, i); + } + if (ix < to.length()) + sb.append(to.charAt(ix)); + } + } + return sb == null ? src : sb.toString(); + } + + /** + * split. + * + * @param ch char. + * @return string array. + */ + public static String[] split(String str, char ch) { + List list = null; char c; - int ix = 0,len=str.length(); - for(int i=0;i(); - list.add(str.substring(ix, i)); - ix = i + 1; - } - } - if( ix > 0 ) - list.add(str.substring(ix)); - return list == null ? EMPTY_STRING_ARRAY : (String[])list.toArray(EMPTY_STRING_ARRAY); - } - - /** - * join string. - * - * @param array String array. - * @return String. - */ - public static String join(String[] array) - { - if( array.length == 0 ) return ""; - StringBuilder sb = new StringBuilder(); - for( String s : array ) - sb.append(s); - return sb.toString(); - } - - /** - * join string like javascript. - * - * @param array String array. - * @param split split - * @return String. - */ - public static String join(String[] array, char split) - { - if( array.length == 0 ) return ""; - StringBuilder sb = new StringBuilder(); - for(int i=0;i 0 ) - sb.append(split); - sb.append(array[i]); - } - return sb.toString(); - } - - /** - * join string like javascript. - * - * @param array String array. - * @param split split - * @return String. - */ - public static String join(String[] array, String split) - { - if( array.length == 0 ) return ""; - StringBuilder sb = new StringBuilder(); - for(int i=0;i 0 ) - sb.append(split); - sb.append(array[i]); - } - return sb.toString(); - } - - public static String join(Collection coll, String split) { - if(coll.isEmpty()) return ""; - - StringBuilder sb = new StringBuilder(); - boolean isFirst = true; - for(String s : coll) { - if(isFirst) isFirst = false; else sb.append(split); - sb.append(s); - } - return sb.toString(); - } - - /** - * parse key-value pair. - * - * @param str string. - * @param itemSeparator item separator. - * @return key-value map; - */ - private static Map parseKeyValuePair(String str, String itemSeparator) - { - String[] tmp = str.split(itemSeparator); - Map map = new HashMap(tmp.length); - for(int i=0;i map = StringUtils.parseQueryString(qs); - return map.get(key); - } - - /** + int ix = 0, len = str.length(); + for (int i = 0; i < len; i++) { + c = str.charAt(i); + if (c == ch) { + if (list == null) + list = new ArrayList(); + list.add(str.substring(ix, i)); + ix = i + 1; + } + } + if (ix > 0) + list.add(str.substring(ix)); + return list == null ? EMPTY_STRING_ARRAY : (String[]) list.toArray(EMPTY_STRING_ARRAY); + } + + /** + * join string. + * + * @param array String array. + * @return String. + */ + public static String join(String[] array) { + if (array.length == 0) return ""; + StringBuilder sb = new StringBuilder(); + for (String s : array) + sb.append(s); + return sb.toString(); + } + + /** + * join string like javascript. + * + * @param array String array. + * @param split split + * @return String. + */ + public static String join(String[] array, char split) { + if (array.length == 0) return ""; + StringBuilder sb = new StringBuilder(); + for (int i = 0; i < array.length; i++) { + if (i > 0) + sb.append(split); + sb.append(array[i]); + } + return sb.toString(); + } + + /** + * join string like javascript. + * + * @param array String array. + * @param split split + * @return String. + */ + public static String join(String[] array, String split) { + if (array.length == 0) return ""; + StringBuilder sb = new StringBuilder(); + for (int i = 0; i < array.length; i++) { + if (i > 0) + sb.append(split); + sb.append(array[i]); + } + return sb.toString(); + } + + public static String join(Collection coll, String split) { + if (coll.isEmpty()) return ""; + + StringBuilder sb = new StringBuilder(); + boolean isFirst = true; + for (String s : coll) { + if (isFirst) isFirst = false; + else sb.append(split); + sb.append(s); + } + return sb.toString(); + } + + /** + * parse key-value pair. + * + * @param str string. + * @param itemSeparator item separator. + * @return key-value map; + */ + private static Map parseKeyValuePair(String str, String itemSeparator) { + String[] tmp = str.split(itemSeparator); + Map map = new HashMap(tmp.length); + for (String aTmp : tmp) { + Matcher matcher = KVP_PATTERN.matcher(aTmp); + if (!matcher.matches()) + continue; + map.put(matcher.group(1), matcher.group(2)); + } + return map; + } + + public static String getQueryStringValue(String qs, String key) { + Map map = StringUtils.parseQueryString(qs); + return map.get(key); + } + + /** * parse query string to Parameters. - * + * * @param qs query string. * @return Parameters instance. */ - public static Map parseQueryString(String qs) - { - if( qs == null || qs.length() == 0 ) + public static Map parseQueryString(String qs) { + if (qs == null || qs.length() == 0) return new HashMap(); - return parseKeyValuePair(qs, "\\&"); - } - - public static String getServiceKey(Map ps) { - StringBuilder buf = new StringBuilder(); + return parseKeyValuePair(qs, "\\&"); + } + + public static String getServiceKey(Map ps) { + StringBuilder buf = new StringBuilder(); String group = ps.get(Constants.GROUP_KEY); - if (group != null && group.length()>0){ + if (group != null && group.length() > 0) { buf.append(group).append("/"); } buf.append(ps.get(Constants.INTERFACE_KEY)); String version = ps.get(Constants.VERSION_KEY); - if (version!= null && version.length()>0){ + if (version != null && version.length() > 0) { buf.append(":").append(version); } return buf.toString(); - } - - public static String toQueryString(Map ps) { - StringBuilder buf = new StringBuilder(); - if (ps != null && ps.size() > 0) { - for (Map.Entry entry : new TreeMap(ps).entrySet()) { - String key = entry.getKey(); - String value = entry.getValue(); - if (key != null && key.length() > 0 - && value != null && value.length() > 0) { - if (buf.length() > 0) { - buf.append("&"); - } - buf.append(key); - buf.append("="); - buf.append(value); - } - } - } - return buf.toString(); - } - - public static String camelToSplitName(String camelName, String split) { - if (camelName == null || camelName.length() == 0) { - return camelName; - } - StringBuilder buf = null; - for (int i = 0; i < camelName.length(); i ++) { - char ch = camelName.charAt(i); - if (ch >= 'A' && ch <= 'Z') { - if (buf == null) { - buf = new StringBuilder(); - if (i > 0) { - buf.append(camelName.substring(0, i)); - } - } - if (i > 0) { - buf.append(split); - } - buf.append(Character.toLowerCase(ch)); - } else if (buf != null) { - buf.append(ch); - } - } - return buf == null ? camelName : buf.toString(); - } - - public static String toArgumentString(Object[] args) { - StringBuilder buf = new StringBuilder(); + } + + public static String toQueryString(Map ps) { + StringBuilder buf = new StringBuilder(); + if (ps != null && ps.size() > 0) { + for (Map.Entry entry : new TreeMap(ps).entrySet()) { + String key = entry.getKey(); + String value = entry.getValue(); + if (key != null && key.length() > 0 + && value != null && value.length() > 0) { + if (buf.length() > 0) { + buf.append("&"); + } + buf.append(key); + buf.append("="); + buf.append(value); + } + } + } + return buf.toString(); + } + + public static String camelToSplitName(String camelName, String split) { + if (camelName == null || camelName.length() == 0) { + return camelName; + } + StringBuilder buf = null; + for (int i = 0; i < camelName.length(); i++) { + char ch = camelName.charAt(i); + if (ch >= 'A' && ch <= 'Z') { + if (buf == null) { + buf = new StringBuilder(); + if (i > 0) { + buf.append(camelName.substring(0, i)); + } + } + if (i > 0) { + buf.append(split); + } + buf.append(Character.toLowerCase(ch)); + } else if (buf != null) { + buf.append(ch); + } + } + return buf == null ? camelName : buf.toString(); + } + + public static String toArgumentString(Object[] args) { + StringBuilder buf = new StringBuilder(); for (Object arg : args) { if (buf.length() > 0) { buf.append(Constants.COMMA_SEPARATOR); @@ -450,7 +422,8 @@ public static String toArgumentString(Object[] args) { } } return buf.toString(); - } + } - private StringUtils(){} + private StringUtils() { + } } \ No newline at end of file diff --git a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/UrlUtils.java b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/UrlUtils.java index 8466ebb973f..68d81e4cbd1 100644 --- a/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/UrlUtils.java +++ b/dubbo-common/src/main/java/com/alibaba/dubbo/common/utils/UrlUtils.java @@ -15,15 +15,11 @@ */ package com.alibaba.dubbo.common.utils; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.Set; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; +import java.util.*; + public class UrlUtils { public static URL parseURL(String address, Map defaults) { @@ -31,7 +27,7 @@ public static URL parseURL(String address, Map defaults) { return null; } String url; - if (address.indexOf("://") >= 0) { + if (address.contains("://")) { url = address; } else { String[] addresses = Constants.COMMA_SPLIT_PATTERN.split(address); @@ -73,7 +69,7 @@ public static URL parseURL(String address, Map defaults) { int port = u.getPort(); String path = u.getPath(); Map parameters = new HashMap(u.getParameters()); - if ((protocol == null || protocol.length() == 0) && defaultProtocol != null && defaultProtocol.length() > 0) { + if ((protocol == null || protocol.length() == 0) && defaultProtocol.length() > 0) { changed = true; protocol = defaultProtocol; } @@ -85,10 +81,6 @@ public static URL parseURL(String address, Map defaults) { changed = true; password = defaultPassword; } - /*if (u.isAnyHost() || u.isLocalHost()) { - changed = true; - host = NetUtils.getLocalHost(); - }*/ if (port <= 0) { if (defaultPort > 0) { changed = true; @@ -150,8 +142,6 @@ public static Map> convertRegister(Map params = StringUtils.parseQueryString(serviceQuery); String group = params.get("group"); String version = params.get("version"); - //params.remove("group"); - //params.remove("version"); String name = serviceName; if (group != null && group.length() > 0) { name = group + "/" + name; @@ -182,8 +172,6 @@ public static Map convertSubscribe(Map subscribe Map params = StringUtils.parseQueryString(serviceQuery); String group = params.get("group"); String version = params.get("version"); - //params.remove("group"); - //params.remove("version"); String name = serviceName; if (group != null && group.length() > 0) { name = group + "/" + name; @@ -274,8 +262,6 @@ public static Map> revertNotify(Map params = StringUtils.parseQueryString(query); String group = params.get("group"); String version = params.get("version"); - // params.remove("group"); - // params.remove("version"); String name = serviceName; if (group != null && group.length() > 0) { name = group + "/" + name; @@ -305,7 +291,7 @@ public static List revertForbid(List forbid, Set subscribed if (forbid != null && forbid.size() > 0) { List newForbid = new ArrayList(); for (String serviceName : forbid) { - if (! serviceName.contains(":") && ! serviceName.contains("/")) { + if (!serviceName.contains(":") && !serviceName.contains("/")) { for (URL url : subscribed) { if (serviceName.equals(url.getServiceInterface())) { newForbid.add(url.getServiceKey()); @@ -334,10 +320,10 @@ public static URL getEmptyUrl(String service, String category) { version = service.substring(i + 1); service = service.substring(0, i); } - return URL.valueOf(Constants.EMPTY_PROTOCOL + "://0.0.0.0/" + service + "?" - + Constants.CATEGORY_KEY + "=" + category - + (group == null ? "" : "&" + Constants.GROUP_KEY + "=" + group) - + (version == null ? "" : "&" + Constants.VERSION_KEY + "=" + version)); + return URL.valueOf(Constants.EMPTY_PROTOCOL + "://0.0.0.0/" + service + "?" + + Constants.CATEGORY_KEY + "=" + category + + (group == null ? "" : "&" + Constants.GROUP_KEY + "=" + group) + + (version == null ? "" : "&" + Constants.VERSION_KEY + "=" + version)); } public static boolean isMatchCategory(String category, String categories) { @@ -346,7 +332,7 @@ public static boolean isMatchCategory(String category, String categories) { } else if (categories.contains(Constants.ANY_VALUE)) { return true; } else if (categories.contains(Constants.REMOVE_VALUE_PREFIX)) { - return ! categories.contains(Constants.REMOVE_VALUE_PREFIX + category); + return !categories.contains(Constants.REMOVE_VALUE_PREFIX + category); } else { return categories.contains(category); } @@ -355,49 +341,54 @@ public static boolean isMatchCategory(String category, String categories) { public static boolean isMatch(URL consumerUrl, URL providerUrl) { String consumerInterface = consumerUrl.getServiceInterface(); String providerInterface = providerUrl.getServiceInterface(); - if( ! (Constants.ANY_VALUE.equals(consumerInterface) || StringUtils.isEquals(consumerInterface, providerInterface)) ) return false; - - if (! isMatchCategory(providerUrl.getParameter(Constants.CATEGORY_KEY, Constants.DEFAULT_CATEGORY), + if (!(Constants.ANY_VALUE.equals(consumerInterface) || StringUtils.isEquals(consumerInterface, providerInterface))) + return false; + + if (!isMatchCategory(providerUrl.getParameter(Constants.CATEGORY_KEY, Constants.DEFAULT_CATEGORY), consumerUrl.getParameter(Constants.CATEGORY_KEY, Constants.DEFAULT_CATEGORY))) { return false; } - if (! providerUrl.getParameter(Constants.ENABLED_KEY, true) - && ! Constants.ANY_VALUE.equals(consumerUrl.getParameter(Constants.ENABLED_KEY))) { + if (!providerUrl.getParameter(Constants.ENABLED_KEY, true) + && !Constants.ANY_VALUE.equals(consumerUrl.getParameter(Constants.ENABLED_KEY))) { return false; } - + String consumerGroup = consumerUrl.getParameter(Constants.GROUP_KEY); String consumerVersion = consumerUrl.getParameter(Constants.VERSION_KEY); String consumerClassifier = consumerUrl.getParameter(Constants.CLASSIFIER_KEY, Constants.ANY_VALUE); - + String providerGroup = providerUrl.getParameter(Constants.GROUP_KEY); String providerVersion = providerUrl.getParameter(Constants.VERSION_KEY); String providerClassifier = providerUrl.getParameter(Constants.CLASSIFIER_KEY, Constants.ANY_VALUE); - return (Constants.ANY_VALUE.equals(consumerGroup) || StringUtils.isEquals(consumerGroup, providerGroup) || StringUtils.isContains(consumerGroup, providerGroup)) - && (Constants.ANY_VALUE.equals(consumerVersion) || StringUtils.isEquals(consumerVersion, providerVersion)) - && (consumerClassifier == null || Constants.ANY_VALUE.equals(consumerClassifier) || StringUtils.isEquals(consumerClassifier, providerClassifier)); + return (Constants.ANY_VALUE.equals(consumerGroup) || + StringUtils.isEquals(consumerGroup, providerGroup) || + StringUtils.isContains(consumerGroup, providerGroup)) && + (Constants.ANY_VALUE.equals(consumerVersion) || + StringUtils.isEquals(consumerVersion, providerVersion)) && + (consumerClassifier == null || Constants.ANY_VALUE.equals(consumerClassifier) || + StringUtils.isEquals(consumerClassifier, providerClassifier)); } - + public static boolean isMatchGlobPattern(String pattern, String value, URL param) { if (param != null && pattern.startsWith("$")) { pattern = param.getRawParameter(pattern.substring(1)); } return isMatchGlobPattern(pattern, value); } - + public static boolean isMatchGlobPattern(String pattern, String value) { if ("*".equals(pattern)) return true; - if((pattern == null || pattern.length() == 0) - && (value == null || value.length() == 0)) + if ((pattern == null || pattern.length() == 0) + && (value == null || value.length() == 0)) return true; - if((pattern == null || pattern.length() == 0) - || (value == null || value.length() == 0)) + if ((pattern == null || pattern.length() == 0) + || (value == null || value.length() == 0)) return false; - + int i = pattern.lastIndexOf('*'); // 没有找到星号 - if(i == -1) { + if (i == -1) { return value.equals(pattern); } // 星号在末尾 @@ -417,12 +408,12 @@ else if (i == 0) { } public static boolean isServiceKeyMatch(URL pattern, URL value) { - return pattern.getParameter(Constants.INTERFACE_KEY).equals( - value.getParameter(Constants.INTERFACE_KEY)) - && isItemMatch(pattern.getParameter(Constants.GROUP_KEY), - value.getParameter(Constants.GROUP_KEY)) - && isItemMatch(pattern.getParameter(Constants.VERSION_KEY), - value.getParameter(Constants.VERSION_KEY)); + return pattern.getParameter(Constants.INTERFACE_KEY).equals( + value.getParameter(Constants.INTERFACE_KEY)) + && isItemMatch(pattern.getParameter(Constants.GROUP_KEY), + value.getParameter(Constants.GROUP_KEY)) + && isItemMatch(pattern.getParameter(Constants.VERSION_KEY), + value.getParameter(Constants.VERSION_KEY)); } /** @@ -430,7 +421,7 @@ && isItemMatch(pattern.getParameter(Constants.VERSION_KEY), * * @param pattern pattern * @param value value - * @return true if match otherwise false + * @return true if match otherwise false */ static boolean isItemMatch(String pattern, String value) { if (pattern == null) { diff --git a/dubbo-common/src/test/java/com/alibaba/dubbo/common/extensionloader/ExtensionLoaderTest.java b/dubbo-common/src/test/java/com/alibaba/dubbo/common/extensionloader/ExtensionLoaderTest.java index 689d97e3f49..d6eeb4dc1b0 100644 --- a/dubbo-common/src/test/java/com/alibaba/dubbo/common/extensionloader/ExtensionLoaderTest.java +++ b/dubbo-common/src/test/java/com/alibaba/dubbo/common/extensionloader/ExtensionLoaderTest.java @@ -15,28 +15,18 @@ */ package com.alibaba.dubbo.common.extensionloader; -import static org.hamcrest.CoreMatchers.anyOf; -import static org.hamcrest.CoreMatchers.*; -import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertFalse; -import static org.junit.Assert.assertThat; -import static org.junit.Assert.assertTrue; -import static org.junit.Assert.*; -import static org.junit.matchers.JUnitMatchers.containsString; - -import java.util.HashSet; -import java.util.List; -import java.util.Set; - import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.extension.ExtensionLoader; import com.alibaba.dubbo.common.extensionloader.activate.ActivateExt1; -import com.alibaba.dubbo.common.extensionloader.activate.impl.ActivateExt1Impl1; -import com.alibaba.dubbo.common.extensionloader.activate.impl.GroupActivateExtImpl; -import com.alibaba.dubbo.common.extensionloader.activate.impl.OrderActivateExtImpl1; -import com.alibaba.dubbo.common.extensionloader.activate.impl.OrderActivateExtImpl2; -import com.alibaba.dubbo.common.extensionloader.activate.impl.ValueActivateExtImpl; +import com.alibaba.dubbo.common.extensionloader.activate.impl.*; +import com.alibaba.dubbo.common.extensionloader.ext1.SimpleExt; import com.alibaba.dubbo.common.extensionloader.ext1.impl.SimpleExtImpl1; +import com.alibaba.dubbo.common.extensionloader.ext1.impl.SimpleExtImpl2; +import com.alibaba.dubbo.common.extensionloader.ext2.Ext2; import com.alibaba.dubbo.common.extensionloader.ext6_wrap.WrappedExt; +import com.alibaba.dubbo.common.extensionloader.ext6_wrap.impl.Ext5Wrapper1; +import com.alibaba.dubbo.common.extensionloader.ext6_wrap.impl.Ext5Wrapper2; import com.alibaba.dubbo.common.extensionloader.ext7.InitErrorExt; import com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt1; import com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt2; @@ -44,16 +34,15 @@ import com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt4; import com.alibaba.dubbo.common.extensionloader.ext8_add.impl.*; import junit.framework.Assert; - import org.junit.Test; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.common.extensionloader.ext1.SimpleExt; -import com.alibaba.dubbo.common.extensionloader.ext1.impl.SimpleExtImpl2; -import com.alibaba.dubbo.common.extensionloader.ext2.Ext2; -import com.alibaba.dubbo.common.extensionloader.ext6_wrap.impl.Ext5Wrapper1; -import com.alibaba.dubbo.common.extensionloader.ext6_wrap.impl.Ext5Wrapper2; +import java.util.HashSet; +import java.util.List; +import java.util.Set; + +import static org.hamcrest.CoreMatchers.*; +import static org.junit.Assert.*; +import static org.junit.matchers.JUnitMatchers.containsString; /** * @author ding.lid @@ -98,35 +87,35 @@ public void test_getExtensionLoader_NotSpiAnnotation() throws Exception { public void test_getDefaultExtension() throws Exception { SimpleExt ext = ExtensionLoader.getExtensionLoader(SimpleExt.class).getDefaultExtension(); assertThat(ext, instanceOf(SimpleExtImpl1.class)); - + String name = ExtensionLoader.getExtensionLoader(SimpleExt.class).getDefaultExtensionName(); assertEquals("impl1", name); } - + @Test public void test_getDefaultExtension_NULL() throws Exception { Ext2 ext = ExtensionLoader.getExtensionLoader(Ext2.class).getDefaultExtension(); assertNull(ext); - + String name = ExtensionLoader.getExtensionLoader(Ext2.class).getDefaultExtensionName(); assertNull(name); } - + @Test public void test_getExtension() throws Exception { assertTrue(ExtensionLoader.getExtensionLoader(SimpleExt.class).getExtension("impl1") instanceof SimpleExtImpl1); assertTrue(ExtensionLoader.getExtensionLoader(SimpleExt.class).getExtension("impl2") instanceof SimpleExtImpl2); } - + @Test public void test_getExtension_WithWrapper() throws Exception { WrappedExt impl1 = ExtensionLoader.getExtensionLoader(WrappedExt.class).getExtension("impl1"); assertThat(impl1, anyOf(instanceOf(Ext5Wrapper1.class), instanceOf(Ext5Wrapper2.class))); - - WrappedExt impl2 = ExtensionLoader.getExtensionLoader(WrappedExt.class).getExtension("impl2") ; + + WrappedExt impl2 = ExtensionLoader.getExtensionLoader(WrappedExt.class).getExtension("impl2"); assertThat(impl2, anyOf(instanceOf(Ext5Wrapper1.class), instanceOf(Ext5Wrapper2.class))); - - + + URL url = new URL("p1", "1.2.3.4", 1010, "path1"); int echoCount1 = Ext5Wrapper1.echoCount.get(); int echoCount2 = Ext5Wrapper2.echoCount.get(); @@ -135,7 +124,7 @@ public void test_getExtension_WithWrapper() throws Exception { assertEquals(echoCount1 + 1, Ext5Wrapper1.echoCount.get()); assertEquals(echoCount2 + 1, Ext5Wrapper2.echoCount.get()); } - + @Test public void test_getExtension_ExceptionNoExtension() throws Exception { try { @@ -145,7 +134,7 @@ public void test_getExtension_ExceptionNoExtension() throws Exception { assertThat(expected.getMessage(), containsString("No such extension com.alibaba.dubbo.common.extensionloader.ext1.SimpleExt by name XXX")); } } - + @Test public void test_getExtension_ExceptionNoExtension_WrapperNotAffactName() throws Exception { try { @@ -155,7 +144,7 @@ public void test_getExtension_ExceptionNoExtension_WrapperNotAffactName() throws assertThat(expected.getMessage(), containsString("No such extension com.alibaba.dubbo.common.extensionloader.ext6_wrap.WrappedExt by name XXX")); } } - + @Test public void test_getExtension_ExceptionNullArg() throws Exception { try { @@ -165,13 +154,13 @@ public void test_getExtension_ExceptionNullArg() throws Exception { assertThat(expected.getMessage(), containsString("Extension name == null")); } } - + @Test public void test_hasExtension() throws Exception { assertTrue(ExtensionLoader.getExtensionLoader(SimpleExt.class).hasExtension("impl1")); assertFalse(ExtensionLoader.getExtensionLoader(SimpleExt.class).hasExtension("impl1,impl2")); assertFalse(ExtensionLoader.getExtensionLoader(SimpleExt.class).hasExtension("xxx")); - + try { ExtensionLoader.getExtensionLoader(SimpleExt.class).hasExtension(null); fail(); @@ -195,16 +184,16 @@ public void test_hasExtension_wrapperIsNotExt() throws Exception { assertThat(expected.getMessage(), containsString("Extension name == null")); } } - + @Test public void test_getSupportedExtensions() throws Exception { Set exts = ExtensionLoader.getExtensionLoader(SimpleExt.class).getSupportedExtensions(); - + Set expected = new HashSet(); expected.add("impl1"); expected.add("impl2"); expected.add("impl3"); - + assertEquals(expected, exts); } @@ -224,8 +213,7 @@ public void test_AddExtension() throws Exception { try { ExtensionLoader.getExtensionLoader(AddExt1.class).getExtension("Manual1"); fail(); - } - catch (IllegalStateException expected) { + } catch (IllegalStateException expected) { assertThat(expected.getMessage(), containsString("No such extension com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt1 by name Manual")); } @@ -243,8 +231,7 @@ public void test_AddExtension_ExceptionWhenExistedExtension() throws Exception { try { ExtensionLoader.getExtensionLoader(AddExt1.class).addExtension("impl1", AddExt1_ManualAdd1.class); fail(); - } - catch (IllegalStateException expected) { + } catch (IllegalStateException expected) { assertThat(expected.getMessage(), containsString("Extension name impl1 already existed(Extension interface com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt1)!")); } } @@ -267,8 +254,7 @@ public void test_AddExtension_Adaptive_ExceptionWhenExistedAdaptive() throws Exc try { loader.addExtension(null, AddExt1_ManualAdaptive.class); fail(); - } - catch (IllegalStateException expected) { + } catch (IllegalStateException expected) { assertThat(expected.getMessage(), containsString("Adaptive Extension already existed(Extension interface com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt1)!")); } } @@ -278,8 +264,7 @@ public void test_replaceExtension() throws Exception { try { ExtensionLoader.getExtensionLoader(AddExt1.class).getExtension("Manual2"); fail(); - } - catch (IllegalStateException expected) { + } catch (IllegalStateException expected) { assertThat(expected.getMessage(), containsString("No such extension com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt1 by name Manual")); } @@ -318,8 +303,7 @@ public void test_replaceExtension_ExceptionWhenNotExistedExtension() throws Exce try { ExtensionLoader.getExtensionLoader(AddExt1.class).replaceExtension("NotExistedExtension", AddExt1_ManualAdd1.class); fail(); - } - catch (IllegalStateException expected) { + } catch (IllegalStateException expected) { assertThat(expected.getMessage(), containsString("Extension name NotExistedExtension not existed(Extension interface com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt1)")); } } @@ -331,8 +315,7 @@ public void test_replaceExtension_Adaptive_ExceptionWhenNotExistedExtension() th try { loader.replaceExtension(null, AddExt4_ManualAdaptive.class); fail(); - } - catch (IllegalStateException expected) { + } catch (IllegalStateException expected) { assertThat(expected.getMessage(), containsString("Adaptive Extension not existed(Extension interface com.alibaba.dubbo.common.extensionloader.ext8_add.AddExt4)")); } } @@ -340,9 +323,9 @@ public void test_replaceExtension_Adaptive_ExceptionWhenNotExistedExtension() th @Test public void test_InitError() throws Exception { ExtensionLoader loader = ExtensionLoader.getExtensionLoader(InitErrorExt.class); - + loader.getExtension("ok"); - + try { loader.getExtension("error"); fail(); @@ -396,7 +379,7 @@ public void testLoadDefaultActivateExtension() throws Exception { Assert.assertEquals(2, list.size()); Assert.assertTrue(list.get(0).getClass() == OrderActivateExtImpl1.class); Assert.assertTrue(list.get(1).getClass() == ActivateExt1Impl1.class); - + url = URL.valueOf("test://localhost/test?ext=default,order1"); list = ExtensionLoader.getExtensionLoader(ActivateExt1.class) .getActivateExtension(url, "ext", "default_group"); @@ -405,4 +388,9 @@ public void testLoadDefaultActivateExtension() throws Exception { Assert.assertTrue(list.get(1).getClass() == OrderActivateExtImpl1.class); } + @Test + public void test_rpc_factory() throws Exception { + + } + } \ No newline at end of file diff --git a/dubbo-config/dubbo-config-api/pom.xml b/dubbo-config/dubbo-config-api/pom.xml index d1f6a82c9c8..c7ee4d0ed96 100644 --- a/dubbo-config/dubbo-config-api/pom.xml +++ b/dubbo-config/dubbo-config-api/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-config - 2.8.4 + 3.0.1 dubbo-config-api jar diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractConfig.java index 3eee351cb50..281b0d29cd6 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractConfig.java @@ -15,14 +15,6 @@ */ package com.alibaba.dubbo.config; -import java.io.Serializable; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.util.HashMap; -import java.util.Map; -import java.util.regex.Matcher; -import java.util.regex.Pattern; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; @@ -34,9 +26,17 @@ import com.alibaba.dubbo.common.utils.StringUtils; import com.alibaba.dubbo.config.support.Parameter; +import java.io.Serializable; +import java.lang.reflect.Method; +import java.lang.reflect.Modifier; +import java.util.HashMap; +import java.util.Map; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + /** * 配置解析的工具方法、公共方法 - * + * * @author william.liangf * @export */ @@ -55,7 +55,7 @@ public abstract class AbstractConfig implements Serializable { private static final Pattern PATTERN_MULTI_NAME = Pattern.compile("[,\\-._0-9a-zA-Z]+"); private static final Pattern PATTERN_METHOD_NAME = Pattern.compile("[a-zA-Z][0-9a-zA-Z]*"); - + private static final Pattern PATTERN_PATH = Pattern.compile("[/\\-$._0-9a-zA-Z]+"); private static final Pattern PATTERN_NAME_HAS_SYMBOL = Pattern.compile("[:*,/\\-._0-9a-zA-Z]+"); @@ -72,8 +72,9 @@ public String getId() { public void setId(String id) { this.id = id; } - + private static final Map legacyProperties = new HashMap(); + static { legacyProperties.put("dubbo.protocol.name", "dubbo.service.protocol"); legacyProperties.put("dubbo.protocol.host", "dubbo.service.server.host"); @@ -84,13 +85,13 @@ public void setId(String id) { legacyProperties.put("dubbo.consumer.check", "dubbo.service.allow.no.provider"); legacyProperties.put("dubbo.service.url", "dubbo.service.address"); } - + private static String convertLegacyValue(String key, String value) { if (value != null && value.length() > 0) { if ("dubbo.service.max.retry.providers".equals(key)) { return String.valueOf(Integer.parseInt(value) - 1); } else if ("dubbo.service.allow.no.provider".equals(key)) { - return String.valueOf(! Boolean.parseBoolean(value)); + return String.valueOf(!Boolean.parseBoolean(value)); } } return value; @@ -103,15 +104,15 @@ protected void appendAnnotation(Class annotationClass, Object annotation) { && method.getReturnType() != void.class && method.getParameterTypes().length == 0 && Modifier.isPublic(method.getModifiers()) - && ! Modifier.isStatic(method.getModifiers())) { + && !Modifier.isStatic(method.getModifiers())) { try { String property = method.getName(); if ("interfaceClass".equals(property) || "interfaceName".equals(property)) { property = "interface"; } String setter = "set" + property.substring(0, 1).toUpperCase() + property.substring(1); - Object value = method.invoke(annotation, new Object[0]); - if (value != null && ! value.equals(method.getDefaultValue())) { + Object value = method.invoke(annotation); + if (value != null && !value.equals(method.getDefaultValue())) { Class parameterType = ReflectUtils.getBoxedClass(method.getReturnType()); if ("filter".equals(property) || "listener".equals(property)) { parameterType = String.class; @@ -121,8 +122,8 @@ protected void appendAnnotation(Class annotationClass, Object annotation) { value = CollectionUtils.toStringMap((String[]) value); } try { - Method setterMethod = getClass().getMethod(setter, new Class[] { parameterType }); - setterMethod.invoke(this, new Object[] { value }); + Method setterMethod = getClass().getMethod(setter, parameterType); + setterMethod.invoke(this, value); } catch (NoSuchMethodException e) { // ignore } @@ -143,7 +144,7 @@ protected static void appendProperties(AbstractConfig config) { for (Method method : methods) { try { String name = method.getName(); - if (name.length() > 3 && name.startsWith("set") && Modifier.isPublic(method.getModifiers()) + if (name.length() > 3 && name.startsWith("set") && Modifier.isPublic(method.getModifiers()) && method.getParameterTypes().length == 1 && isPrimitive(method.getParameterTypes()[0])) { String property = StringUtils.camelToSplitName(name.substring(3, 4).toLowerCase() + name.substring(4), "-"); @@ -151,30 +152,30 @@ protected static void appendProperties(AbstractConfig config) { if (config.getId() != null && config.getId().length() > 0) { String pn = prefix + config.getId() + "." + property; value = System.getProperty(pn); - if(! StringUtils.isBlank(value)) { + if (!StringUtils.isBlank(value)) { logger.info("Use System Property " + pn + " to config dubbo"); } } if (value == null || value.length() == 0) { String pn = prefix + property; value = System.getProperty(pn); - if(! StringUtils.isBlank(value)) { + if (!StringUtils.isBlank(value)) { logger.info("Use System Property " + pn + " to config dubbo"); } } if (value == null || value.length() == 0) { Method getter; try { - getter = config.getClass().getMethod("get" + name.substring(3), new Class[0]); + getter = config.getClass().getMethod("get" + name.substring(3)); } catch (NoSuchMethodException e) { try { - getter = config.getClass().getMethod("is" + name.substring(3), new Class[0]); + getter = config.getClass().getMethod("is" + name.substring(3)); } catch (NoSuchMethodException e2) { getter = null; } } if (getter != null) { - if (getter.invoke(config, new Object[0]) == null) { + if (getter.invoke(config) == null) { if (config.getId() != null && config.getId().length() > 0) { value = ConfigUtils.getProperty(prefix + config.getId() + "." + property); } @@ -187,12 +188,12 @@ protected static void appendProperties(AbstractConfig config) { value = convertLegacyValue(legacyKey, ConfigUtils.getProperty(legacyKey)); } } - + } } } if (value != null && value.length() > 0) { - method.invoke(config, new Object[] {convertPrimitive(method.getParameterTypes()[0], value)}); + method.invoke(config, convertPrimitive(method.getParameterTypes()[0], value)); } } } catch (Exception e) { @@ -200,7 +201,7 @@ protected static void appendProperties(AbstractConfig config) { } } } - + private static String getTagName(Class cls) { String tag = cls.getSimpleName(); for (String suffix : SUFFIXS) { @@ -212,11 +213,11 @@ private static String getTagName(Class cls) { tag = tag.toLowerCase(); return tag; } - + protected static void appendParameters(Map parameters, Object config) { appendParameters(parameters, config, null); } - + @SuppressWarnings("unchecked") protected static void appendParameters(Map parameters, Object config, String prefix) { if (config == null) { @@ -226,9 +227,9 @@ protected static void appendParameters(Map parameters, Object co for (Method method : methods) { try { String name = method.getName(); - if ((name.startsWith("get") || name.startsWith("is")) - && ! "getClass".equals(name) - && Modifier.isPublic(method.getModifiers()) + if ((name.startsWith("get") || name.startsWith("is")) + && !"getClass".equals(name) + && Modifier.isPublic(method.getModifiers()) && method.getParameterTypes().length == 0 && isPrimitive(method.getReturnType())) { Parameter parameter = method.getAnnotation(Parameter.class); @@ -243,18 +244,18 @@ && isPrimitive(method.getReturnType())) { } else { key = prop; } - Object value = method.invoke(config, new Object[0]); + Object value = method.invoke(config); String str = String.valueOf(value).trim(); if (value != null && str.length() > 0) { if (parameter != null && parameter.escaped()) { str = URL.encode(str); } if (parameter != null && parameter.append()) { - String pre = (String)parameters.get(Constants.DEFAULT_KEY + "." + key); + String pre = parameters.get(Constants.DEFAULT_KEY + "." + key); if (pre != null && pre.length() > 0) { str = pre + "," + str; } - pre = (String)parameters.get(key); + pre = parameters.get(key); if (pre != null && pre.length() > 0) { str = pre + "," + str; } @@ -267,10 +268,10 @@ && isPrimitive(method.getReturnType())) { throw new IllegalStateException(config.getClass().getSimpleName() + "." + key + " == null"); } } else if ("getParameters".equals(name) - && Modifier.isPublic(method.getModifiers()) + && Modifier.isPublic(method.getModifiers()) && method.getParameterTypes().length == 0 && method.getReturnType() == Map.class) { - Map map = (Map) method.invoke(config, new Object[0]); + Map map = (Map) method.invoke(config); if (map != null && map.size() > 0) { String pre = (prefix != null && prefix.length() > 0 ? prefix + "." : ""); for (Map.Entry entry : map.entrySet()) { @@ -283,11 +284,11 @@ && isPrimitive(method.getReturnType())) { } } } - + protected static void appendAttributes(Map parameters, Object config) { appendAttributes(parameters, config, null); } - + protected static void appendAttributes(Map parameters, Object config, String prefix) { if (config == null) { return; @@ -296,22 +297,22 @@ protected static void appendAttributes(Map parameters, Object co for (Method method : methods) { try { String name = method.getName(); - if ((name.startsWith("get") || name.startsWith("is")) - && ! "getClass".equals(name) - && Modifier.isPublic(method.getModifiers()) + if ((name.startsWith("get") || name.startsWith("is")) + && !"getClass".equals(name) + && Modifier.isPublic(method.getModifiers()) && method.getParameterTypes().length == 0 && isPrimitive(method.getReturnType())) { Parameter parameter = method.getAnnotation(Parameter.class); if (parameter == null || !parameter.attribute()) continue; String key; - if (parameter != null && parameter.key() != null && parameter.key().length() > 0) { + if (parameter.key() != null && parameter.key().length() > 0) { key = parameter.key(); } else { int i = name.startsWith("get") ? 3 : 2; key = name.substring(i, i + 1).toLowerCase() + name.substring(i + 1); } - Object value = method.invoke(config, new Object[0]); + Object value = method.invoke(config); if (value != null) { if (prefix != null && prefix.length() > 0) { key = prefix + "." + key; @@ -324,21 +325,21 @@ && isPrimitive(method.getReturnType())) { } } } - + private static boolean isPrimitive(Class type) { - return type.isPrimitive() - || type == String.class + return type.isPrimitive() + || type == String.class || type == Character.class || type == Boolean.class || type == Byte.class || type == Short.class - || type == Integer.class + || type == Integer.class || type == Long.class - || type == Float.class + || type == Float.class || type == Double.class || type == Object.class; } - + private static Object convertPrimitive(Class type, String value) { if (type == char.class || type == Character.class) { return value.length() > 0 ? value.charAt(0) : '\0'; @@ -359,15 +360,15 @@ private static Object convertPrimitive(Class type, String value) { } return value; } - + protected static void checkExtension(Class type, String property, String value) { checkName(property, value); - if (value != null && value.length() > 0 - && ! ExtensionLoader.getExtensionLoader(type).hasExtension(value)) { + if (value != null && value.length() > 0 + && !ExtensionLoader.getExtensionLoader(type).hasExtension(value)) { throw new IllegalStateException("No such extension " + value + " for " + property + "/" + type.getName()); } } - + protected static void checkMultiExtension(Class type, String property, String value) { checkMultiName(property, value); if (value != null && value.length() > 0) { @@ -377,9 +378,9 @@ protected static void checkMultiExtension(Class type, String property, String v = v.substring(1); } if (Constants.DEFAULT_KEY.equals(v)) { - continue; + continue; } - if (! ExtensionLoader.getExtensionLoader(type).hasExtension(v)) { + if (!ExtensionLoader.getExtensionLoader(type).hasExtension(v)) { throw new IllegalStateException("No such extension " + v + " for " + property + "/" + type.getName()); } } @@ -397,7 +398,7 @@ protected static void checkPathLength(String property, String value) { protected static void checkName(String property, String value) { checkProperty(property, value, MAX_LENGTH, PATTERN_NAME); } - + protected static void checkNameHasSymbol(String property, String value) { checkProperty(property, value, MAX_LENGTH, PATTERN_NAME_HAS_SYMBOL); } @@ -405,7 +406,7 @@ protected static void checkNameHasSymbol(String property, String value) { protected static void checkKey(String property, String value) { checkProperty(property, value, MAX_LENGTH, PATTERN_KEY); } - + protected static void checkMultiName(String property, String value) { checkProperty(property, value, MAX_LENGTH, PATTERN_MULTI_NAME); } @@ -417,7 +418,7 @@ protected static void checkPathName(String property, String value) { protected static void checkMethodName(String property, String value) { checkProperty(property, value, MAX_LENGTH, PATTERN_METHOD_NAME); } - + protected static void checkParameterName(Map parameters) { if (parameters == null || parameters.size() == 0) { return; @@ -427,22 +428,22 @@ protected static void checkParameterName(Map parameters) { checkNameHasSymbol(entry.getKey(), entry.getValue()); } } - + protected static void checkProperty(String property, String value, int maxlength, Pattern pattern) { if (value == null || value.length() == 0) { return; } - if(value.length() > maxlength){ + if (value.length() > maxlength) { throw new IllegalStateException("Invalid " + property + "=\"" + value + "\" is longer than " + maxlength); } if (pattern != null) { Matcher matcher = pattern.matcher(value); - if(! matcher.matches()) { + if (!matcher.matches()) { throw new IllegalStateException("Invalid " + property + "=\"" + value + "\" contain illegal charactor, only digit, letter, '-', '_' and '.' is legal."); } } } - + static { Runtime.getRuntime().addShutdownHook(new Thread(new Runnable() { public void run() { @@ -453,9 +454,9 @@ public void run() { } }, "DubboShutdownHook")); } - - private static final String[] SUFFIXS = new String[] {"Config", "Bean"}; - + + private static final String[] SUFFIXS = new String[]{"Config", "Bean"}; + @Override public String toString() { try { @@ -466,14 +467,14 @@ public String toString() { for (Method method : methods) { try { String name = method.getName(); - if ((name.startsWith("get") || name.startsWith("is")) - && ! "getClass".equals(name) && ! "get".equals(name) && ! "is".equals(name) - && Modifier.isPublic(method.getModifiers()) + if ((name.startsWith("get") || name.startsWith("is")) + && !"getClass".equals(name) && !"get".equals(name) && !"is".equals(name) + && Modifier.isPublic(method.getModifiers()) && method.getParameterTypes().length == 0 && isPrimitive(method.getReturnType())) { int i = name.startsWith("get") ? 3 : 2; String key = name.substring(i, i + 1).toLowerCase() + name.substring(i + 1); - Object value = method.invoke(this, new Object[0]); + Object value = method.invoke(this); if (value != null) { buf.append(" "); buf.append(key); diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractInterfaceConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractInterfaceConfig.java index fca17165e0d..6a22b3d73b7 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractInterfaceConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractInterfaceConfig.java @@ -15,20 +15,11 @@ */ package com.alibaba.dubbo.config; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.common.utils.ConfigUtils; -import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.common.utils.ReflectUtils; -import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.common.utils.UrlUtils; +import com.alibaba.dubbo.common.utils.*; import com.alibaba.dubbo.config.support.Parameter; import com.alibaba.dubbo.monitor.MonitorFactory; import com.alibaba.dubbo.monitor.MonitorService; @@ -39,67 +30,76 @@ import com.alibaba.dubbo.rpc.ProxyFactory; import com.alibaba.dubbo.rpc.cluster.Cluster; import com.alibaba.dubbo.rpc.support.MockInvoker; +import com.alibaba.dubbo.tracker.RpcTrackerEngine; +import com.alibaba.dubbo.tracker.RpcTrackerEngineFactory; +import com.alibaba.dubbo.tracker.RpcTrackerFactory; +import com.alibaba.dubbo.tracker.RpcTrackerManager; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; +import java.util.Map; /** * AbstractDefaultConfig - * + * * @author william.liangf * @export */ public abstract class AbstractInterfaceConfig extends AbstractMethodConfig { - private static final long serialVersionUID = -1559314110797223229L; + private static final long serialVersionUID = -1559314110797223229L; // 服务接口的本地实现类名 - protected String local; - + protected String local; // 服务接口的本地实现类名 - protected String stub; - + protected String stub; // 服务监控 - protected MonitorConfig monitor; - + protected MonitorConfig monitor; + // 服务追踪 + protected RpcTrackerEngineConfig tracker; + // 代理类型 - protected String proxy; - + protected String proxy; + // 集群方式 - protected String cluster; + protected String cluster; // 过滤器 - protected String filter; - + protected String filter; + // 监听器 - protected String listener; + protected String listener; // 负责人 - protected String owner; + protected String owner; // 连接数限制,0表示共享连接,否则为该服务独享连接数 - protected Integer connections; - + protected Integer connections; + // 连接数限制 - protected String layer; - + protected String layer; + // 应用信息 - protected ApplicationConfig application; - + protected ApplicationConfig application; + // 模块信息 - protected ModuleConfig module; + protected ModuleConfig module; // 注册中心 protected List registries; - + // callback实例个数限制 - private Integer callbacks; - + private Integer callbacks; + // 连接事件 - protected String onconnect; - + protected String onconnect; + // 断开事件 - protected String ondisconnect; + protected String ondisconnect; // 服务暴露或引用的scope,如果为local,则表示只在当前JVM内查找. - private String scope; + private String scope; protected void checkRegistry() { // 兼容旧版本 @@ -116,13 +116,13 @@ protected void checkRegistry() { } } if ((registries == null || registries.size() == 0)) { - throw new IllegalStateException((getClass().getSimpleName().startsWith("Reference") - ? "No such any registry to refer service in consumer " - : "No such any registry to export service in provider ") - + NetUtils.getLocalHost() - + " use dubbo version " - + Version.getVersion() - + ", Please add to your spring config. If you want unregister, please set "); + throw new IllegalStateException((getClass().getSimpleName().startsWith("Reference") + ? "No such any registry to refer service in consumer " + : "No such any registry to export service in provider ") + + NetUtils.getLocalHost() + + " use dubbo version " + + Version.getVersion() + + ", Please add to your spring config. If you want unregister, please set "); } for (RegistryConfig registryConfig : registries) { appendProperties(registryConfig); @@ -140,10 +140,10 @@ protected void checkApplication() { } if (application == null) { throw new IllegalStateException( - "No such application config! Please add to your spring config."); + "No such application config! Please add to your spring config."); } appendProperties(application); - + String wait = ConfigUtils.getProperty(Constants.SHUTDOWN_WAIT_KEY); if (wait != null && wait.trim().length() > 0) { System.setProperty(Constants.SHUTDOWN_WAIT_KEY, wait.trim()); @@ -154,7 +154,7 @@ protected void checkApplication() { } } } - + protected List loadRegistries(boolean provider) { checkRegistry(); List registryList = new ArrayList(); @@ -162,14 +162,13 @@ protected List loadRegistries(boolean provider) { for (RegistryConfig config : registries) { String address = config.getAddress(); if (address == null || address.length() == 0) { - address = Constants.ANYHOST_VALUE; + address = Constants.ANYHOST_VALUE; } String sysaddress = System.getProperty("dubbo.registry.address"); if (sysaddress != null && sysaddress.length() > 0) { address = sysaddress; } - if (address != null && address.length() > 0 - && ! RegistryConfig.NO_AVAILABLE.equalsIgnoreCase(address)) { + if (address.length() > 0 && !RegistryConfig.NO_AVAILABLE.equalsIgnoreCase(address)) { Map map = new HashMap(); appendParameters(map, application); appendParameters(map, config); @@ -179,7 +178,7 @@ protected List loadRegistries(boolean provider) { if (ConfigUtils.getPid() > 0) { map.put(Constants.PID_KEY, String.valueOf(ConfigUtils.getPid())); } - if (! map.containsKey("protocol")) { + if (!map.containsKey("protocol")) { if (ExtensionLoader.getExtensionLoader(RegistryFactory.class).hasExtension("remote")) { map.put("protocol", "remote"); } else { @@ -191,7 +190,7 @@ protected List loadRegistries(boolean provider) { url = url.addParameter(Constants.REGISTRY_KEY, url.getProtocol()); url = url.setProtocol(Constants.REGISTRY_PROTOCOL); if ((provider && url.getParameter(Constants.REGISTER_KEY, true)) - || (! provider && url.getParameter(Constants.SUBSCRIBE_KEY, true))) { + || (!provider && url.getParameter(Constants.SUBSCRIBE_KEY, true))) { registryList.add(url); } } @@ -200,7 +199,7 @@ protected List loadRegistries(boolean provider) { } return registryList; } - + protected URL loadMonitor(URL registryURL) { if (monitor == null) { String monitorAddress = ConfigUtils.getProperty("dubbo.monitor.address"); @@ -222,12 +221,12 @@ protected URL loadMonitor(URL registryURL) { } appendParameters(map, monitor); String address = monitor.getAddress(); - String sysaddress = System.getProperty("dubbo.monitor.address"); - if (sysaddress != null && sysaddress.length() > 0) { - address = sysaddress; + String sysAddress = System.getProperty("dubbo.monitor.address"); + if (sysAddress != null && sysAddress.length() > 0) { + address = sysAddress; } if (ConfigUtils.isNotEmpty(address)) { - if (! map.containsKey(Constants.PROTOCOL_KEY)) { + if (!map.containsKey(Constants.PROTOCOL_KEY)) { if (ExtensionLoader.getExtensionLoader(MonitorFactory.class).hasExtension("logstat")) { map.put(Constants.PROTOCOL_KEY, "logstat"); } else { @@ -240,14 +239,51 @@ protected URL loadMonitor(URL registryURL) { } return null; } - + + + protected void initRpcTrackerManagerIfNeeded() { + URL url = loadTracker(); + if (url != null) { + tracker.setProtocol(url.getProtocol() == null ? "zipkin" : url.getProtocol()); + if (tracker.getRef() != null) { + RpcTrackerManager.setRpcTrackerEngine((RpcTrackerEngine) tracker.getRef()); + } else { + RpcTrackerEngineFactory rpcTrackerEngineFactory = ExtensionLoader.getExtensionLoader(RpcTrackerEngineFactory.class).getExtension(url.getProtocol()); + RpcTrackerManager.createRpcTrackerEngine(rpcTrackerEngineFactory, url); + } + RpcTrackerFactory rpcTrackerFactory = ExtensionLoader.getExtensionLoader(RpcTrackerFactory.class).getExtension(url.getProtocol()); + RpcTrackerManager.setRpcTrackerFactory(rpcTrackerFactory); + } + } + + private URL loadTracker() { + if (tracker != null) { + appendProperties(tracker); + Map map = new HashMap(); + map.put("dubbo", Version.getVersion()); + map.put("application", application.getName()); + map.put(Constants.TIMESTAMP_KEY, String.valueOf(System.currentTimeMillis())); + if (ConfigUtils.getPid() > 0) { + map.put(Constants.PID_KEY, String.valueOf(ConfigUtils.getPid())); + } + appendParameters(map, tracker); + String address = tracker.getAddress(); + if (ConfigUtils.isNotEmpty(address)) { + return UrlUtils.parseURL(address, map); + } else { + return UrlUtils.parseURL(NetUtils.ANYHOST, map); + } + } + return null; + } + protected void checkInterfaceAndMethods(Class interfaceClass, List methods) { // 接口不能为空 if (interfaceClass == null) { throw new IllegalStateException("interface not allow null!"); } // 检查接口类型必需为接口 - if(! interfaceClass.isInterface()) { + if (!interfaceClass.isInterface()) { throw new IllegalStateException("The interface class " + interfaceClass + " is not a interface!"); } // 检查方法是否在接口中存在 @@ -271,11 +307,11 @@ protected void checkInterfaceAndMethods(Class interfaceClass, List interfaceClass) { if (ConfigUtils.isNotEmpty(local)) { Class localClass = ConfigUtils.isDefault(local) ? ReflectUtils.forName(interfaceClass.getName() + "Local") : ReflectUtils.forName(local); - if (! interfaceClass.isAssignableFrom(localClass)) { + if (!interfaceClass.isAssignableFrom(localClass)) { throw new IllegalStateException("The local implemention class " + localClass.getName() + " not implement interface " + interfaceClass.getName()); } try { @@ -286,7 +322,7 @@ protected void checkStubAndMock(Class interfaceClass) { } if (ConfigUtils.isNotEmpty(stub)) { Class localClass = ConfigUtils.isDefault(stub) ? ReflectUtils.forName(interfaceClass.getName() + "Stub") : ReflectUtils.forName(stub); - if (! interfaceClass.isAssignableFrom(localClass)) { + if (!interfaceClass.isAssignableFrom(localClass)) { throw new IllegalStateException("The local implemention class " + localClass.getName() + " not implement interface " + interfaceClass.getName()); } try { @@ -305,11 +341,11 @@ protected void checkStubAndMock(Class interfaceClass) { } } else { Class mockClass = ConfigUtils.isDefault(mock) ? ReflectUtils.forName(interfaceClass.getName() + "Mock") : ReflectUtils.forName(mock); - if (! interfaceClass.isAssignableFrom(mockClass)) { + if (!interfaceClass.isAssignableFrom(mockClass)) { throw new IllegalStateException("The mock implemention class " + mockClass.getName() + " not implement interface " + interfaceClass.getName()); } try { - mockClass.getConstructor(new Class[0]); + mockClass.getConstructor(); } catch (NoSuchMethodException e) { throw new IllegalStateException("No such empty constructor \"public " + mockClass.getSimpleName() + "()\" in mock implemention class " + mockClass.getName()); } @@ -318,8 +354,8 @@ protected void checkStubAndMock(Class interfaceClass) { } /** - * @deprecated Replace to getStub() * @return local + * @deprecated Replace to getStub() */ @Deprecated public String getLocal() { @@ -327,8 +363,8 @@ public String getLocal() { } /** - * @deprecated Replace to setStub(String) * @param local + * @deprecated Replace to setStub(String) */ @Deprecated public void setLocal(String local) { @@ -337,8 +373,8 @@ public void setLocal(String local) { } /** - * @deprecated Replace to setStub(Boolean) * @param local + * @deprecated Replace to setStub(Boolean) */ @Deprecated public void setLocal(Boolean local) { @@ -348,7 +384,7 @@ public void setLocal(Boolean local) { setLocal(String.valueOf(local)); } } - + public String getStub() { return stub; } @@ -365,7 +401,7 @@ public void setStub(Boolean stub) { setStub(String.valueOf(stub)); } } - + public String getCluster() { return cluster; } @@ -378,7 +414,7 @@ public void setCluster(String cluster) { public String getProxy() { return proxy; } - + public void setProxy(String proxy) { checkExtension(ProxyFactory.class, "proxy", proxy); this.proxy = proxy; @@ -396,7 +432,7 @@ public void setConnections(Integer connections) { public String getFilter() { return filter; } - + public void setFilter(String filter) { checkMultiExtension(Filter.class, "filter", filter); this.filter = filter; @@ -407,7 +443,7 @@ public String getListener() { checkMultiExtension(InvokerListener.class, "listener", listener); return listener; } - + public void setListener(String listener) { this.listener = listener; } @@ -451,9 +487,9 @@ public List getRegistries() { return registries; } - @SuppressWarnings({ "unchecked" }) + @SuppressWarnings({"unchecked"}) public void setRegistries(List registries) { - this.registries = (List)registries; + this.registries = (List) registries; } public MonitorConfig getMonitor() { @@ -468,12 +504,20 @@ public void setMonitor(String monitor) { this.monitor = new MonitorConfig(monitor); } + public RpcTrackerEngineConfig getTracker() { + return tracker; + } + + public void setTracker(RpcTrackerEngineConfig tracker) { + this.tracker = tracker; + } + public String getOwner() { return owner; } public void setOwner(String owner) { - checkMultiName("owner", owner); + checkMultiName("owner", owner); this.owner = owner; } @@ -501,12 +545,12 @@ public void setOndisconnect(String ondisconnect) { this.ondisconnect = ondisconnect; } - public String getScope() { - return scope; - } + public String getScope() { + return scope; + } - public void setScope(String scope) { - this.scope = scope; - } + public void setScope(String scope) { + this.scope = scope; + } } \ No newline at end of file diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractMethodConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractMethodConfig.java index 1c838c64b1b..39350067137 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractMethodConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractMethodConfig.java @@ -15,15 +15,15 @@ */ package com.alibaba.dubbo.config; -import java.util.Map; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.config.support.Parameter; import com.alibaba.dubbo.rpc.cluster.LoadBalance; +import java.util.Map; + /** * AbstractMethodConfig - * + * * @author william.liangf * @export */ @@ -32,34 +32,36 @@ public abstract class AbstractMethodConfig extends AbstractConfig { private static final long serialVersionUID = 1L; // 远程调用超时时间(毫秒) - protected Integer timeout; + protected Integer timeout; // 重试次数 - protected Integer retries; + protected Integer retries; // 最大并发调用 - protected Integer actives; - + protected Integer actives; + + protected Integer threads; + // 负载均衡 - protected String loadbalance; + protected String loadbalance; // 是否异步 - protected Boolean async; - + protected Boolean async; + // 异步发送是否等待发送成功 - protected Boolean sent; + protected Boolean sent; // 服务接口的失败mock实现类名 - protected String mock; + protected String mock; // 合并器 - protected String merger; - + protected String merger; + // 服务接口的失败mock实现类名 - protected String cache; + protected String cache; // 服务接口的失败mock实现类名 - protected String validation; + protected String validation; // 自定义参数 protected Map parameters; @@ -100,11 +102,19 @@ public void setAsync(Boolean async) { public Integer getActives() { return actives; } - + public void setActives(Integer actives) { this.actives = actives; } + public Integer getThreads() { + return threads; + } + + public void setThreads(Integer threads) { + this.threads = threads; + } + public Boolean getSent() { return sent; } @@ -126,7 +136,7 @@ public void setMock(String mock) { } this.mock = mock; } - + public void setMock(Boolean mock) { if (mock == null) { setMock((String) null); diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractReferenceConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractReferenceConfig.java index d7506d983ea..fcb47d284b2 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractReferenceConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractReferenceConfig.java @@ -23,44 +23,44 @@ /** * AbstractConsumerConfig - * - * @see com.alibaba.dubbo.config.ReferenceConfig + * * @author william.liangf * @export + * @see com.alibaba.dubbo.config.ReferenceConfig */ public abstract class AbstractReferenceConfig extends AbstractInterfaceConfig { private static final long serialVersionUID = -2786526984373031126L; // ======== 引用缺省值,当引用属性未设置时使用该缺省值替代 ======== - + // 检查服务提供者是否存在 - protected Boolean check; + protected Boolean check; // 是否加载时即刻初始化 - protected Boolean init; + protected Boolean init; // 是否使用泛接口 - protected String generic; + protected String generic; // 优先从JVM内获取引用实例 - protected Boolean injvm; - + protected Boolean injvm; + // lazy create connection - protected Boolean lazy; + protected Boolean lazy; + + protected String reconnect; + + protected Boolean sticky; - protected String reconnect; - - protected Boolean sticky; - //stub是否支持event事件. //TODO slove merge problem - protected Boolean stubevent ;//= Constants.DEFAULT_STUB_EVENT; + protected Boolean stubevent;//= Constants.DEFAULT_STUB_EVENT; // 版本 - protected String version; + protected String version; // 服务分组 - protected String group; + protected String group; public Boolean isCheck() { return check; @@ -105,12 +105,12 @@ public String getGeneric() { public Boolean isInjvm() { return injvm; } - + /** * @param injvm * @deprecated 通过scope设置,scope=local表示使用injvm协议. */ - @Deprecated + @Deprecated public void setInjvm(Boolean injvm) { this.injvm = injvm; } @@ -142,7 +142,7 @@ public void setLazy(Boolean lazy) { @Override public void setOnconnect(String onconnect) { - if (onconnect != null && onconnect.length() >0){ + if (onconnect != null && onconnect.length() > 0) { this.stubevent = true; } super.setOnconnect(onconnect); @@ -150,7 +150,7 @@ public void setOnconnect(String onconnect) { @Override public void setOndisconnect(String ondisconnect) { - if (ondisconnect != null && ondisconnect.length() >0){ + if (ondisconnect != null && ondisconnect.length() > 0) { this.stubevent = true; } super.setOndisconnect(ondisconnect); @@ -160,7 +160,7 @@ public void setOndisconnect(String ondisconnect) { public Boolean getStubevent() { return stubevent; } - + @Parameter(key = Constants.RECONNECT_KEY) public String getReconnect() { return reconnect; diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractServiceConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractServiceConfig.java index 68f0ffe78b0..73f3babf2df 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractServiceConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/AbstractServiceConfig.java @@ -15,60 +15,60 @@ */ package com.alibaba.dubbo.config; -import java.util.Arrays; -import java.util.List; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.config.support.Parameter; import com.alibaba.dubbo.rpc.ExporterListener; +import java.util.Arrays; +import java.util.List; + /** * AbstractServiceConfig - * + * * @author william.liangf * @export */ public abstract class AbstractServiceConfig extends AbstractInterfaceConfig { - private static final long serialVersionUID = 1L; + private static final long serialVersionUID = 1L; // 服务版本 - protected String version; + protected String version; // 服务分组 - protected String group; + protected String group; // 服务是否已经deprecated - protected Boolean deprecated; + protected Boolean deprecated; // 延迟暴露 - protected Integer delay; + protected Integer delay; // 是否暴露 - protected Boolean export; + protected Boolean export; // 权重 - protected Integer weight; + protected Integer weight; // 应用文档 - protected String document; + protected String document; // 在注册中心上注册成动态的还是静态的服务 - protected Boolean dynamic; + protected Boolean dynamic; // 是否使用令牌 - protected String token; + protected String token; // 访问日志 - protected String accesslog; + protected String accesslog; // 允许执行请求数 - private Integer executes; + private Integer executes; protected List protocols; // 是否注册 - private Boolean register; + private Boolean register; public String getVersion() { return version; @@ -88,13 +88,13 @@ public void setGroup(String group) { this.group = group; } - public Integer getDelay() { - return delay; - } + public Integer getDelay() { + return delay; + } - public void setDelay(Integer delay) { - this.delay = delay; - } + public void setDelay(Integer delay) { + this.delay = delay; + } public Boolean getExport() { return export; @@ -103,34 +103,34 @@ public Boolean getExport() { public void setExport(Boolean export) { this.export = export; } - + public Integer getWeight() { return weight; } - + public void setWeight(Integer weight) { this.weight = weight; } - + @Parameter(escaped = true) public String getDocument() { return document; } - + public void setDocument(String document) { this.document = document; } - public String getToken() { - return token; - } + public String getToken() { + return token; + } + + public void setToken(String token) { + checkName("token", token); + this.token = token; + } - public void setToken(String token) { - checkName("token", token); - this.token = token; - } - - public void setToken(Boolean token) { + public void setToken(Boolean token) { if (token == null) { setToken((String) null); } else { @@ -158,9 +158,9 @@ public List getProtocols() { return protocols; } - @SuppressWarnings({ "unchecked" }) + @SuppressWarnings({"unchecked"}) public void setProtocols(List protocols) { - this.protocols = (List)protocols; + this.protocols = (List) protocols; } public ProtocolConfig getProtocol() { @@ -168,7 +168,7 @@ public ProtocolConfig getProtocol() { } public void setProtocol(ProtocolConfig protocol) { - this.protocols = Arrays.asList(new ProtocolConfig[] {protocol}); + this.protocols = Arrays.asList(new ProtocolConfig[]{protocol}); } public String getAccesslog() { @@ -178,7 +178,7 @@ public String getAccesslog() { public void setAccesslog(String accesslog) { this.accesslog = accesslog; } - + public void setAccesslog(Boolean accesslog) { if (accesslog == null) { setAccesslog((String) null); @@ -190,7 +190,7 @@ public void setAccesslog(Boolean accesslog) { public Integer getExecutes() { return executes; } - + public void setExecutes(Integer executes) { this.executes = executes; } diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ApplicationConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ApplicationConfig.java index 5f535e8a3e9..dcf03bff9cd 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ApplicationConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ApplicationConfig.java @@ -15,65 +15,69 @@ */ package com.alibaba.dubbo.config; -import java.util.ArrayList; -import java.util.List; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.compiler.support.AdaptiveCompiler; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.config.support.Parameter; +import java.util.ArrayList; +import java.util.List; + /** * ApplicationConfig - * + * * @author william.liangf * @export */ public class ApplicationConfig extends AbstractConfig { - private static final long serialVersionUID = 5508512956753757169L; + private static final long serialVersionUID = 5508512956753757169L; // 应用名称 - private String name; + private String name; // 模块版本 - private String version; + private String version; // 应用负责人 - private String owner; + private String owner; // 组织名(BU或部门) - private String organization; + private String organization; // 分层 - private String architecture; + private String architecture; // 环境,如:dev/test/run - private String environment; + private String environment; // Java代码编译器 - private String compiler; + private String compiler; // 日志输出方式 - private String logger; + private String logger; // 注册中心 private List registries; // 服务监控 - private MonitorConfig monitor; + private MonitorConfig monitor; + + private RpcTrackerEngineConfig tracker; // 是否为缺省 - private Boolean isDefault; + private Boolean isDefault; + + private boolean closed; public ApplicationConfig() { } - + public ApplicationConfig(String name) { setName(name); } - + @Parameter(key = Constants.APPLICATION_KEY, required = true) public String getName() { return name; @@ -105,16 +109,16 @@ public void setOwner(String owner) { this.owner = owner; } - public String getOrganization() { - return organization; - } + public String getOrganization() { + return organization; + } - public void setOrganization(String organization) { - checkName("organization", organization); - this.organization = organization; - } + public void setOrganization(String organization) { + checkName("organization", organization); + this.organization = organization; + } - public String getArchitecture() { + public String getArchitecture() { return architecture; } @@ -124,18 +128,18 @@ public void setArchitecture(String architecture) { } public String getEnvironment() { - return environment; - } + return environment; + } - public void setEnvironment(String environment) { - checkName("environment", environment); - if(environment != null) { - if (! ("develop".equals(environment) || "test".equals(environment) || "product".equals(environment))) { + public void setEnvironment(String environment) { + checkName("environment", environment); + if (environment != null) { + if (!("develop".equals(environment) || "test".equals(environment) || "product".equals(environment))) { throw new IllegalStateException("Unsupported environment: " + environment + ", only support develop/test/product, default is product."); } } - this.environment = environment; - } + this.environment = environment; + } public RegistryConfig getRegistry() { return registries == null || registries.size() == 0 ? null : registries.get(0); @@ -151,9 +155,9 @@ public List getRegistries() { return registries; } - @SuppressWarnings({ "unchecked" }) + @SuppressWarnings({"unchecked"}) public void setRegistries(List registries) { - this.registries = (List)registries; + this.registries = (List) registries; } public MonitorConfig getMonitor() { @@ -168,6 +172,14 @@ public void setMonitor(String monitor) { this.monitor = new MonitorConfig(monitor); } + public RpcTrackerEngineConfig getTracker() { + return tracker; + } + + public void setTracker(RpcTrackerEngineConfig tracker) { + this.tracker = tracker; + } + public String getCompiler() { return compiler; } @@ -194,4 +206,11 @@ public void setDefault(Boolean isDefault) { this.isDefault = isDefault; } + public synchronized void close() { + if (closed) { + return; + } + ProtocolConfig.destroyAll(); + closed = true; + } } \ No newline at end of file diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/MethodConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/MethodConfig.java index c0c6218010b..54fc8ee8391 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/MethodConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/MethodConfig.java @@ -15,14 +15,13 @@ */ package com.alibaba.dubbo.config; -import java.util.List; - -import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.config.support.Parameter; +import java.util.List; + /** * MethodConfig - * + * * @author william.liangf * @export */ @@ -31,49 +30,28 @@ public class MethodConfig extends AbstractMethodConfig { private static final long serialVersionUID = 884908855422675941L; // 方法名 - private String name; - + private String name; + // 统计参数 - private Integer stat; + private Integer stat; // 是否重试 - private Boolean retry; + private Boolean retry; // 是否为可靠异步 - private Boolean reliable; + private Boolean reliable; // 方法使用线程数限制 - private Integer executes; - + private Integer executes; + // 是否过时 - private Boolean deprecated; + private Boolean deprecated; // 是否需要开启stiky策略 - private Boolean sticky; - - // 是否需要返回 - private Boolean isReturn; - - //异步调用回调实例 - private Object oninvoke; - - //异步调用回调方法 - private String oninvokeMethod; - - //异步调用回调实例 - private Object onreturn; - - //异步调用回调方法 - private String onreturnMethod; - - //异步调用异常回调实例 - private Object onthrow; - - //异步调用异常回调方法 - private String onthrowMethod; - + private Boolean sticky; + private List arguments; - + @Parameter(excluded = true) public String getName() { return name; @@ -86,11 +64,11 @@ public void setName(String name) { id = name; } } - + public Integer getStat() { return stat; } - + @Deprecated public void setStat(Integer stat) { this.stat = stat; @@ -140,7 +118,7 @@ public void setArguments(List arguments) { public List getArguments() { return arguments; } - + public Boolean getSticky() { return sticky; } @@ -149,66 +127,4 @@ public void setSticky(Boolean sticky) { this.sticky = sticky; } - @Parameter(key = Constants.ON_RETURN_INSTANCE_KEY, excluded = true, attribute = true) - public Object getOnreturn() { - return onreturn; - } - - public void setOnreturn(Object onreturn) { - this.onreturn = onreturn; - } - - @Parameter(key = Constants.ON_RETURN_METHOD_KEY, excluded = true, attribute = true) - public String getOnreturnMethod() { - return onreturnMethod; - } - - public void setOnreturnMethod(String onreturnMethod) { - this.onreturnMethod = onreturnMethod; - } - - @Parameter(key = Constants.ON_THROW_INSTANCE_KEY, excluded = true, attribute = true) - public Object getOnthrow() { - return onthrow; - } - - public void setOnthrow(Object onthrow) { - this.onthrow = onthrow; - } - - @Parameter(key = Constants.ON_THROW_METHOD_KEY, excluded = true, attribute = true) - public String getOnthrowMethod() { - return onthrowMethod; - } - - public void setOnthrowMethod(String onthrowMethod) { - this.onthrowMethod = onthrowMethod; - } - - @Parameter(key = Constants.ON_INVOKE_INSTANCE_KEY, excluded = true, attribute = true) - public Object getOninvoke() { - return oninvoke; - } - - public void setOninvoke(Object oninvoke) { - this.oninvoke = oninvoke; - } - - @Parameter(key = Constants.ON_INVOKE_METHOD_KEY, excluded = true, attribute = true) - public String getOninvokeMethod() { - return oninvokeMethod; - } - - public void setOninvokeMethod(String oninvokeMethod) { - this.oninvokeMethod = oninvokeMethod; - } - - public Boolean isReturn() { - return isReturn; - } - - public void setReturn(Boolean isReturn) { - this.isReturn = isReturn; - } - } \ No newline at end of file diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ProtocolConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ProtocolConfig.java index 8e592bd9739..8266a2bc462 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ProtocolConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ProtocolConfig.java @@ -15,108 +15,108 @@ */ package com.alibaba.dubbo.config; -import java.util.Map; - import com.alibaba.dubbo.common.extension.ExtensionLoader; import com.alibaba.dubbo.common.serialize.Serialization; import com.alibaba.dubbo.common.status.StatusChecker; import com.alibaba.dubbo.common.threadpool.ThreadPool; import com.alibaba.dubbo.config.support.Parameter; import com.alibaba.dubbo.registry.support.AbstractRegistryFactory; -import com.alibaba.dubbo.remoting.Dispatcher; import com.alibaba.dubbo.remoting.Codec; -import com.alibaba.dubbo.remoting.Transporter; +import com.alibaba.dubbo.remoting.Dispatcher; import com.alibaba.dubbo.remoting.exchange.Exchanger; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; +import com.alibaba.dubbo.remoting.transport.Transporter; import com.alibaba.dubbo.rpc.Protocol; +import java.util.Map; + /** * ProtocolConfig - * + * * @author william.liangf * @export */ public class ProtocolConfig extends AbstractConfig { - private static final long serialVersionUID = 6913423882496634749L; + private static final long serialVersionUID = 6913423882496634749L; // 服务协议 - private String name; + private String name; // 服务IP地址(多网卡时使用) - private String host; + private String host; // 服务端口 - private Integer port; + private Integer port; // 上下文路径 - private String contextpath; - + private String contextpath; + // 线程池类型 - private String threadpool; - + private String threadpool; + // 线程池大小(固定大小) - private Integer threads; - + private Integer threads; + // IO线程池大小(固定大小) - private Integer iothreads; - + private Integer iothreads; + // 线程池队列大小 - private Integer queues; - + private Integer queues; + // 最大接收连接数 - private Integer accepts; - + private Integer accepts; + // 协议编码 - private String codec; - + private String codec; + // 序列化方式 - private String serialization; - + private String serialization; + // 字符集 - private String charset; - + private String charset; + // 最大请求数据长度 - private Integer payload; - + private Integer payload; + // 缓存区大小 - private Integer buffer; - + private Integer buffer; + // 心跳间隔 - private Integer heartbeat; + private Integer heartbeat; // 访问日志 - private String accesslog; - + private String accesslog; + // 网络传输方式 - private String transporter; - + private String transporter; + // 信息交换方式 - private String exchanger; - + private String exchanger; + // 信息线程模型派发方式 - private String dispatcher; + private String dispatcher; // 对称网络组网方式 - private String networker; - + private String networker; + // 服务器端实现 - private String server; - + private String server; + // 客户端实现 - private String client; - + private String client; + // 支持的telnet命令,多个命令用逗号分隔 - private String telnet; - + private String telnet; + // 命令行提示符 - private String prompt; + private String prompt; // status检查 - private String status; - + private String status; + // 是否注册 - private Boolean register; + private Boolean register; // 是否长连接 // TODO add this to provider config @@ -127,16 +127,16 @@ public class ProtocolConfig extends AbstractConfig { private String optimizer; private String extension; - + // 参数 private Map parameters; // 是否为缺省 private Boolean isDefault; - + public ProtocolConfig() { } - + public ProtocolConfig(String name) { setName(name); } @@ -145,7 +145,7 @@ public ProtocolConfig(String name, int port) { setName(name); setPort(port); } - + @Parameter(excluded = true) public String getName() { return name; @@ -227,15 +227,15 @@ public void setIothreads(Integer iothreads) { public Integer getQueues() { return queues; } - + public void setQueues(Integer queues) { this.queues = queues; } - + public Integer getAccepts() { return accepts; } - + public void setAccepts(Integer accepts) { this.accepts = accepts; } @@ -254,7 +254,7 @@ public void setCodec(String codec) { public String getSerialization() { return serialization; } - + public void setSerialization(String serialization) { if ("dubbo".equals(name)) { checkMultiExtension(Serialization.class, "serialization", serialization); @@ -315,11 +315,11 @@ public void setClient(String client) { } this.client = client; } - + public String getAccesslog() { return accesslog; } - + public void setAccesslog(String accesslog) { this.accesslog = accesslog; } @@ -327,7 +327,7 @@ public void setAccesslog(String accesslog) { public String getTelnet() { return telnet; } - + public void setTelnet(String telnet) { checkMultiExtension(TelnetHandler.class, "telnet", telnet); this.telnet = telnet; @@ -345,7 +345,7 @@ public void setPrompt(String prompt) { public String getStatus() { return status; } - + public void setStatus(String status) { checkMultiExtension(StatusChecker.class, "status", status); this.status = status; @@ -354,24 +354,24 @@ public void setStatus(String status) { public Boolean isRegister() { return register; } - + public void setRegister(Boolean register) { this.register = register; } - + public String getTransporter() { return transporter; } - + public void setTransporter(String transporter) { checkExtension(Transporter.class, "transporter", transporter); this.transporter = transporter; } - + public String getExchanger() { return exchanger; } - + public void setExchanger(String exchanger) { checkExtension(Exchanger.class, "exchanger", exchanger); this.exchanger = exchanger; @@ -379,6 +379,7 @@ public void setExchanger(String exchanger) { /** * 单词拼写错误,请使用{@link #getDispatcher()} + * * @deprecated {@link #getDispatcher()} */ @Deprecated @@ -389,6 +390,7 @@ public String getDispather() { /** * 单词拼写错误,请使用{@link #setDispatcher(String) + * * @deprecated {@link #setDispatcher(String)} */ @Deprecated @@ -453,12 +455,6 @@ public void setExtension(String extension) { this.extension = extension; } - public void destory() { - if (name != null) { - ExtensionLoader.getExtensionLoader(Protocol.class).getExtension(name).destroy();; - } - } - public static void destroyAll() { AbstractRegistryFactory.destroyAll(); ExtensionLoader loader = ExtensionLoader.getExtensionLoader(Protocol.class); diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ProviderConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ProviderConfig.java index e25abbda2a1..ce63854e927 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ProviderConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ProviderConfig.java @@ -15,106 +15,106 @@ */ package com.alibaba.dubbo.config; -import java.util.Arrays; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.status.StatusChecker; import com.alibaba.dubbo.common.threadpool.ThreadPool; import com.alibaba.dubbo.config.support.Parameter; import com.alibaba.dubbo.remoting.Dispatcher; -import com.alibaba.dubbo.remoting.Transporter; +import com.alibaba.dubbo.remoting.transport.Transporter; import com.alibaba.dubbo.remoting.exchange.Exchanger; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; +import java.util.Arrays; + /** * ProviderConfig - * - * @see com.alibaba.dubbo.config.ProtocolConfig - * @see com.alibaba.dubbo.config.ServiceConfig + * * @author william.liangf * @export + * @see com.alibaba.dubbo.config.ProtocolConfig + * @see com.alibaba.dubbo.config.ServiceConfig */ public class ProviderConfig extends AbstractServiceConfig { - private static final long serialVersionUID = 6913423882496634749L; + private static final long serialVersionUID = 6913423882496634749L; // ======== 协议缺省值,当协议属性未设置时使用该缺省值替代 ======== // 服务IP地址(多网卡时使用) - private String host; + private String host; // 服务端口 - private Integer port; + private Integer port; // 上下 - private String contextpath; + private String contextpath; // 线程池类型 - private String threadpool; - + private String threadpool; + // 线程池大小(固定大小) - private Integer threads; + private Integer threads; // IO线程池大小(固定大小) - private Integer iothreads; - + private Integer iothreads; + // 线程池队列大小 - private Integer queues; + private Integer queues; // 最大接收连接数 - private Integer accepts; - + private Integer accepts; + // 协议编码 - private String codec; - + private String codec; + // 序列化方式 - private String serialization; + private String serialization; // 字符集 - private String charset; - + private String charset; + // 最大请求数据长度 - private Integer payload; + private Integer payload; // 缓存区大小 - private Integer buffer; - + private Integer buffer; + // 网络传输方式 - private String transporter; - + private String transporter; + // 信息交换方式 - private String exchanger; + private String exchanger; // 信息线程模型派发方式 - private String dispatcher; + private String dispatcher; // 对称网络组网方式 - private String networker; - + private String networker; + // 服务器端实现 - private String server; - + private String server; + // 客户端实现 - private String client; - + private String client; + // 支持的telnet命令,多个命令用逗号分隔 - private String telnet; + private String telnet; // 命令行提示符 - private String prompt; + private String prompt; // status检查 - private String status; - + private String status; + // 停止时等候时间 - private Integer wait; - + private Integer wait; + // 是否为缺省 - private Boolean isDefault; - + private Boolean isDefault; + @Deprecated public void setProtocol(String protocol) { - this.protocols = Arrays.asList(new ProtocolConfig[] {new ProtocolConfig(protocol)}); + this.protocols = Arrays.asList(new ProtocolConfig[]{new ProtocolConfig(protocol)}); } @Parameter(excluded = true) @@ -126,21 +126,21 @@ public Boolean isDefault() { public void setDefault(Boolean isDefault) { this.isDefault = isDefault; } - + @Parameter(excluded = true) public String getHost() { return host; } - + public void setHost(String host) { this.host = host; } - + @Parameter(excluded = true) public Integer getPort() { return port; } - + @Deprecated public void setPort(Integer port) { this.port = port; @@ -175,11 +175,11 @@ public void setThreadpool(String threadpool) { checkExtension(ThreadPool.class, "threadpool", threadpool); this.threadpool = threadpool; } - + public Integer getThreads() { return threads; } - + public void setThreads(Integer threads) { this.threads = threads; } @@ -195,15 +195,15 @@ public void setIothreads(Integer iothreads) { public Integer getQueues() { return queues; } - + public void setQueues(Integer queues) { this.queues = queues; } - + public Integer getAccepts() { return accepts; } - + public void setAccepts(Integer accepts) { this.accepts = accepts; } @@ -219,7 +219,7 @@ public void setCodec(String codec) { public String getSerialization() { return serialization; } - + public void setSerialization(String serialization) { this.serialization = serialization; } @@ -235,7 +235,7 @@ public void setCharset(String charset) { public Integer getPayload() { return payload; } - + public void setPayload(Integer payload) { this.payload = payload; } @@ -255,7 +255,7 @@ public String getServer() { public void setServer(String server) { this.server = server; } - + public String getClient() { return client; } @@ -267,7 +267,7 @@ public void setClient(String client) { public String getTelnet() { return telnet; } - + public void setTelnet(String telnet) { checkMultiExtension(TelnetHandler.class, "telnet", telnet); this.telnet = telnet; @@ -285,7 +285,7 @@ public void setPrompt(String prompt) { public String getStatus() { return status; } - + public void setStatus(String status) { checkMultiExtension(StatusChecker.class, "status", status); this.status = status; @@ -325,20 +325,20 @@ public Boolean isAsync() { public Integer getActives() { return super.getActives(); } - + public String getTransporter() { return transporter; } - + public void setTransporter(String transporter) { checkExtension(Transporter.class, "transporter", transporter); this.transporter = transporter; } - + public String getExchanger() { return exchanger; } - + public void setExchanger(String exchanger) { checkExtension(Exchanger.class, "exchanger", exchanger); this.exchanger = exchanger; @@ -346,6 +346,7 @@ public void setExchanger(String exchanger) { /** * 单词拼写错误,请使用{@link #getDispatcher()} + * * @deprecated {@link #getDispatcher()} */ @Deprecated @@ -356,6 +357,7 @@ public String getDispather() { /** * 单词拼写错误,请使用{@link #setDispatcher(String)} + * * @deprecated {@link #setDispatcher(String)} */ @Deprecated @@ -384,7 +386,7 @@ public void setNetworker(String networker) { public Integer getWait() { return wait; } - + public void setWait(Integer wait) { this.wait = wait; } diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ReferenceConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ReferenceConfig.java index 12dcc9472a5..bc17178af99 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ReferenceConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ReferenceConfig.java @@ -15,18 +15,6 @@ */ package com.alibaba.dubbo.config; -import java.io.File; -import java.io.FileInputStream; -import java.io.IOException; -import java.lang.reflect.Method; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.HashMap; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.Properties; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; @@ -34,14 +22,12 @@ import com.alibaba.dubbo.common.extension.ExtensionLoader; import com.alibaba.dubbo.common.utils.ConfigUtils; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.common.utils.ReflectUtils; import com.alibaba.dubbo.common.utils.StringUtils; import com.alibaba.dubbo.config.annotation.Reference; import com.alibaba.dubbo.config.support.Parameter; import com.alibaba.dubbo.rpc.Invoker; import com.alibaba.dubbo.rpc.Protocol; import com.alibaba.dubbo.rpc.ProxyFactory; -import com.alibaba.dubbo.rpc.StaticContext; import com.alibaba.dubbo.rpc.cluster.Cluster; import com.alibaba.dubbo.rpc.cluster.directory.StaticDirectory; import com.alibaba.dubbo.rpc.cluster.support.AvailableCluster; @@ -50,40 +36,45 @@ import com.alibaba.dubbo.rpc.service.GenericService; import com.alibaba.dubbo.rpc.support.ProtocolUtils; +import java.io.File; +import java.io.FileInputStream; +import java.io.IOException; +import java.util.*; + /** * ReferenceConfig - * + * * @author william.liangf * @export */ public class ReferenceConfig extends AbstractReferenceConfig { - private static final long serialVersionUID = -5864351140409987595L; + private static final long serialVersionUID = -5864351140409987595L; private static final Protocol refprotocol = ExtensionLoader.getExtensionLoader(Protocol.class).getAdaptiveExtension(); private static final Cluster cluster = ExtensionLoader.getExtensionLoader(Cluster.class).getAdaptiveExtension(); - + private static final ProxyFactory proxyFactory = ExtensionLoader.getExtensionLoader(ProxyFactory.class).getAdaptiveExtension(); // 接口类型 - private String interfaceName; + private String interfaceName; - private Class interfaceClass; + private Class interfaceClass; // 客户端类型 - private String client; + private String client; // 点对点直连服务提供地址 - private String url; + private String url; // 方法配置 - private List methods; + private List methods; // 缺省配置 - private ConsumerConfig consumer; - - private String protocol; + private ConsumerConfig consumer; + + private String protocol; // 接口代理类引用 private transient volatile T ref; @@ -102,7 +93,7 @@ public class ReferenceConfig extends AbstractReferenceConfig { protected void finalize() throws Throwable { super.finalize(); - if(! ReferenceConfig.this.destroyed) { + if (!ReferenceConfig.this.destroyed) { logger.warn("ReferenceConfig(" + url + ") is not DESTROYED when FINALIZE"); /* 先不做Destroy操作 @@ -116,8 +107,9 @@ protected void finalize() throws Throwable { } }; - public ReferenceConfig() {} - + public ReferenceConfig() { + } + public ReferenceConfig(Reference reference) { appendAnnotation(Reference.class, reference); } @@ -131,20 +123,20 @@ public List toUrls() { } public synchronized T get() { - if (destroyed){ + if (destroyed) { throw new IllegalStateException("Already destroyed!"); } - if (ref == null) { - init(); - } - return ref; + if (ref == null) { + init(); + } + return ref; } - + public synchronized void destroy() { if (ref == null) { return; } - if (destroyed){ + if (destroyed) { return; } destroyed = true; @@ -158,15 +150,15 @@ public synchronized void destroy() { } private void init() { - if (initialized) { - return; - } - initialized = true; - if (interfaceName == null || interfaceName.length() == 0) { - throw new IllegalStateException(" interface not allow null!"); - } - // 获取消费者全局配置 - checkDefault(); + if (initialized) { + return; + } + initialized = true; + if (interfaceName == null || interfaceName.length() == 0) { + throw new IllegalStateException(" interface not allow null!"); + } + // 获取消费者全局配置 + checkDefault(); appendProperties(this); if (getGeneric() == null && getConsumer() != null) { setGeneric(getConsumer().getGeneric()); @@ -175,50 +167,50 @@ private void init() { interfaceClass = GenericService.class; } else { try { - interfaceClass = Class.forName(interfaceName, true, Thread.currentThread() - .getContextClassLoader()); - } catch (ClassNotFoundException e) { - throw new IllegalStateException(e.getMessage(), e); - } + interfaceClass = Class.forName(interfaceName, true, Thread.currentThread() + .getContextClassLoader()); + } catch (ClassNotFoundException e) { + throw new IllegalStateException(e.getMessage(), e); + } checkInterfaceAndMethods(interfaceClass, methods); } String resolve = System.getProperty(interfaceName); String resolveFile = null; if (resolve == null || resolve.length() == 0) { - resolveFile = System.getProperty("dubbo.resolve.file"); - if (resolveFile == null || resolveFile.length() == 0) { - File userResolveFile = new File(new File(System.getProperty("user.home")), "dubbo-resolve.properties"); - if (userResolveFile.exists()) { - resolveFile = userResolveFile.getAbsolutePath(); - } - } - if (resolveFile != null && resolveFile.length() > 0) { - Properties properties = new Properties(); - FileInputStream fis = null; - try { - fis = new FileInputStream(new File(resolveFile)); - properties.load(fis); - } catch (IOException e) { - throw new IllegalStateException("Unload " + resolveFile + ", cause: " + e.getMessage(), e); - } finally { - try { - if(null != fis) fis.close(); + resolveFile = System.getProperty("dubbo.resolve.file"); + if (resolveFile == null || resolveFile.length() == 0) { + File userResolveFile = new File(new File(System.getProperty("user.home")), "dubbo-resolve.properties"); + if (userResolveFile.exists()) { + resolveFile = userResolveFile.getAbsolutePath(); + } + } + if (resolveFile != null && resolveFile.length() > 0) { + Properties properties = new Properties(); + FileInputStream fis = null; + try { + fis = new FileInputStream(new File(resolveFile)); + properties.load(fis); + } catch (IOException e) { + throw new IllegalStateException("Unload " + resolveFile + ", cause: " + e.getMessage(), e); + } finally { + try { + if (null != fis) fis.close(); } catch (IOException e) { logger.warn(e.getMessage(), e); } - } - resolve = properties.getProperty(interfaceName); - } + } + resolve = properties.getProperty(interfaceName); + } } if (resolve != null && resolve.length() > 0) { - url = resolve; - if (logger.isWarnEnabled()) { - if (resolveFile != null && resolveFile.length() > 0) { - logger.warn("Using default dubbo resolve file " + resolveFile + " replace " + interfaceName + "" + resolve + " to p2p invoke remote service."); - } else { - logger.warn("Using -D" + interfaceName + "=" + resolve + " to p2p invoke remote service."); - } - } + url = resolve; + if (logger.isWarnEnabled()) { + if (resolveFile != null && resolveFile.length() > 0) { + logger.warn("Using default dubbo resolve file " + resolveFile + " replace " + interfaceName + "" + resolve + " to p2p invoke remote service."); + } else { + logger.warn("Using -D" + interfaceName + "=" + resolve + " to p2p invoke remote service."); + } + } } if (consumer != null) { if (application == null) { @@ -251,6 +243,7 @@ private void init() { } } checkApplication(); + initRpcTrackerManagerIfNeeded(); checkStubAndMock(interfaceClass); Map map = new HashMap(); Map attributes = new HashMap(); @@ -260,18 +253,20 @@ private void init() { if (ConfigUtils.getPid() > 0) { map.put(Constants.PID_KEY, String.valueOf(ConfigUtils.getPid())); } - if (! isGeneric()) { + if (tracker != null) { + map.put(Constants.TRACKER_KEY, tracker.getProtocol()); + } + if (!isGeneric()) { String revision = Version.getVersion(interfaceClass, version); if (revision != null && revision.length() > 0) { map.put("revision", revision); } String[] methods = Wrapper.getWrapper(interfaceClass).getMethodNames(); - if(methods.length == 0) { + if (methods.length == 0) { logger.warn("NO method found in service interface " + interfaceClass.getName()); map.put("methods", Constants.ANY_VALUE); - } - else { + } else { map.put("methods", StringUtils.join(new HashSet(Arrays.asList(methods)), ",")); } } @@ -292,72 +287,31 @@ private void init() { } } appendAttributes(attributes, method, prifix + "." + method.getName()); - checkAndConvertImplicitConfig(method, map, attributes); } } - //attributes通过系统context进行存储. - StaticContext.getSystemContext().putAll(attributes); ref = createProxy(map); } - - private static void checkAndConvertImplicitConfig(MethodConfig method, Map map, Map attributes){ - //check config conflict - if (Boolean.FALSE.equals(method.isReturn()) && (method.getOnreturn() != null || method.getOnthrow() != null)) { - throw new IllegalStateException("method config error : return attribute must be set true when onreturn or onthrow has been setted."); - } - //convert onreturn methodName to Method - String onReturnMethodKey = StaticContext.getKey(map,method.getName(),Constants.ON_RETURN_METHOD_KEY); - Object onReturnMethod = attributes.get(onReturnMethodKey); - if (onReturnMethod != null && onReturnMethod instanceof String){ - attributes.put(onReturnMethodKey, getMethodByName(method.getOnreturn().getClass(), onReturnMethod.toString())); - } - //convert onthrow methodName to Method - String onThrowMethodKey = StaticContext.getKey(map,method.getName(),Constants.ON_THROW_METHOD_KEY); - Object onThrowMethod = attributes.get(onThrowMethodKey); - if (onThrowMethod != null && onThrowMethod instanceof String){ - attributes.put(onThrowMethodKey, getMethodByName(method.getOnthrow().getClass(), onThrowMethod.toString())); - } - //convert oninvoke methodName to Method - String onInvokeMethodKey = StaticContext.getKey(map,method.getName(),Constants.ON_INVOKE_METHOD_KEY); - Object onInvokeMethod = attributes.get(onInvokeMethodKey); - if (onInvokeMethod != null && onInvokeMethod instanceof String){ - attributes.put(onInvokeMethodKey, getMethodByName(method.getOninvoke().getClass(), onInvokeMethod.toString())); - } - } - private static Method getMethodByName(Class clazz, String methodName){ - try { - return ReflectUtils.findMethodByMethodName(clazz, methodName); - } catch (Exception e) { - throw new IllegalStateException(e); - } - } - - @SuppressWarnings({ "unchecked", "rawtypes", "deprecation" }) - private T createProxy(Map map) { - URL tmpUrl = new URL("temp", "localhost", 0, map); - final boolean isJvmRefer; + @SuppressWarnings({"unchecked", "rawtypes", "deprecation"}) + private T createProxy(Map map) { + URL tmpUrl = new URL("temp", "localhost", 0, map); + final boolean isJvmRefer; if (isInjvm() == null) { - if (url != null && url.length() > 0) { //指定URL的情况下,不做本地引用 - isJvmRefer = false; - } else if (InjvmProtocol.getInjvmProtocol().isInjvmRefer(tmpUrl)) { - //默认情况下如果本地有服务暴露,则引用本地服务. - isJvmRefer = true; - } else { - isJvmRefer = false; - } + //指定URL的情况下,不做本地引用 + isJvmRefer = !(url != null && url.length() > 0) && InjvmProtocol.getInjvmProtocol().isInjvmRefer(tmpUrl); + //默认情况下如果本地有服务暴露,则引用本地服务. } else { - isJvmRefer = isInjvm().booleanValue(); + isJvmRefer = isInjvm(); } - - if (isJvmRefer) { - URL url = new URL(Constants.LOCAL_PROTOCOL, NetUtils.LOCALHOST, 0, interfaceClass.getName()).addParameters(map); - invoker = refprotocol.refer(interfaceClass, url); + if (isJvmRefer) { + URL url = new URL(Constants.LOCAL_PROTOCOL, NetUtils.LOCALHOST, 0, interfaceClass.getName()).addParameters(map); + invoker = refprotocol.refer(interfaceClass, url); if (logger.isInfoEnabled()) { logger.info("Using injvm service " + interfaceClass.getName()); } - } else { - if (url != null && url.length() > 0) { // 用户指定URL,指定的URL可能是对点对直连地址,也可能是注册中心URL + } else { + // 用户指定URL,指定的URL可能是对点对直连地址,也可能是注册中心URL + if (url != null && url.length() > 0) { String[] us = Constants.SEMICOLON_SPLIT_PATTERN.split(url); if (us != null && us.length > 0) { for (String u : us) { @@ -372,19 +326,22 @@ private T createProxy(Map map) { } } } - } else { // 通过注册中心配置拼装URL - List us = loadRegistries(false); - if (us != null && us.size() > 0) { - for (URL u : us) { - URL monitorUrl = loadMonitor(u); + } else { + // 通过注册中心配置拼装URL + List us = loadRegistries(false); + if (us != null && us.size() > 0) { + for (URL u : us) { + URL monitorUrl = loadMonitor(u); if (monitorUrl != null) { map.put(Constants.MONITOR_KEY, URL.encode(monitorUrl.toFullString())); } - urls.add(u.addParameterAndEncoded(Constants.REFER_KEY, StringUtils.toQueryString(map))); + urls.add(u.addParameterAndEncoded(Constants.REFER_KEY, StringUtils.toQueryString(map))); } - } - if (urls == null || urls.size() == 0) { - throw new IllegalStateException("No such any registry to reference " + interfaceName + " on the consumer " + NetUtils.getLocalHost() + " use dubbo version " + Version.getVersion() + ", please config to your spring config."); + } + if (urls == null || urls.size() == 0) { + throw new IllegalStateException("No such any registry to reference " + interfaceName + " on the consumer " + + NetUtils.getLocalHost() + " use dubbo version " + Version.getVersion() + + ", please config to your spring config."); } } @@ -401,9 +358,9 @@ private T createProxy(Map map) { } if (registryURL != null) { // 有 注册中心协议的URL // 对有注册中心的Cluster 只用 AvailableCluster - URL u = registryURL.addParameter(Constants.CLUSTER_KEY, AvailableCluster.NAME); + URL u = registryURL.addParameter(Constants.CLUSTER_KEY, AvailableCluster.NAME); invoker = cluster.join(new StaticDirectory(u, invokers)); - } else { // 不是 注册中心的URL + } else { // 不是 注册中心的URL invoker = cluster.join(new StaticDirectory(invokers)); } } @@ -414,10 +371,13 @@ private T createProxy(Map map) { c = consumer.isCheck(); } if (c == null) { - c = true; // default true + c = true; } - if (c && ! invoker.isAvailable()) { - throw new IllegalStateException("Failed to check the status of the service " + interfaceName + ". No provider available for the service " + (group == null ? "" : group + "/") + interfaceName + (version == null ? "" : ":" + version) + " from the url " + invoker.getUrl() + " to the consumer " + NetUtils.getLocalHost() + " use dubbo version " + Version.getVersion()); + if (c && !invoker.isAvailable()) { + throw new IllegalStateException("Failed to check the status of the service " + + interfaceName + ". No provider available for the service " + (group == null ? "" : group + "/") + + interfaceName + (version == null ? "" : ":" + version) + " from the url " + + invoker.getUrl() + " to the consumer " + NetUtils.getLocalHost() + " use dubbo version " + Version.getVersion()); } if (logger.isInfoEnabled()) { logger.info("Refer dubbo service " + interfaceClass.getName() + " from url " + invoker.getUrl()); @@ -433,34 +393,34 @@ private void checkDefault() { appendProperties(consumer); } - public Class getInterfaceClass() { - if (interfaceClass != null) { - return interfaceClass; - } - if (isGeneric() - || (getConsumer() != null && getConsumer().isGeneric())) { - return GenericService.class; - } - try { - if (interfaceName != null && interfaceName.length() > 0) { - this.interfaceClass = Class.forName(interfaceName, true, Thread.currentThread() - .getContextClassLoader()); - } + public Class getInterfaceClass() { + if (interfaceClass != null) { + return interfaceClass; + } + if (isGeneric() + || (getConsumer() != null && getConsumer().isGeneric())) { + return GenericService.class; + } + try { + if (interfaceName != null && interfaceName.length() > 0) { + this.interfaceClass = Class.forName(interfaceName, true, Thread.currentThread() + .getContextClassLoader()); + } } catch (ClassNotFoundException t) { throw new IllegalStateException(t.getMessage(), t); } - return interfaceClass; - } - - /** - * @deprecated - * @see #setInterface(Class) - * @param interfaceClass - */ - @Deprecated - public void setInterfaceClass(Class interfaceClass) { - setInterface(interfaceClass); - } + return interfaceClass; + } + + /** + * @param interfaceClass + * @see #setInterface(Class) + * @deprecated + */ + @Deprecated + public void setInterfaceClass(Class interfaceClass) { + setInterface(interfaceClass); + } public String getInterface() { return interfaceName; @@ -472,9 +432,9 @@ public void setInterface(String interfaceName) { id = interfaceName; } } - + public void setInterface(Class interfaceClass) { - if (interfaceClass != null && ! interfaceClass.isInterface()) { + if (interfaceClass != null && !interfaceClass.isInterface()) { throw new IllegalStateException("The interface class " + interfaceClass + " is not a interface!"); } this.interfaceClass = interfaceClass; @@ -517,16 +477,16 @@ public void setConsumer(ConsumerConfig consumer) { } public String getProtocol() { - return protocol; - } + return protocol; + } - public void setProtocol(String protocol) { - this.protocol = protocol; - } + public void setProtocol(String protocol) { + this.protocol = protocol; + } - // just for test + // just for test Invoker getInvoker() { return invoker; } - + } \ No newline at end of file diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/RegistryConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/RegistryConfig.java index e53f7ba3970..8e57874904e 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/RegistryConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/RegistryConfig.java @@ -15,85 +15,85 @@ */ package com.alibaba.dubbo.config; -import java.util.Map; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.config.support.Parameter; import com.alibaba.dubbo.registry.support.AbstractRegistryFactory; +import java.util.Map; + /** * RegistryConfig - * + * * @author william.liangf * @export */ public class RegistryConfig extends AbstractConfig { - private static final long serialVersionUID = 5508512956753757169L; - - public static final String NO_AVAILABLE = "N/A"; + private static final long serialVersionUID = 5508512956753757169L; + + public static final String NO_AVAILABLE = "N/A"; // 注册中心地址 - private String address; - - // 注册中心登录用户名 - private String username; + private String address; + + // 注册中心登录用户名 + private String username; // 注册中心登录密码 - private String password; + private String password; // 注册中心缺省端口 - private Integer port; - + private Integer port; + // 注册中心协议 - private String protocol; + private String protocol; // 客户端实现 - private String transporter; - - private String server; - - private String client; + private String transporter; + + private String server; + + private String client; - private String cluster; - - private String group; + private String cluster; - private String version; + private String group; + + private String version; // 注册中心请求超时时间(毫秒) - private Integer timeout; + private Integer timeout; // 注册中心会话超时时间(毫秒) - private Integer session; - + private Integer session; + // 动态注册中心列表存储文件 - private String file; - + private String file; + // 停止时等候完成通知时间 - private Integer wait; - + private Integer wait; + // 启动时检查注册中心是否存在 - private Boolean check; + private Boolean check; // 在该注册中心上注册是动态的还是静态的服务 - private Boolean dynamic; - + private Boolean dynamic; + // 在该注册中心上服务是否暴露 - private Boolean register; - + private Boolean register; + // 在该注册中心上服务是否引用 - private Boolean subscribe; + private Boolean subscribe; // 自定义参数 private Map parameters; // 是否为缺省 - private Boolean isDefault; - + private Boolean isDefault; + public RegistryConfig() { } - + public RegistryConfig(String address) { setAddress(address); } @@ -143,9 +143,9 @@ public void setPassword(String password) { } /** - * @deprecated - * @see com.alibaba.dubbo.config.ProviderConfig#getWait() * @return wait + * @see com.alibaba.dubbo.config.ProviderConfig#getWait() + * @deprecated */ @Deprecated public Integer getWait() { @@ -153,24 +153,24 @@ public Integer getWait() { } /** - * @deprecated - * @see com.alibaba.dubbo.config.ProviderConfig#setWait(Integer) * @param wait + * @see com.alibaba.dubbo.config.ProviderConfig#setWait(Integer) + * @deprecated */ @Deprecated public void setWait(Integer wait) { this.wait = wait; - if( wait!=null && wait>0) + if (wait != null && wait > 0) System.setProperty(Constants.SHUTDOWN_WAIT_KEY, String.valueOf(wait)); } - + public Boolean isCheck() { - return check; - } + return check; + } - public void setCheck(Boolean check) { - this.check = check; - } + public void setCheck(Boolean check) { + this.check = check; + } public String getFile() { return file; @@ -182,26 +182,26 @@ public void setFile(String file) { } /** - * @deprecated - * @see #getTransporter() * @return transport + * @see #getTransporter() + * @deprecated */ @Deprecated @Parameter(excluded = true) public String getTransport() { return getTransporter(); } - + /** - * @deprecated - * @see #setTransporter(String) * @param transport + * @see #setTransporter(String) + * @deprecated */ @Deprecated public void setTransport(String transport) { setTransporter(transport); } - + public String getTransporter() { return transporter; } @@ -213,11 +213,11 @@ public void setTransporter(String transporter) { }*/ this.transporter = transporter; } - + public String getServer() { return server; } - + public void setServer(String server) { checkName("server", server); /*if(server != null && server.length() > 0 && ! ExtensionLoader.getExtensionLoader(Transporter.class).hasExtension(server)){ @@ -225,11 +225,11 @@ public void setServer(String server) { }*/ this.server = server; } - + public String getClient() { return client; } - + public void setClient(String client) { checkName("client", client); /*if(client != null && client.length() > 0 && ! ExtensionLoader.getExtensionLoader(Transporter.class).hasExtension(client)){ @@ -238,13 +238,13 @@ public void setClient(String client) { this.client = client; } - public Integer getTimeout() { - return timeout; - } + public Integer getTimeout() { + return timeout; + } - public void setTimeout(Integer timeout) { - this.timeout = timeout; - } + public void setTimeout(Integer timeout) { + this.timeout = timeout; + } public Integer getSession() { return session; @@ -269,22 +269,22 @@ public Boolean isRegister() { public void setRegister(Boolean register) { this.register = register; } - + public Boolean isSubscribe() { return subscribe; } - + public void setSubscribe(Boolean subscribe) { this.subscribe = subscribe; } public String getCluster() { - return cluster; - } + return cluster; + } - public void setCluster(String cluster) { - this.cluster = cluster; - } + public void setCluster(String cluster) { + this.cluster = cluster; + } public String getGroup() { return group; diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/RpcTrackerEngineConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/RpcTrackerEngineConfig.java new file mode 100644 index 00000000000..b23a54a04c4 --- /dev/null +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/RpcTrackerEngineConfig.java @@ -0,0 +1,130 @@ +package com.alibaba.dubbo.config; + +import java.util.Map; + +public class RpcTrackerEngineConfig extends AbstractConfig { + + private String application; + + private String protocol; + + private String address; + + private Integer port; + + private String transport; + + private String sampler; + + private Float samplerate; + + private Integer flushinterval; + + private String group; + + private String version; + + private T ref; + + private Map parameters; + + public RpcTrackerEngineConfig() { + } + + public String getApplication() { + return application; + } + + public void setApplication(String application) { + this.application = application; + } + + public String getProtocol() { + return protocol; + } + + public void setProtocol(String protocol) { + this.protocol = protocol; + } + + public String getAddress() { + return address; + } + + public void setAddress(String address) { + this.address = address; + } + + public Integer getPort() { + return port; + } + + public void setPort(Integer port) { + this.port = port; + } + + public String getTransport() { + return transport; + } + + public void setTransport(String transport) { + this.transport = transport; + } + + public String getSampler() { + return sampler; + } + + public void setSampler(String sampler) { + this.sampler = sampler; + } + + public Float getSamplerate() { + return samplerate; + } + + public void setSamplerate(Float samplerate) { + this.samplerate = samplerate; + } + + public Integer getFlushinterval() { + return flushinterval; + } + + public void setFlushinterval(Integer flushinterval) { + this.flushinterval = flushinterval; + } + + public String getGroup() { + return group; + } + + public void setGroup(String group) { + this.group = group; + } + + public String getVersion() { + return version; + } + + public void setVersion(String version) { + this.version = version; + } + + public T getRef() { + return ref; + } + + public void setRef(T ref) { + this.ref = ref; + } + + public Map getParameters() { + return parameters; + } + + public void setParameters(Map parameters) { + checkParameterName(parameters); + this.parameters = parameters; + } +} diff --git a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ServiceConfig.java b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ServiceConfig.java index 76a393a5ac4..5f7b113447d 100644 --- a/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ServiceConfig.java +++ b/dubbo-config/dubbo-config-api/src/main/java/com/alibaba/dubbo/config/ServiceConfig.java @@ -15,20 +15,6 @@ */ package com.alibaba.dubbo.config; -import java.lang.reflect.Method; -import java.net.InetAddress; -import java.net.InetSocketAddress; -import java.net.Socket; -import java.net.SocketAddress; -import java.net.UnknownHostException; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.HashMap; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.UUID; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; @@ -40,55 +26,55 @@ import com.alibaba.dubbo.common.utils.StringUtils; import com.alibaba.dubbo.config.annotation.Service; import com.alibaba.dubbo.config.support.Parameter; -import com.alibaba.dubbo.rpc.Exporter; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Protocol; -import com.alibaba.dubbo.rpc.ProxyFactory; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.cluster.ConfiguratorFactory; -import com.alibaba.dubbo.rpc.ServiceClassHolder; import com.alibaba.dubbo.rpc.service.GenericService; import com.alibaba.dubbo.rpc.support.ProtocolUtils; +import java.lang.reflect.Method; +import java.net.*; +import java.util.*; + /** * ServiceConfig - * + * * @author william.liangf * @export */ public class ServiceConfig extends AbstractServiceConfig { - private static final long serialVersionUID = 3033787999037024738L; + private static final long serialVersionUID = 3033787999037024738L; private static final Protocol protocol = ExtensionLoader.getExtensionLoader(Protocol.class).getAdaptiveExtension(); - + private static final ProxyFactory proxyFactory = ExtensionLoader.getExtensionLoader(ProxyFactory.class).getAdaptiveExtension(); private static final Map RANDOM_PORT_MAP = new HashMap(); // 接口类型 - private String interfaceName; + private String interfaceName; - private Class interfaceClass; + private Class interfaceClass; // 接口实现类引用 - private T ref; + private T ref; // 服务名称 - private String path; + private String path; // 方法配置 - private List methods; + private List methods; private ProviderConfig provider; private final List urls = new ArrayList(); - + private final List> exporters = new ArrayList>(); private transient volatile boolean exported; - private transient volatile boolean unexported; - + private transient volatile boolean unexported; + private volatile String generic; public ServiceConfig() { @@ -105,16 +91,16 @@ public URL toUrl() { public List toUrls() { return urls; } - + @Parameter(excluded = true) public boolean isExported() { - return exported; - } + return exported; + } @Parameter(excluded = true) - public boolean isUnexported() { - return unexported; - } + public boolean isUnexported() { + return unexported; + } public synchronized void export() { if (provider != null) { @@ -125,7 +111,7 @@ public synchronized void export() { delay = provider.getDelay(); } } - if (export != null && ! export.booleanValue()) { + if (export != null && !export) { return; } if (delay != null && delay > 0) { @@ -133,7 +119,7 @@ public synchronized void export() { public void run() { try { Thread.sleep(delay); - } catch (Throwable e) { + } catch (Throwable ignored) { } doExport(); } @@ -145,7 +131,7 @@ public void run() { doExport(); } } - + protected synchronized void doExport() { if (unexported) { throw new IllegalStateException("Already unexported!"); @@ -207,9 +193,9 @@ protected synchronized void doExport() { checkRef(); generic = Boolean.FALSE.toString(); } - if(local !=null){ - if(local=="true"){ - local=interfaceName+"Local"; + if (local != null) { + if (local.equals("true")) { + local = interfaceName + "Local"; } Class localClass; try { @@ -217,13 +203,13 @@ protected synchronized void doExport() { } catch (ClassNotFoundException e) { throw new IllegalStateException(e.getMessage(), e); } - if(!interfaceClass.isAssignableFrom(localClass)){ + if (!interfaceClass.isAssignableFrom(localClass)) { throw new IllegalStateException("The local implemention class " + localClass.getName() + " not implement interface " + interfaceName); } } - if(stub !=null){ - if(stub=="true"){ - stub=interfaceName+"Stub"; + if (stub != null) { + if (stub.equals("true")) { + stub = interfaceName + "Stub"; } Class stubClass; try { @@ -231,7 +217,7 @@ protected synchronized void doExport() { } catch (ClassNotFoundException e) { throw new IllegalStateException(e.getMessage(), e); } - if(!interfaceClass.isAssignableFrom(stubClass)){ + if (!interfaceClass.isAssignableFrom(stubClass)) { throw new IllegalStateException("The stub implemention class " + stubClass.getName() + " not implement interface " + interfaceName); } } @@ -251,7 +237,7 @@ private void checkRef() { if (ref == null) { throw new IllegalStateException("ref not allow null!"); } - if (! interfaceClass.isInstance(ref)) { + if (!interfaceClass.isInstance(ref)) { throw new IllegalStateException("The class " + ref.getClass().getName() + " unimplemented interface " + interfaceClass + "!"); @@ -259,27 +245,28 @@ private void checkRef() { } public synchronized void unexport() { - if (! exported) { + if (!exported) { return; } if (unexported) { return; } - if (exporters != null && exporters.size() > 0) { - for (Exporter exporter : exporters) { - try { + if (exporters != null && exporters.size() > 0) { + for (Exporter exporter : exporters) { + try { exporter.unexport(); } catch (Throwable t) { logger.warn("unexpected err when unexport" + exporter, t); } - } - exporters.clear(); - } + } + exporters.clear(); + } unexported = true; } - - @SuppressWarnings({ "unchecked", "rawtypes" }) + + @SuppressWarnings({"unchecked", "rawtypes"}) private void doExportUrls() { + initRpcTrackerManagerIfNeeded(); List registryURLs = loadRegistries(true); for (ProtocolConfig protocolConfig : protocols) { doExportUrlsFor1Protocol(protocolConfig, registryURLs); @@ -317,7 +304,8 @@ private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List r } finally { try { socket.close(); - } catch (Throwable e) {} + } catch (Throwable ignored) { + } } } catch (Exception e) { logger.warn(e.getMessage(), e); @@ -357,6 +345,9 @@ private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List r if (ConfigUtils.getPid() > 0) { map.put(Constants.PID_KEY, String.valueOf(ConfigUtils.getPid())); } + if (tracker != null) { + map.put(Constants.TRACKER_KEY, tracker.getProtocol()); + } appendParameters(map, application); appendParameters(map, module); appendParameters(map, provider, Constants.DEFAULT_KEY); @@ -376,30 +367,30 @@ private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List r if (arguments != null && arguments.size() > 0) { for (ArgumentConfig argument : arguments) { //类型自动转换. - if(argument.getType() != null && argument.getType().length() >0){ + if (argument.getType() != null && argument.getType().length() > 0) { Method[] methods = interfaceClass.getMethods(); //遍历所有方法 - if(methods != null && methods.length > 0){ - for (int i = 0; i < methods.length; i++) { - String methodName = methods[i].getName(); + if (methods != null && methods.length > 0) { + for (Method mtd : methods) { + String methodName = mtd.getName(); //匹配方法名称,获取方法签名. - if(methodName.equals(method.getName())){ - Class[] argtypes = methods[i].getParameterTypes(); + if (methodName.equals(method.getName())) { + Class[] argtypes = mtd.getParameterTypes(); //一个方法中单个callback - if (argument.getIndex() != -1 ){ - if (argtypes[argument.getIndex()].getName().equals(argument.getType())){ + if (argument.getIndex() != -1) { + if (argtypes[argument.getIndex()].getName().equals(argument.getType())) { appendParameters(map, argument, method.getName() + "." + argument.getIndex()); - }else { - throw new IllegalArgumentException("argument config error : the index attribute and type attirbute not match :index :"+argument.getIndex() + ", type:" + argument.getType()); + } else { + throw new IllegalArgumentException("argument config error : the index attribute and type attirbute not match :index :" + argument.getIndex() + ", type:" + argument.getType()); } } else { //一个方法中多个callback - for (int j = 0 ;j argclazz = argtypes[j]; - if (argclazz.getName().equals(argument.getType())){ + if (argclazz.getName().equals(argument.getType())) { appendParameters(map, argument, method.getName() + "." + j); - if (argument.getIndex() != -1 && argument.getIndex() != j){ - throw new IllegalArgumentException("argument config error : the index attribute and type attirbute not match :index :"+argument.getIndex() + ", type:" + argument.getType()); + if (argument.getIndex() != -1 && argument.getIndex() != j) { + throw new IllegalArgumentException("argument config error : the index attribute and type attirbute not match :index :" + argument.getIndex() + ", type:" + argument.getType()); } } } @@ -407,15 +398,14 @@ private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List r } } } - }else if(argument.getIndex() != -1){ + } else if (argument.getIndex() != -1) { appendParameters(map, argument, method.getName() + "." + argument.getIndex()); - }else { + } else { throw new IllegalArgumentException("argument config must set index or type attribute.eg: or "); } - } } - } // end of methods for + } } if (ProtocolUtils.isGeneric(generic)) { @@ -428,15 +418,15 @@ private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List r } String[] methods = Wrapper.getWrapper(interfaceClass).getMethodNames(); - if(methods.length == 0) { + if (methods.length == 0) { logger.warn("NO method found in service interface " + interfaceClass.getName()); map.put("methods", Constants.ANY_VALUE); - } - else { + } else { map.put("methods", StringUtils.join(new HashSet(Arrays.asList(methods)), ",")); } } - if (! ConfigUtils.isEmpty(token)) { + + if (!ConfigUtils.isEmpty(token)) { if (ConfigUtils.isDefault(token)) { map.put("token", UUID.randomUUID().toString()); } else { @@ -462,14 +452,13 @@ private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List r String scope = url.getParameter(Constants.SCOPE_KEY); //配置为none不暴露 - if (! Constants.SCOPE_NONE.toString().equalsIgnoreCase(scope)) { - + if (!Constants.SCOPE_NONE.equalsIgnoreCase(scope)) { //配置不是remote的情况下做本地暴露 (配置为remote,则表示只暴露远程服务) - if (!Constants.SCOPE_REMOTE.toString().equalsIgnoreCase(scope)) { + if (!Constants.SCOPE_REMOTE.equalsIgnoreCase(scope)) { exportLocal(url); } //如果配置不是local则暴露为远程服务.(配置为local,则表示只暴露远程服务) - if (! Constants.SCOPE_LOCAL.toString().equalsIgnoreCase(scope) ){ + if (!Constants.SCOPE_LOCAL.equalsIgnoreCase(scope)) { if (logger.isInfoEnabled()) { logger.info("Export dubbo service " + interfaceClass.getName() + " to url " + url); } @@ -484,14 +473,13 @@ private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List r if (logger.isInfoEnabled()) { logger.info("Register dubbo service " + interfaceClass.getName() + " url " + url + " to registry " + registryURL); } - Invoker invoker = proxyFactory.getInvoker(ref, (Class) interfaceClass, registryURL.addParameterAndEncoded(Constants.EXPORT_KEY, url.toFullString())); - + Invoker invoker = proxyFactory.getInvoker(ref, + (Class) interfaceClass, registryURL.addParameterAndEncoded(Constants.EXPORT_KEY, url.toFullString())); Exporter exporter = protocol.export(invoker); exporters.add(exporter); } } else { Invoker invoker = proxyFactory.getInvoker(ref, (Class) interfaceClass, url); - Exporter exporter = protocol.export(invoker); exporters.add(exporter); } @@ -501,7 +489,7 @@ private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List r } - @SuppressWarnings({ "unchecked", "rawtypes" }) + @SuppressWarnings({"unchecked", "rawtypes"}) private void exportLocal(URL url) { if (!Constants.LOCAL_PROTOCOL.equalsIgnoreCase(url.getProtocol())) { URL local = URL.valueOf(url.toFullString()) @@ -515,7 +503,7 @@ private void exportLocal(URL url) { Exporter exporter = protocol.export( proxyFactory.getInvoker(ref, (Class) interfaceClass, local)); exporters.add(exporter); - logger.info("Export dubbo service " + interfaceClass.getName() +" to local registry"); + logger.info("Export dubbo service " + interfaceClass.getName() + " to local registry"); } } @@ -535,7 +523,7 @@ private void checkProtocol() { && provider != null) { setProtocols(provider.getProtocols()); } - // 兼容旧版本 + // 兼容旧版本 if (protocols == null || protocols.size() == 0) { setProtocol(new ProtocolConfig()); } @@ -557,7 +545,7 @@ public Class getInterfaceClass() { try { if (interfaceName != null && interfaceName.length() > 0) { this.interfaceClass = Class.forName(interfaceName, true, Thread.currentThread() - .getContextClassLoader()); + .getContextClassLoader()); } } catch (ClassNotFoundException t) { throw new IllegalStateException(t.getMessage(), t); @@ -566,9 +554,9 @@ public Class getInterfaceClass() { } /** - * @deprecated - * @see #setInterface(Class) * @param interfaceClass + * @see #setInterface(Class) + * @deprecated */ public void setInterfaceClass(Class interfaceClass) { setInterface(interfaceClass); @@ -584,9 +572,9 @@ public void setInterface(String interfaceName) { id = interfaceName; } } - + public void setInterface(Class interfaceClass) { - if (interfaceClass != null && ! interfaceClass.isInterface()) { + if (interfaceClass != null && !interfaceClass.isInterface()) { throw new IllegalStateException("The interface class " + interfaceClass + " is not a interface!"); } this.interfaceClass = interfaceClass; @@ -611,21 +599,23 @@ public void setPath(String path) { this.path = path; } - public List getMethods() { - return methods; - } + public List getMethods() { + return methods; + } - @SuppressWarnings("unchecked") + @SuppressWarnings("unchecked") public void setMethods(List methods) { - this.methods = (List) methods; - } + this.methods = (List) methods; + } public ProviderConfig getProvider() { return provider; } public void setGeneric(String generic) { - if (StringUtils.isEmpty(generic)) { return; } + if (StringUtils.isEmpty(generic)) { + return; + } if (ProtocolUtils.isGeneric(generic)) { this.generic = generic; } else { @@ -640,11 +630,11 @@ public String getGeneric() { public void setProvider(ProviderConfig provider) { this.provider = provider; } - - public List getExportedUrls(){ + + public List getExportedUrls() { return urls; } - + // ======== Deprecated ======== /** @@ -664,7 +654,7 @@ public void setProviders(List providers) { } @Deprecated - private static final List convertProviderToProtocol(List providers) { + private static List convertProviderToProtocol(List providers) { if (providers == null || providers.size() == 0) { return null; } @@ -674,9 +664,9 @@ private static final List convertProviderToProtocol(List convertProtocolToProvider(List protocols) { + private static List convertProtocolToProvider(List protocols) { if (protocols == null || protocols.size() == 0) { return null; } @@ -686,9 +676,9 @@ private static final List convertProtocolToProvider(List proxieeClass = null; - private Boolean isOk = false; - - public RpcConfigGetSetProxy(Object p){ - - if(p == null){ + + + private Object proxiee = null; + private Class proxieeClass = null; + private Boolean isOk = false; + + public RpcConfigGetSetProxy(Object p) { + + if (p == null) { return; } - - if (!isKindOf(p.getClass(), RPC_CONFIG_BASECLASS)){ + + if (!isKindOf(p.getClass(), RPC_CONFIG_BASECLASS)) { return; } - + proxiee = p; //proxieeClass = c; proxieeClass = p.getClass(); isOk = true; - + } - - public boolean isOk(){ + + public boolean isOk() { return isOk; } - - public Object setValue(String key, Object value){ - - if (!isOk()){ + + public Object setValue(String key, Object value) { + + if (!isOk()) { return null; } - + Method m = findSetMethod(key, value, proxieeClass); return invoke(m, value); } - public Object getValue(String key){ - - if (!isOk()){ + public Object getValue(String key) { + + if (!isOk()) { return null; } - + Method m = findGetMethod(key, proxieeClass); return invoke(m, null); } - public static boolean isKindOf(Class c, String type){ + public static boolean isKindOf(Class c, String type) { // get the class def for obj and type - + Class tClass; try { tClass = Class.forName(type); } catch (ClassNotFoundException e) { return false; } - + // check against type and superclasses - while ( c != null ) { - if ( c == tClass ) return true; + while (c != null) { + if (c == tClass) return true; c = c.getSuperclass(); } - + return false; } - + private Object invoke(Method m, Object value) { - - if (m == null){ + + if (m == null) { return null; } - + try { - if(value == null){ - return m.invoke(proxiee, (Object[])null); - }else{ + if (value == null) { + return m.invoke(proxiee, (Object[]) null); + } else { return m.invoke(proxiee, value); } } catch (IllegalArgumentException e) { @@ -121,31 +119,31 @@ private Object invoke(Method m, Object value) { return null; } } - - private Method findGetMethod(String key, Class clazz){ - + + private Method findGetMethod(String key, Class clazz) { + Method m = findMethod(key, null, "get", clazz); - if (m != null){ + if (m != null) { return m; } - + return findMethod(key, null, "is", clazz); } - - private Method findSetMethod(String key, Object value, Class clazz){ - + + private Method findSetMethod(String key, Object value, Class clazz) { + return findMethod(key, value, "set", clazz); } - - private Method getMethod(String methodName, Object value, Class clazz){ - - try{ - if (value == null){ - return clazz.getMethod(methodName, (Class[])null); - }else{ + + private Method getMethod(String methodName, Object value, Class clazz) { + + try { + if (value == null) { + return clazz.getMethod(methodName, (Class[]) null); + } else { return clazz.getMethod(methodName, value.getClass()); } - }catch (SecurityException e) { + } catch (SecurityException e) { log.error("SecurityException: " + e.getMessage()); return null; } catch (NoSuchMethodException e) { @@ -154,15 +152,15 @@ private Method getMethod(String methodName, Object value, Class clazz){ } } - private Method findMethod(String key, Object value, String prefix, Class clazz){ - - if(key.length() < 2){ + private Method findMethod(String key, Object value, String prefix, Class clazz) { + + if (key.length() < 2) { return null; } - - key = key.substring(0,1).toUpperCase() + key.substring(1); + + key = key.substring(0, 1).toUpperCase() + key.substring(1); String methodName = prefix + key; - + return getMethod(methodName, value, clazz); } diff --git a/dubbo-config/dubbo-config-api/src/test/java/com/alibaba/dubbo/config/TrackConfigTest.java b/dubbo-config/dubbo-config-api/src/test/java/com/alibaba/dubbo/config/TrackConfigTest.java new file mode 100644 index 00000000000..289af411859 --- /dev/null +++ b/dubbo-config/dubbo-config-api/src/test/java/com/alibaba/dubbo/config/TrackConfigTest.java @@ -0,0 +1,19 @@ +package com.alibaba.dubbo.config; + +import org.junit.Test; + +public class TrackConfigTest { + + @Test + public void test_trackConfig(){ + RpcTrackerEngineConfig trackerEngineConfig = new RpcTrackerEngineConfig(); + trackerEngineConfig.setProtocol("zipkin"); + trackerEngineConfig.setAddress("localhost:9411"); + trackerEngineConfig.setApplication("test"); + trackerEngineConfig.setTransport("kafka"); + trackerEngineConfig.setSampler("counting"); + trackerEngineConfig.setSamplerate(0.1f); + trackerEngineConfig.setFlushinterval(2); + System.out.println(trackerEngineConfig.toString()); + } +} diff --git a/dubbo-config/dubbo-config-spring/pom.xml b/dubbo-config/dubbo-config-spring/pom.xml index 9732dff29d6..65c039b07d8 100644 --- a/dubbo-config/dubbo-config-spring/pom.xml +++ b/dubbo-config/dubbo-config-spring/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-config - 2.8.4 + 3.0.1 dubbo-config-spring jar diff --git a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/AnnotationBean.java b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/AnnotationBean.java index 8f54baacee8..9f4f6c75435 100644 --- a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/AnnotationBean.java +++ b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/AnnotationBean.java @@ -15,15 +15,14 @@ */ package com.alibaba.dubbo.config.spring; -import java.lang.reflect.Field; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.util.ArrayList; -import java.util.List; -import java.util.Set; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; - +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.logger.Logger; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.common.utils.ConcurrentHashSet; +import com.alibaba.dubbo.common.utils.ReflectUtils; +import com.alibaba.dubbo.config.*; +import com.alibaba.dubbo.config.annotation.Reference; +import com.alibaba.dubbo.config.annotation.Service; import org.springframework.aop.support.AopUtils; import org.springframework.beans.BeansException; import org.springframework.beans.factory.BeanInitializationException; @@ -35,27 +34,18 @@ import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContextAware; -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.utils.ConcurrentHashSet; -import com.alibaba.dubbo.common.utils.ReflectUtils; -import com.alibaba.dubbo.config.AbstractConfig; -import com.alibaba.dubbo.config.ApplicationConfig; -import com.alibaba.dubbo.config.ConsumerConfig; -import com.alibaba.dubbo.config.ModuleConfig; -import com.alibaba.dubbo.config.MonitorConfig; -import com.alibaba.dubbo.config.ProtocolConfig; -import com.alibaba.dubbo.config.ProviderConfig; -import com.alibaba.dubbo.config.ReferenceConfig; -import com.alibaba.dubbo.config.RegistryConfig; -import com.alibaba.dubbo.config.ServiceConfig; -import com.alibaba.dubbo.config.annotation.Reference; -import com.alibaba.dubbo.config.annotation.Service; +import java.lang.reflect.Field; +import java.lang.reflect.Method; +import java.lang.reflect.Modifier; +import java.util.ArrayList; +import java.util.List; +import java.util.Set; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; /** * AnnotationBean - * + * * @author william.liangf * @export */ @@ -98,7 +88,7 @@ public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) try { // init scanner Class scannerClass = ReflectUtils.forName("org.springframework.context.annotation.ClassPathBeanDefinitionScanner"); - Object scanner = scannerClass.getConstructor(new Class[] {BeanDefinitionRegistry.class, boolean.class}).newInstance(new Object[] {(BeanDefinitionRegistry) beanFactory, true}); + Object scanner = scannerClass.getConstructor(new Class[]{BeanDefinitionRegistry.class, boolean.class}).newInstance((BeanDefinitionRegistry) beanFactory, true); // add filter Class filterClass = ReflectUtils.forName("org.springframework.core.type.filter.AnnotationTypeFilter"); Object filter = filterClass.getConstructor(Class.class).newInstance(Service.class); @@ -106,8 +96,8 @@ public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) addIncludeFilter.invoke(scanner, filter); // scan packages String[] packages = Constants.COMMA_SPLIT_PATTERN.split(annotationPackage); - Method scan = scannerClass.getMethod("scan", new Class[]{String[].class}); - scan.invoke(scanner, new Object[] {packages}); + Method scan = scannerClass.getMethod("scan", String[].class); + scan.invoke(scanner, new Object[]{packages}); } catch (Throwable e) { // spring 2.0 } @@ -133,11 +123,11 @@ public void destroy() throws Exception { public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException { - if (! isMatchPackage(bean)) { + if (!isMatchPackage(bean)) { return bean; } Class clazz = bean.getClass(); - if(isProxyBean(bean)){ + if (isProxyBean(bean)) { clazz = AopUtils.getTargetClass(bean); } Service service = clazz.getAnnotation(Service.class); @@ -157,34 +147,32 @@ public Object postProcessAfterInitialization(Object bean, String beanName) List registryConfigs = new ArrayList(); for (String registryId : service.registry()) { if (registryId != null && registryId.length() > 0) { - registryConfigs.add((RegistryConfig)applicationContext.getBean(registryId, RegistryConfig.class)); + registryConfigs.add(applicationContext.getBean(registryId, RegistryConfig.class)); } } serviceConfig.setRegistries(registryConfigs); } if (service.provider() != null && service.provider().length() > 0) { - serviceConfig.setProvider((ProviderConfig)applicationContext.getBean(service.provider(),ProviderConfig.class)); + serviceConfig.setProvider(applicationContext.getBean(service.provider(), ProviderConfig.class)); } if (service.monitor() != null && service.monitor().length() > 0) { - serviceConfig.setMonitor((MonitorConfig)applicationContext.getBean(service.monitor(), MonitorConfig.class)); + serviceConfig.setMonitor(applicationContext.getBean(service.monitor(), MonitorConfig.class)); } if (service.application() != null && service.application().length() > 0) { - serviceConfig.setApplication((ApplicationConfig)applicationContext.getBean(service.application(), ApplicationConfig.class)); + serviceConfig.setApplication(applicationContext.getBean(service.application(), ApplicationConfig.class)); } if (service.module() != null && service.module().length() > 0) { - serviceConfig.setModule((ModuleConfig)applicationContext.getBean(service.module(), ModuleConfig.class)); + serviceConfig.setModule(applicationContext.getBean(service.module(), ModuleConfig.class)); } if (service.provider() != null && service.provider().length() > 0) { - serviceConfig.setProvider((ProviderConfig)applicationContext.getBean(service.provider(), ProviderConfig.class)); - } else { - + serviceConfig.setProvider((ProviderConfig) applicationContext.getBean(service.provider(), ProviderConfig.class)); } if (service.protocol() != null && service.protocol().length > 0) { List protocolConfigs = new ArrayList(); // modified by lishen; fix dubbo's bug for (String protocolId : service.protocol()) { if (protocolId != null && protocolId.length() > 0) { - protocolConfigs.add((ProtocolConfig)applicationContext.getBean(protocolId, ProtocolConfig.class)); + protocolConfigs.add(applicationContext.getBean(protocolId, ProtocolConfig.class)); } } serviceConfig.setProtocols(protocolConfigs); @@ -192,7 +180,7 @@ public Object postProcessAfterInitialization(Object bean, String beanName) try { serviceConfig.afterPropertiesSet(); } catch (RuntimeException e) { - throw (RuntimeException) e; + throw e; } catch (Exception e) { throw new IllegalStateException(e.getMessage(), e); } @@ -203,14 +191,14 @@ public Object postProcessAfterInitialization(Object bean, String beanName) } return bean; } - + public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException { - if (! isMatchPackage(bean)) { + if (!isMatchPackage(bean)) { return bean; } Class clazz = bean.getClass(); - if(isProxyBean(bean)){ + if (isProxyBean(bean)) { clazz = AopUtils.getTargetClass(bean); } Method[] methods = clazz.getMethods(); @@ -219,15 +207,15 @@ public Object postProcessBeforeInitialization(Object bean, String beanName) if (name.length() > 3 && name.startsWith("set") && method.getParameterTypes().length == 1 && Modifier.isPublic(method.getModifiers()) - && ! Modifier.isStatic(method.getModifiers())) { + && !Modifier.isStatic(method.getModifiers())) { try { - Reference reference = method.getAnnotation(Reference.class); - if (reference != null) { - Object value = refer(reference, method.getParameterTypes()[0]); - if (value != null) { - method.invoke(bean, new Object[] { value }); - } - } + Reference reference = method.getAnnotation(Reference.class); + if (reference != null) { + Object value = refer(reference, method.getParameterTypes()[0]); + if (value != null) { + method.invoke(bean, value); + } + } } catch (Exception e) { // modified by lishen throw new BeanInitializationException("Failed to init remote service reference at method " + name + " in class " + bean.getClass().getName(), e); @@ -238,16 +226,16 @@ public Object postProcessBeforeInitialization(Object bean, String beanName) Field[] fields = clazz.getDeclaredFields(); for (Field field : fields) { try { - if (! field.isAccessible()) { + if (!field.isAccessible()) { field.setAccessible(true); } Reference reference = field.getAnnotation(Reference.class); - if (reference != null) { - Object value = refer(reference, field.getType()); - if (value != null) { - field.set(bean, value); - } - } + if (reference != null) { + Object value = refer(reference, field.getType()); + if (value != null) { + field.set(bean, value); + } + } } catch (Exception e) { // modified by lishen throw new BeanInitializationException("Failed to init remote service reference at filed " + field.getName() + " in class " + bean.getClass().getName(), e); @@ -259,9 +247,9 @@ public Object postProcessBeforeInitialization(Object bean, String beanName) private Object refer(Reference reference, Class referenceClass) { //method.getParameterTypes()[0] String interfaceName; - if (! "".equals(reference.interfaceName())) { + if (!"".equals(reference.interfaceName())) { interfaceName = reference.interfaceName(); - } else if (! void.class.equals(reference.interfaceClass())) { + } else if (!void.class.equals(reference.interfaceClass())) { interfaceName = reference.interfaceClass().getName(); } else if (referenceClass.isInterface()) { interfaceName = referenceClass.getName(); @@ -283,30 +271,30 @@ private Object refer(Reference reference, Class referenceClass) { //method.ge List registryConfigs = new ArrayList(); for (String registryId : reference.registry()) { if (registryId != null && registryId.length() > 0) { - registryConfigs.add((RegistryConfig)applicationContext.getBean(registryId, RegistryConfig.class)); + registryConfigs.add(applicationContext.getBean(registryId, RegistryConfig.class)); } } referenceConfig.setRegistries(registryConfigs); } if (reference.consumer() != null && reference.consumer().length() > 0) { - referenceConfig.setConsumer((ConsumerConfig)applicationContext.getBean(reference.consumer(), ConsumerConfig.class)); + referenceConfig.setConsumer(applicationContext.getBean(reference.consumer(), ConsumerConfig.class)); } if (reference.monitor() != null && reference.monitor().length() > 0) { - referenceConfig.setMonitor((MonitorConfig)applicationContext.getBean(reference.monitor(), MonitorConfig.class)); + referenceConfig.setMonitor(applicationContext.getBean(reference.monitor(), MonitorConfig.class)); } if (reference.application() != null && reference.application().length() > 0) { - referenceConfig.setApplication((ApplicationConfig)applicationContext.getBean(reference.application(), ApplicationConfig.class)); + referenceConfig.setApplication(applicationContext.getBean(reference.application(), ApplicationConfig.class)); } if (reference.module() != null && reference.module().length() > 0) { - referenceConfig.setModule((ModuleConfig)applicationContext.getBean(reference.module(), ModuleConfig.class)); + referenceConfig.setModule(applicationContext.getBean(reference.module(), ModuleConfig.class)); } if (reference.consumer() != null && reference.consumer().length() > 0) { - referenceConfig.setConsumer((ConsumerConfig)applicationContext.getBean(reference.consumer(), ConsumerConfig.class)); + referenceConfig.setConsumer(applicationContext.getBean(reference.consumer(), ConsumerConfig.class)); } try { referenceConfig.afterPropertiesSet(); } catch (RuntimeException e) { - throw (RuntimeException) e; + throw e; } catch (Exception e) { throw new IllegalStateException(e.getMessage(), e); } @@ -322,7 +310,7 @@ private boolean isMatchPackage(Object bean) { return true; } Class clazz = bean.getClass(); - if(isProxyBean(bean)){ + if (isProxyBean(bean)) { clazz = AopUtils.getTargetClass(bean); } String beanClassName = clazz.getName(); diff --git a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/ReferenceBean.java b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/ReferenceBean.java index d149448739d..ab3794a57a4 100644 --- a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/ReferenceBean.java +++ b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/ReferenceBean.java @@ -15,10 +15,10 @@ */ package com.alibaba.dubbo.config.spring; -import java.util.ArrayList; -import java.util.List; -import java.util.Map; - +import com.alibaba.dubbo.config.*; +import com.alibaba.dubbo.config.annotation.Reference; +import com.alibaba.dubbo.config.spring.extension.SpringExtensionFactory; +import com.alibaba.dubbo.config.support.Parameter; import org.springframework.beans.factory.BeanFactoryUtils; import org.springframework.beans.factory.DisposableBean; import org.springframework.beans.factory.FactoryBean; @@ -26,29 +26,23 @@ import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContextAware; -import com.alibaba.dubbo.config.ApplicationConfig; -import com.alibaba.dubbo.config.ConsumerConfig; -import com.alibaba.dubbo.config.ModuleConfig; -import com.alibaba.dubbo.config.MonitorConfig; -import com.alibaba.dubbo.config.ReferenceConfig; -import com.alibaba.dubbo.config.RegistryConfig; -import com.alibaba.dubbo.config.annotation.Reference; -import com.alibaba.dubbo.config.spring.extension.SpringExtensionFactory; -import com.alibaba.dubbo.config.support.Parameter; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; /** * ReferenceFactoryBean - * + * * @author william.liangf * @export */ public class ReferenceBean extends ReferenceConfig implements FactoryBean, ApplicationContextAware, InitializingBean, DisposableBean { - private static final long serialVersionUID = 213195494150089726L; - - private transient ApplicationContext applicationContext; + private static final long serialVersionUID = 213195494150089726L; + + private transient ApplicationContext applicationContext; - public ReferenceBean() { + public ReferenceBean() { super(); } @@ -57,10 +51,10 @@ public ReferenceBean(Reference reference) { } public void setApplicationContext(ApplicationContext applicationContext) { - this.applicationContext = applicationContext; - SpringExtensionFactory.addApplicationContext(applicationContext); - } - + this.applicationContext = applicationContext; + SpringExtensionFactory.addApplicationContext(applicationContext); + } + public Object getObject() throws Exception { return get(); } @@ -74,14 +68,14 @@ public boolean isSingleton() { return true; } - @SuppressWarnings({ "unchecked"}) + @SuppressWarnings({"unchecked"}) public void afterPropertiesSet() throws Exception { if (getConsumer() == null) { - Map consumerConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ConsumerConfig.class, false, false); + Map consumerConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ConsumerConfig.class, false, false); if (consumerConfigMap != null && consumerConfigMap.size() > 0) { ConsumerConfig consumerConfig = null; for (ConsumerConfig config : consumerConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { if (consumerConfig != null) { throw new IllegalStateException("Duplicate consumer configs: " + consumerConfig + " and " + config); } @@ -99,7 +93,7 @@ public void afterPropertiesSet() throws Exception { if (applicationConfigMap != null && applicationConfigMap.size() > 0) { ApplicationConfig applicationConfig = null; for (ApplicationConfig config : applicationConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { if (applicationConfig != null) { throw new IllegalStateException("Duplicate application configs: " + applicationConfig + " and " + config); } @@ -117,7 +111,7 @@ public void afterPropertiesSet() throws Exception { if (moduleConfigMap != null && moduleConfigMap.size() > 0) { ModuleConfig moduleConfig = null; for (ModuleConfig config : moduleConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { if (moduleConfig != null) { throw new IllegalStateException("Duplicate module configs: " + moduleConfig + " and " + config); } @@ -136,7 +130,7 @@ public void afterPropertiesSet() throws Exception { if (registryConfigMap != null && registryConfigMap.size() > 0) { List registryConfigs = new ArrayList(); for (RegistryConfig config : registryConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { registryConfigs.add(config); } } @@ -152,7 +146,7 @@ public void afterPropertiesSet() throws Exception { if (monitorConfigMap != null && monitorConfigMap.size() > 0) { MonitorConfig monitorConfig = null; for (MonitorConfig config : monitorConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { if (monitorConfig != null) { throw new IllegalStateException("Duplicate monitor configs: " + monitorConfig + " and " + config); } @@ -164,11 +158,29 @@ public void afterPropertiesSet() throws Exception { } } } + + if (getTracker() == null && + (getConsumer() == null || getConsumer().getTracker() == null) && + (getApplication() == null || getApplication().getTracker() == null)) { + Map trackerConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, RpcTrackerEngineConfig.class, false, false); + if (trackerConfigMap != null && trackerConfigMap.size() > 0) { + RpcTrackerEngineConfig trackerEngineConfig = null; + for (RpcTrackerEngineConfig config : trackerConfigMap.values()) { + trackerEngineConfig = config; + } + if (trackerEngineConfig != null) { + setTracker(trackerEngineConfig); + } + } + } + + Boolean b = isInit(); if (b == null && getConsumer() != null) { b = getConsumer().isInit(); } - if (b != null && b.booleanValue()) { + if (b != null && b) { getObject(); } } diff --git a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/ServiceBean.java b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/ServiceBean.java index cc9c2a0776a..96e2d1231f3 100644 --- a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/ServiceBean.java +++ b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/ServiceBean.java @@ -15,11 +15,9 @@ */ package com.alibaba.dubbo.config.spring; -import java.lang.reflect.Method; -import java.util.ArrayList; -import java.util.List; -import java.util.Map; - +import com.alibaba.dubbo.config.*; +import com.alibaba.dubbo.config.annotation.Service; +import com.alibaba.dubbo.config.spring.extension.SpringExtensionFactory; import org.springframework.aop.support.AopUtils; import org.springframework.beans.factory.BeanFactoryUtils; import org.springframework.beans.factory.BeanNameAware; @@ -32,35 +30,30 @@ import org.springframework.context.event.ContextRefreshedEvent; import org.springframework.context.support.AbstractApplicationContext; -import com.alibaba.dubbo.config.ApplicationConfig; -import com.alibaba.dubbo.config.ModuleConfig; -import com.alibaba.dubbo.config.MonitorConfig; -import com.alibaba.dubbo.config.ProtocolConfig; -import com.alibaba.dubbo.config.ProviderConfig; -import com.alibaba.dubbo.config.RegistryConfig; -import com.alibaba.dubbo.config.ServiceConfig; -import com.alibaba.dubbo.config.annotation.Service; -import com.alibaba.dubbo.config.spring.extension.SpringExtensionFactory; +import java.lang.reflect.Method; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; /** * ServiceFactoryBean - * + * * @author william.liangf * @export */ public class ServiceBean extends ServiceConfig implements InitializingBean, DisposableBean, ApplicationContextAware, ApplicationListener, BeanNameAware { - private static final long serialVersionUID = 213195494150089726L; + private static final long serialVersionUID = 213195494150089726L; private static transient ApplicationContext SPRING_CONTEXT; - - private transient ApplicationContext applicationContext; + + private transient ApplicationContext applicationContext; private transient String beanName; private transient boolean supportedApplicationListener; - - public ServiceBean() { + + public ServiceBean() { super(); } @@ -69,33 +62,33 @@ public ServiceBean(Service service) { } public static ApplicationContext getSpringContext() { - return SPRING_CONTEXT; - } + return SPRING_CONTEXT; + } - public void setApplicationContext(ApplicationContext applicationContext) { - this.applicationContext = applicationContext; - SpringExtensionFactory.addApplicationContext(applicationContext); - if (applicationContext != null) { - SPRING_CONTEXT = applicationContext; - try { - Method method = applicationContext.getClass().getMethod("addApplicationListener", new Class[]{ApplicationListener.class}); // 兼容Spring2.0.1 - method.invoke(applicationContext, new Object[] {this}); - supportedApplicationListener = true; - } catch (Throwable t) { + public void setApplicationContext(ApplicationContext applicationContext) { + this.applicationContext = applicationContext; + SpringExtensionFactory.addApplicationContext(applicationContext); + if (applicationContext != null) { + SPRING_CONTEXT = applicationContext; + try { + Method method = applicationContext.getClass().getMethod("addApplicationListener", ApplicationListener.class); // 兼容Spring2.0.1 + method.invoke(applicationContext, this); + supportedApplicationListener = true; + } catch (Throwable t) { if (applicationContext instanceof AbstractApplicationContext) { - try { - Method method = AbstractApplicationContext.class.getDeclaredMethod("addListener", new Class[]{ApplicationListener.class}); // 兼容Spring2.0.1 - if (! method.isAccessible()) { + try { + Method method = AbstractApplicationContext.class.getDeclaredMethod("addListener", ApplicationListener.class); // 兼容Spring2.0.1 + if (!method.isAccessible()) { method.setAccessible(true); } - method.invoke(applicationContext, new Object[] {this}); + method.invoke(applicationContext, this); supportedApplicationListener = true; - } catch (Throwable t2) { - } - } - } - } - } + } catch (Throwable ignored) { + } + } + } + } + } public void setBeanName(String name) { this.beanName = name; @@ -103,7 +96,7 @@ public void setBeanName(String name) { public void onApplicationEvent(ApplicationEvent event) { if (ContextRefreshedEvent.class.getName().equals(event.getClass().getName())) { - if (isDelay() && ! isExported() && ! isUnexported()) { + if (isDelay() && !isExported() && !isUnexported()) { if (logger.isInfoEnabled()) { logger.info("The service ready on spring started. service: " + getInterface()); } @@ -111,27 +104,29 @@ public void onApplicationEvent(ApplicationEvent event) { } } } - + private boolean isDelay() { Integer delay = getDelay(); ProviderConfig provider = getProvider(); if (delay == null && provider != null) { delay = provider.getDelay(); } - return supportedApplicationListener && (delay == null || delay.intValue() == -1); + return supportedApplicationListener && (delay == null || delay == -1); } - @SuppressWarnings({ "unchecked", "deprecation" }) - public void afterPropertiesSet() throws Exception { + @SuppressWarnings({"unchecked", "deprecation"}) + public void afterPropertiesSet() throws Exception { if (getProvider() == null) { - Map providerConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ProviderConfig.class, false, false); + Map providerConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ProviderConfig.class, false, false); if (providerConfigMap != null && providerConfigMap.size() > 0) { - Map protocolConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ProtocolConfig.class, false, false); + Map protocolConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ProtocolConfig.class, false, false); if ((protocolConfigMap == null || protocolConfigMap.size() == 0) && providerConfigMap.size() > 1) { // 兼容旧版本 List providerConfigs = new ArrayList(); for (ProviderConfig config : providerConfigMap.values()) { - if (config.isDefault() != null && config.isDefault().booleanValue()) { + if (config.isDefault() != null && config.isDefault()) { providerConfigs.add(config); } } @@ -141,7 +136,7 @@ public void afterPropertiesSet() throws Exception { } else { ProviderConfig providerConfig = null; for (ProviderConfig config : providerConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { if (providerConfig != null) { throw new IllegalStateException("Duplicate provider configs: " + providerConfig + " and " + config); } @@ -156,11 +151,12 @@ public void afterPropertiesSet() throws Exception { } if (getApplication() == null && (getProvider() == null || getProvider().getApplication() == null)) { - Map applicationConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ApplicationConfig.class, false, false); + Map applicationConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ApplicationConfig.class, false, false); if (applicationConfigMap != null && applicationConfigMap.size() > 0) { ApplicationConfig applicationConfig = null; for (ApplicationConfig config : applicationConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { if (applicationConfig != null) { throw new IllegalStateException("Duplicate application configs: " + applicationConfig + " and " + config); } @@ -174,11 +170,12 @@ public void afterPropertiesSet() throws Exception { } if (getModule() == null && (getProvider() == null || getProvider().getModule() == null)) { - Map moduleConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ModuleConfig.class, false, false); + Map moduleConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ModuleConfig.class, false, false); if (moduleConfigMap != null && moduleConfigMap.size() > 0) { ModuleConfig moduleConfig = null; for (ModuleConfig config : moduleConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { if (moduleConfig != null) { throw new IllegalStateException("Duplicate module configs: " + moduleConfig + " and " + config); } @@ -193,11 +190,12 @@ public void afterPropertiesSet() throws Exception { if ((getRegistries() == null || getRegistries().size() == 0) && (getProvider() == null || getProvider().getRegistries() == null || getProvider().getRegistries().size() == 0) && (getApplication() == null || getApplication().getRegistries() == null || getApplication().getRegistries().size() == 0)) { - Map registryConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, RegistryConfig.class, false, false); + Map registryConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, RegistryConfig.class, false, false); if (registryConfigMap != null && registryConfigMap.size() > 0) { List registryConfigs = new ArrayList(); for (RegistryConfig config : registryConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { registryConfigs.add(config); } } @@ -209,11 +207,12 @@ public void afterPropertiesSet() throws Exception { if (getMonitor() == null && (getProvider() == null || getProvider().getMonitor() == null) && (getApplication() == null || getApplication().getMonitor() == null)) { - Map monitorConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, MonitorConfig.class, false, false); + Map monitorConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, MonitorConfig.class, false, false); if (monitorConfigMap != null && monitorConfigMap.size() > 0) { MonitorConfig monitorConfig = null; for (MonitorConfig config : monitorConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { if (monitorConfig != null) { throw new IllegalStateException("Duplicate monitor configs: " + monitorConfig + " and " + config); } @@ -225,13 +224,31 @@ public void afterPropertiesSet() throws Exception { } } } + + if (getTracker() == null && + (getProvider() == null || getProvider().getTracker() == null) && + (getApplication() == null || getApplication().getTracker() == null)) { + Map trackerConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, RpcTrackerEngineConfig.class, false, false); + if (trackerConfigMap != null && trackerConfigMap.size() > 0) { + RpcTrackerEngineConfig trackerEngineConfig = null; + for (RpcTrackerEngineConfig config : trackerConfigMap.values()) { + trackerEngineConfig = config; + } + if (trackerEngineConfig != null) { + setTracker(trackerEngineConfig); + } + } + } + if ((getProtocols() == null || getProtocols().size() == 0) && (getProvider() == null || getProvider().getProtocols() == null || getProvider().getProtocols().size() == 0)) { - Map protocolConfigMap = applicationContext == null ? null : BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ProtocolConfig.class, false, false); + Map protocolConfigMap = applicationContext == null ? null : + BeanFactoryUtils.beansOfTypeIncludingAncestors(applicationContext, ProtocolConfig.class, false, false); if (protocolConfigMap != null && protocolConfigMap.size() > 0) { List protocolConfigs = new ArrayList(); for (ProtocolConfig config : protocolConfigMap.values()) { - if (config.isDefault() == null || config.isDefault().booleanValue()) { + if (config.isDefault() == null || config.isDefault()) { protocolConfigs.add(config); } } @@ -241,13 +258,13 @@ public void afterPropertiesSet() throws Exception { } } if (getPath() == null || getPath().length() == 0) { - if (beanName != null && beanName.length() > 0 + if (beanName != null && beanName.length() > 0 && getInterface() != null && getInterface().length() > 0 && beanName.startsWith(getInterface())) { setPath(beanName); } } - if (! isDelay()) { + if (!isDelay()) { export(); } } diff --git a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/schema/DubboBeanDefinitionParser.java b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/schema/DubboBeanDefinitionParser.java index c95f8c51546..28ee29ef744 100644 --- a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/schema/DubboBeanDefinitionParser.java +++ b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/schema/DubboBeanDefinitionParser.java @@ -15,13 +15,16 @@ */ package com.alibaba.dubbo.config.spring.schema; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.util.Date; -import java.util.HashSet; -import java.util.Set; -import java.util.regex.Pattern; - +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.extension.ExtensionLoader; +import com.alibaba.dubbo.common.logger.Logger; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.common.utils.ReflectUtils; +import com.alibaba.dubbo.common.utils.StringUtils; +import com.alibaba.dubbo.config.*; +import com.alibaba.dubbo.config.spring.ReferenceBean; +import com.alibaba.dubbo.config.spring.ServiceBean; +import com.alibaba.dubbo.rpc.Protocol; import org.springframework.beans.PropertyValue; import org.springframework.beans.factory.config.BeanDefinition; import org.springframework.beans.factory.config.BeanDefinitionHolder; @@ -33,39 +36,26 @@ import org.springframework.beans.factory.xml.BeanDefinitionParser; import org.springframework.beans.factory.xml.ParserContext; import org.w3c.dom.Element; -import org.w3c.dom.NamedNodeMap; import org.w3c.dom.Node; import org.w3c.dom.NodeList; -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.utils.ReflectUtils; -import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.config.ArgumentConfig; -import com.alibaba.dubbo.config.ConsumerConfig; -import com.alibaba.dubbo.config.MethodConfig; -import com.alibaba.dubbo.config.MonitorConfig; -import com.alibaba.dubbo.config.ProtocolConfig; -import com.alibaba.dubbo.config.ProviderConfig; -import com.alibaba.dubbo.config.RegistryConfig; -import com.alibaba.dubbo.config.spring.ReferenceBean; -import com.alibaba.dubbo.config.spring.ServiceBean; -import com.alibaba.dubbo.rpc.Protocol; +import java.lang.reflect.Method; +import java.lang.reflect.Modifier; +import java.util.Date; +import java.util.regex.Pattern; /** * AbstractBeanDefinitionParser - * + * * @author william.liangf * @export */ public class DubboBeanDefinitionParser implements BeanDefinitionParser { - + private static final Logger logger = LoggerFactory.getLogger(DubboBeanDefinitionParser.class); - + private final Class beanClass; - + private final boolean required; public DubboBeanDefinitionParser(Class beanClass, boolean required) { @@ -76,7 +66,7 @@ public DubboBeanDefinitionParser(Class beanClass, boolean required) { public BeanDefinition parse(Element element, ParserContext parserContext) { return parse(element, parserContext, beanClass, required); } - + @SuppressWarnings("unchecked") private static BeanDefinition parse(Element element, ParserContext parserContext, Class beanClass, boolean required) { RootBeanDefinition beanDefinition = new RootBeanDefinition(); @@ -84,36 +74,41 @@ private static BeanDefinition parse(Element element, ParserContext parserContext beanDefinition.setLazyInit(false); String id = element.getAttribute("id"); if ((id == null || id.length() == 0) && required) { - String generatedBeanName = element.getAttribute("name"); - if (generatedBeanName == null || generatedBeanName.length() == 0) { - if (ProtocolConfig.class.equals(beanClass)) { - generatedBeanName = "dubbo"; - } else { - generatedBeanName = element.getAttribute("interface"); - } - } - if (generatedBeanName == null || generatedBeanName.length() == 0) { - generatedBeanName = beanClass.getName(); - } - id = generatedBeanName; + String generatedBeanName = element.getAttribute("name"); + if (generatedBeanName == null || generatedBeanName.length() == 0) { + if (ProtocolConfig.class.equals(beanClass)) { + generatedBeanName = "dubbo"; + } else { + generatedBeanName = element.getAttribute("interface"); + } + } + if (generatedBeanName == null || generatedBeanName.length() == 0) { + generatedBeanName = beanClass.getName(); + } + id = generatedBeanName; int counter = 2; - while(parserContext.getRegistry().containsBeanDefinition(id)) { - id = generatedBeanName + (counter ++); + while (parserContext.getRegistry().containsBeanDefinition(id)) { + id = generatedBeanName + (counter++); } } if (id != null && id.length() > 0) { - if (parserContext.getRegistry().containsBeanDefinition(id)) { - throw new IllegalStateException("Duplicate spring bean id " + id); - } + if (parserContext.getRegistry().containsBeanDefinition(id)) { + throw new IllegalStateException("Duplicate spring bean id " + id); + } parserContext.getRegistry().registerBeanDefinition(id, beanDefinition); beanDefinition.getPropertyValues().addPropertyValue("id", id); } + String destroyMethodName = element.getAttribute("destroy-method"); + if (!StringUtils.isEmpty(destroyMethodName)) { + beanDefinition.setDestroyMethodName(destroyMethodName); + } if (ProtocolConfig.class.equals(beanClass)) { for (String name : parserContext.getRegistry().getBeanDefinitionNames()) { BeanDefinition definition = parserContext.getRegistry().getBeanDefinition(name); PropertyValue property = definition.getPropertyValues().getPropertyValue("protocol"); if (property != null) { Object value = property.getValue(); + assert id != null; if (value instanceof ProtocolConfig && id.equals(((ProtocolConfig) value).getName())) { definition.getPropertyValues().addPropertyValue("protocol", new RuntimeBeanReference(id)); } @@ -121,7 +116,7 @@ private static BeanDefinition parse(Element element, ParserContext parserContext } } else if (ServiceBean.class.equals(beanClass)) { String className = element.getAttribute("class"); - if(className != null && className.length() > 0) { + if (className != null && className.length() > 0) { RootBeanDefinition classDefinition = new RootBeanDefinition(); classDefinition.setBeanClass(ReflectUtils.forName(className)); classDefinition.setLazyInit(false); @@ -133,7 +128,6 @@ private static BeanDefinition parse(Element element, ParserContext parserContext } else if (ConsumerConfig.class.equals(beanClass)) { parseNested(element, parserContext, ReferenceBean.class, false, "reference", "consumer", id, beanDefinition); } - Set props = new HashSet(); ManagedMap parameters = null; for (Method setter : beanClass.getMethods()) { String name = setter.getName(); @@ -142,23 +136,25 @@ private static BeanDefinition parse(Element element, ParserContext parserContext && setter.getParameterTypes().length == 1) { Class type = setter.getParameterTypes()[0]; String property = StringUtils.camelToSplitName(name.substring(3, 4).toLowerCase() + name.substring(4), "-"); - props.add(property); Method getter = null; try { - getter = beanClass.getMethod("get" + name.substring(3), new Class[0]); + getter = beanClass.getMethod("get" + name.substring(3)); } catch (NoSuchMethodException e) { try { - getter = beanClass.getMethod("is" + name.substring(3), new Class[0]); - } catch (NoSuchMethodException e2) { + getter = beanClass.getMethod("is" + name.substring(3)); + } catch (NoSuchMethodException ignored) { } } - if (getter == null - || ! Modifier.isPublic(getter.getModifiers()) - || ! type.equals(getter.getReturnType())) { + if (getter == null + || !Modifier.isPublic(getter.getModifiers()) + || !type.equals(getter.getReturnType())) { continue; } if ("parameters".equals(property)) { parameters = parseParameters(element.getChildNodes(), beanDefinition); + if (parameters != null) { + beanDefinition.getPropertyValues().addPropertyValue("parameters", parameters); + } } else if ("methods".equals(property)) { parseMethods(id, element.getChildNodes(), beanDefinition, parserContext); } else if ("arguments".equals(property)) { @@ -166,16 +162,16 @@ private static BeanDefinition parse(Element element, ParserContext parserContext } else { String value = element.getAttribute(property); if (value != null) { - value = value.trim(); - if (value.length() > 0) { - if ("registry".equals(property) && RegistryConfig.NO_AVAILABLE.equalsIgnoreCase(value)) { - RegistryConfig registryConfig = new RegistryConfig(); - registryConfig.setAddress(RegistryConfig.NO_AVAILABLE); - beanDefinition.getPropertyValues().addPropertyValue(property, registryConfig); + value = value.trim(); + if (value.length() > 0) { + if ("registry".equals(property) && RegistryConfig.NO_AVAILABLE.equalsIgnoreCase(value)) { + RegistryConfig registryConfig = new RegistryConfig(); + registryConfig.setAddress(RegistryConfig.NO_AVAILABLE); + beanDefinition.getPropertyValues().addPropertyValue(property, registryConfig); } else if ("registry".equals(property) && value.indexOf(',') != -1) { - parseMultiRef("registries", value, beanDefinition, parserContext); + parseMultiRef("registries", value, beanDefinition, parserContext); } else if ("provider".equals(property) && value.indexOf(',') != -1) { - parseMultiRef("providers", value, beanDefinition, parserContext); + parseMultiRef("providers", value, beanDefinition, parserContext); } else if ("protocol".equals(property) && value.indexOf(',') != -1) { parseMultiRef("protocols", value, beanDefinition, parserContext); } else { @@ -191,10 +187,10 @@ private static BeanDefinition parse(Element element, ParserContext parserContext value = null; } reference = value; - } else if ("protocol".equals(property) + } else if ("protocol".equals(property) && ExtensionLoader.getExtensionLoader(Protocol.class).hasExtension(value) - && (! parserContext.getRegistry().containsBeanDefinition(value) - || ! ProtocolConfig.class.getName().equals(parserContext.getRegistry().getBeanDefinition(value).getBeanClassName()))) { + && (!parserContext.getRegistry().containsBeanDefinition(value) + || !ProtocolConfig.class.getName().equals(parserContext.getRegistry().getBeanDefinition(value).getBeanClassName()))) { if ("dubbo:provider".equals(element.getTagName())) { logger.warn("Recommended replace to "); } @@ -202,9 +198,9 @@ private static BeanDefinition parse(Element element, ParserContext parserContext ProtocolConfig protocol = new ProtocolConfig(); protocol.setName(value); reference = protocol; - } else if ("monitor".equals(property) - && (! parserContext.getRegistry().containsBeanDefinition(value) - || ! MonitorConfig.class.getName().equals(parserContext.getRegistry().getBeanDefinition(value).getBeanClassName()))) { + } else if ("monitor".equals(property) + && (!parserContext.getRegistry().containsBeanDefinition(value) + || !MonitorConfig.class.getName().equals(parserContext.getRegistry().getBeanDefinition(value).getBeanClassName()))) { // 兼容旧版本配置 reference = convertMonitor(value); } else if ("onreturn".equals(property)) { @@ -222,40 +218,24 @@ private static BeanDefinition parse(Element element, ParserContext parserContext } else { if ("ref".equals(property) && parserContext.getRegistry().containsBeanDefinition(value)) { BeanDefinition refBean = parserContext.getRegistry().getBeanDefinition(value); - if (! refBean.isSingleton()) { - throw new IllegalStateException("The exported service ref " + value + " must be singleton! Please set the " + value + " bean scope to singleton, eg: "); + if (!refBean.isSingleton()) { + throw new IllegalStateException("The exported service ref " + value + " must be singleton! Please set the " + value + " bean scope to singleton, eg: "); } } reference = new RuntimeBeanReference(value); } - beanDefinition.getPropertyValues().addPropertyValue(property, reference); + beanDefinition.getPropertyValues().addPropertyValue(property, reference); } - } + } } } } } - NamedNodeMap attributes = element.getAttributes(); - int len = attributes.getLength(); - for (int i = 0; i < len; i++) { - Node node = attributes.item(i); - String name = node.getLocalName(); - if (! props.contains(name)) { - if (parameters == null) { - parameters = new ManagedMap(); - } - String value = node.getNodeValue(); - parameters.put(name, new TypedStringValue(value, String.class)); - } - } - if (parameters != null) { - beanDefinition.getPropertyValues().addPropertyValue("parameters", parameters); - } return beanDefinition; } private static final Pattern GROUP_AND_VERION = Pattern.compile("^[\\-.0-9_a-zA-Z]+(\\:[\\-.0-9_a-zA-Z]+)?$"); - + protected static MonitorConfig convertMonitor(String monitor) { if (monitor == null || monitor.length() == 0) { return null; @@ -278,31 +258,30 @@ protected static MonitorConfig convertMonitor(String monitor) { } return null; } - + private static boolean isPrimitive(Class cls) { return cls.isPrimitive() || cls == Boolean.class || cls == Byte.class || cls == Character.class || cls == Short.class || cls == Integer.class || cls == Long.class || cls == Float.class || cls == Double.class || cls == String.class || cls == Date.class || cls == Class.class; } - + @SuppressWarnings("unchecked") - private static void parseMultiRef(String property, String value, RootBeanDefinition beanDefinition, - ParserContext parserContext) { - String[] values = value.split("\\s*[,]+\\s*"); - ManagedList list = null; - for (int i = 0; i < values.length; i++) { - String v = values[i]; + private static void parseMultiRef(String property, String value, RootBeanDefinition beanDefinition, + ParserContext parserContext) { + String[] values = value.split("\\s*[,]+\\s*"); + ManagedList list = null; + for (String v : values) { if (v != null && v.length() > 0) { - if (list == null) { + if (list == null) { list = new ManagedList(); } - list.add(new RuntimeBeanReference(v)); + list.add(new RuntimeBeanReference(v)); } } beanDefinition.getPropertyValues().addPropertyValue(property, list); } - + private static void parseNested(Element element, ParserContext parserContext, Class beanClass, boolean required, String tag, String property, String ref, BeanDefinition beanDefinition) { NodeList nodeList = element.getChildNodes(); if (nodeList != null && nodeList.getLength() > 0) { @@ -383,7 +362,7 @@ private static ManagedMap parseParameters(NodeList nodeList, RootBeanDefinition @SuppressWarnings("unchecked") private static void parseMethods(String id, NodeList nodeList, RootBeanDefinition beanDefinition, - ParserContext parserContext) { + ParserContext parserContext) { if (nodeList != null && nodeList.getLength() > 0) { ManagedList methods = null; for (int i = 0; i < nodeList.getLength(); i++) { @@ -412,10 +391,10 @@ private static void parseMethods(String id, NodeList nodeList, RootBeanDefinitio } } } - + @SuppressWarnings("unchecked") private static void parseArguments(String id, NodeList nodeList, RootBeanDefinition beanDefinition, - ParserContext parserContext) { + ParserContext parserContext) { if (nodeList != null && nodeList.getLength() > 0) { ManagedList arguments = null; for (int i = 0; i < nodeList.getLength(); i++) { diff --git a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/schema/DubboNamespaceHandler.java b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/schema/DubboNamespaceHandler.java index 4afe4a42828..1867004296b 100644 --- a/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/schema/DubboNamespaceHandler.java +++ b/dubbo-config/dubbo-config-spring/src/main/java/com/alibaba/dubbo/config/spring/schema/DubboNamespaceHandler.java @@ -15,34 +15,27 @@ */ package com.alibaba.dubbo.config.spring.schema; -import org.springframework.beans.factory.xml.NamespaceHandlerSupport; - import com.alibaba.dubbo.common.Version; -import com.alibaba.dubbo.config.ApplicationConfig; -import com.alibaba.dubbo.config.ConsumerConfig; -import com.alibaba.dubbo.config.ModuleConfig; -import com.alibaba.dubbo.config.MonitorConfig; -import com.alibaba.dubbo.config.ProtocolConfig; -import com.alibaba.dubbo.config.ProviderConfig; -import com.alibaba.dubbo.config.RegistryConfig; +import com.alibaba.dubbo.config.*; import com.alibaba.dubbo.config.spring.AnnotationBean; import com.alibaba.dubbo.config.spring.ReferenceBean; import com.alibaba.dubbo.config.spring.ServiceBean; +import org.springframework.beans.factory.xml.NamespaceHandlerSupport; /** * DubboNamespaceHandler - * + * * @author william.liangf * @export */ public class DubboNamespaceHandler extends NamespaceHandlerSupport { - static { - Version.checkDuplicate(DubboNamespaceHandler.class); - } + static { + Version.checkDuplicate(DubboNamespaceHandler.class); + } - public void init() { - registerBeanDefinitionParser("application", new DubboBeanDefinitionParser(ApplicationConfig.class, true)); + public void init() { + registerBeanDefinitionParser("application", new DubboBeanDefinitionParser(ApplicationConfig.class, true)); registerBeanDefinitionParser("module", new DubboBeanDefinitionParser(ModuleConfig.class, true)); registerBeanDefinitionParser("registry", new DubboBeanDefinitionParser(RegistryConfig.class, true)); registerBeanDefinitionParser("monitor", new DubboBeanDefinitionParser(MonitorConfig.class, true)); @@ -52,6 +45,6 @@ public void init() { registerBeanDefinitionParser("service", new DubboBeanDefinitionParser(ServiceBean.class, true)); registerBeanDefinitionParser("reference", new DubboBeanDefinitionParser(ReferenceBean.class, false)); registerBeanDefinitionParser("annotation", new DubboBeanDefinitionParser(AnnotationBean.class, true)); + registerBeanDefinitionParser("tracker", new DubboBeanDefinitionParser(RpcTrackerEngineConfig.class, true)); } - } \ No newline at end of file diff --git a/dubbo-config/dubbo-config-spring/src/main/resources/META-INF/dubbo.xsd b/dubbo-config/dubbo-config-spring/src/main/resources/META-INF/dubbo.xsd index d0168856cd4..001105e4d36 100644 --- a/dubbo-config/dubbo-config-spring/src/main/resources/META-INF/dubbo.xsd +++ b/dubbo-config/dubbo-config-spring/src/main/resources/META-INF/dubbo.xsd @@ -1,783 +1,849 @@ - - - - + xmlns:xsd="http://www.w3.org/2001/XMLSchema" + xmlns:beans="http://www.springframework.org/schema/beans" + xmlns:tool="http://www.springframework.org/schema/tool" + targetNamespace="http://code.alibabatech.com/schema/dubbo"> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -796,387 +862,397 @@ - - - + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/dubbo-config/dubbo-config-spring/src/test/java/com/alibaba/dubbo/config/spring/ConfigTest.java b/dubbo-config/dubbo-config-spring/src/test/java/com/alibaba/dubbo/config/spring/ConfigTest.java index 71d81d3d7af..44894330b90 100644 --- a/dubbo-config/dubbo-config-spring/src/test/java/com/alibaba/dubbo/config/spring/ConfigTest.java +++ b/dubbo-config/dubbo-config-spring/src/test/java/com/alibaba/dubbo/config/spring/ConfigTest.java @@ -415,8 +415,6 @@ public void test_RpcContext_getUrls() throws Exception { } catch (RpcException expected) { assertThat(expected.getMessage(), containsString("Tried 3 times")); } - - assertEquals(3, RpcContext.getContext().getUrls().size()); } finally { ctx.stop(); ctx.close(); @@ -447,8 +445,6 @@ public void test_retrySettingFail() throws Exception { } catch (RpcException expected) { assertThat(expected.getMessage(), containsString("Tried 1 times")); } - - assertEquals(1, RpcContext.getContext().getUrls().size()); } finally { ctx.stop(); ctx.close(); diff --git a/dubbo-config/pom.xml b/dubbo-config/pom.xml index 925195632b1..f1971823a66 100644 --- a/dubbo-config/pom.xml +++ b/dubbo-config/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-config pom diff --git a/dubbo-container/dubbo-container-api/pom.xml b/dubbo-container/dubbo-container-api/pom.xml index 3cb4bda94c4..a33f0c356a3 100644 --- a/dubbo-container/dubbo-container-api/pom.xml +++ b/dubbo-container/dubbo-container-api/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-container - 2.8.4 + 3.0.1 dubbo-container-api jar diff --git a/dubbo-container/dubbo-container-javaconfig/pom.xml b/dubbo-container/dubbo-container-javaconfig/pom.xml index 3cc3985b60e..1b3116919d2 100644 --- a/dubbo-container/dubbo-container-javaconfig/pom.xml +++ b/dubbo-container/dubbo-container-javaconfig/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-container - 2.8.4 + 3.0.1 dubbo-container-javaconfig jar diff --git a/dubbo-container/dubbo-container-jetty/pom.xml b/dubbo-container/dubbo-container-jetty/pom.xml index 3fd180fb91a..0fbbbb08fd6 100644 --- a/dubbo-container/dubbo-container-jetty/pom.xml +++ b/dubbo-container/dubbo-container-jetty/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-container - 2.8.4 + 3.0.1 dubbo-container-jetty jar diff --git a/dubbo-container/dubbo-container-jetty/src/main/java/com/alibaba/dubbo/container/jetty/JettyContainer.java b/dubbo-container/dubbo-container-jetty/src/main/java/com/alibaba/dubbo/container/jetty/JettyContainer.java index e9fae863480..49879baa94e 100644 --- a/dubbo-container/dubbo-container-jetty/src/main/java/com/alibaba/dubbo/container/jetty/JettyContainer.java +++ b/dubbo-container/dubbo-container-jetty/src/main/java/com/alibaba/dubbo/container/jetty/JettyContainer.java @@ -15,13 +15,6 @@ */ package com.alibaba.dubbo.container.jetty; -import org.mortbay.jetty.Handler; -import org.mortbay.jetty.Server; -import org.mortbay.jetty.nio.SelectChannelConnector; -import org.mortbay.jetty.servlet.FilterHolder; -import org.mortbay.jetty.servlet.ServletHandler; -import org.mortbay.jetty.servlet.ServletHolder; - import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.ConfigUtils; @@ -29,10 +22,16 @@ import com.alibaba.dubbo.container.Container; import com.alibaba.dubbo.container.page.PageServlet; import com.alibaba.dubbo.container.page.ResourceFilter; +import org.mortbay.jetty.Handler; +import org.mortbay.jetty.Server; +import org.mortbay.jetty.nio.SelectChannelConnector; +import org.mortbay.jetty.servlet.FilterHolder; +import org.mortbay.jetty.servlet.ServletHandler; +import org.mortbay.jetty.servlet.ServletHolder; /** * JettyContainer. (SPI, Singleton, ThreadSafe) - * + * * @author william.liangf */ public class JettyContainer implements Container { @@ -60,17 +59,17 @@ public void start() { connector = new SelectChannelConnector(); connector.setPort(port); ServletHandler handler = new ServletHandler(); - + String resources = ConfigUtils.getProperty(JETTY_DIRECTORY); if (resources != null && resources.length() > 0) { FilterHolder resourceHolder = handler.addFilterWithMapping(ResourceFilter.class, "/*", Handler.DEFAULT); resourceHolder.setInitParameter("resources", resources); } - + ServletHolder pageHolder = handler.addServletWithMapping(PageServlet.class, "/*"); pageHolder.setInitParameter("pages", ConfigUtils.getProperty(JETTY_PAGES)); pageHolder.setInitOrder(2); - + Server server = new Server(); server.addConnector(connector); server.addHandler(handler); diff --git a/dubbo-container/dubbo-container-log4j/pom.xml b/dubbo-container/dubbo-container-log4j/pom.xml index be4637f3263..97bfcc30d31 100644 --- a/dubbo-container/dubbo-container-log4j/pom.xml +++ b/dubbo-container/dubbo-container-log4j/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-container - 2.8.4 + 3.0.1 dubbo-container-log4j jar diff --git a/dubbo-container/dubbo-container-logback/pom.xml b/dubbo-container/dubbo-container-logback/pom.xml index a123294937e..738986bf90b 100644 --- a/dubbo-container/dubbo-container-logback/pom.xml +++ b/dubbo-container/dubbo-container-logback/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-container - 2.8.4 + 3.0.1 dubbo-container-logback jar diff --git a/dubbo-container/dubbo-container-spring/pom.xml b/dubbo-container/dubbo-container-spring/pom.xml index 9564561a899..122e4d343ac 100644 --- a/dubbo-container/dubbo-container-spring/pom.xml +++ b/dubbo-container/dubbo-container-spring/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-container - 2.8.4 + 3.0.1 dubbo-container-spring jar diff --git a/dubbo-container/pom.xml b/dubbo-container/pom.xml index b277ac00762..1803f60600b 100644 --- a/dubbo-container/pom.xml +++ b/dubbo-container/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-container pom diff --git a/dubbo-demo/dubbo-demo-api/pom.xml b/dubbo-demo/dubbo-demo-api/pom.xml index a311efe313b..0cd1c04fe68 100644 --- a/dubbo-demo/dubbo-demo-api/pom.xml +++ b/dubbo-demo/dubbo-demo-api/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-demo - 2.8.4 + 3.0.1 dubbo-demo-api jar diff --git a/dubbo-demo/dubbo-demo-api/src/main/java/com/alibaba/dubbo/demo/bid/BidService.java b/dubbo-demo/dubbo-demo-api/src/main/java/com/alibaba/dubbo/demo/bid/BidService.java index 31ed65d0ad4..ad6bbc974c6 100644 --- a/dubbo-demo/dubbo-demo-api/src/main/java/com/alibaba/dubbo/demo/bid/BidService.java +++ b/dubbo-demo/dubbo-demo-api/src/main/java/com/alibaba/dubbo/demo/bid/BidService.java @@ -1,12 +1,12 @@ /** * Copyright 1999-2014 dangdang.com. - * + *

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -17,7 +17,8 @@ public interface BidService { - BidResponse bid(BidRequest request); + BidResponse bid(BidRequest request); void throwNPE() throws NullPointerException; + } \ No newline at end of file diff --git a/dubbo-demo/dubbo-demo-consumer/pom.xml b/dubbo-demo/dubbo-demo-consumer/pom.xml index 3e2427967bb..449d7181cf6 100644 --- a/dubbo-demo/dubbo-demo-consumer/pom.xml +++ b/dubbo-demo/dubbo-demo-consumer/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-demo - 2.8.4 + 3.0.1 dubbo-demo-consumer jar diff --git a/dubbo-demo/dubbo-demo-consumer/src/main/java/com/alibaba/dubbo/demo/consumer/DemoAction.java b/dubbo-demo/dubbo-demo-consumer/src/main/java/com/alibaba/dubbo/demo/consumer/DemoAction.java index b6138e729ad..2984a9dd9e9 100644 --- a/dubbo-demo/dubbo-demo-consumer/src/main/java/com/alibaba/dubbo/demo/consumer/DemoAction.java +++ b/dubbo-demo/dubbo-demo-consumer/src/main/java/com/alibaba/dubbo/demo/consumer/DemoAction.java @@ -15,13 +15,11 @@ */ package com.alibaba.dubbo.demo.consumer; -import java.util.ArrayList; -import java.util.List; - import com.alibaba.dubbo.demo.bid.*; -import com.alibaba.dubbo.demo.user.User; import com.alibaba.dubbo.demo.user.facade.AnotherUserRestService; -import com.alibaba.dubbo.rpc.RpcContext; + +import java.util.ArrayList; +import java.util.List; public class DemoAction { @@ -38,7 +36,7 @@ public void setAnotherUserRestService(AnotherUserRestService anotherUserRestServ } public void start() throws Exception { - BidRequest request = new BidRequest(); + final BidRequest request = new BidRequest(); Impression imp = new Impression(); imp.setBidFloor(1.1); @@ -62,14 +60,7 @@ public void start() throws Exception { device.setGeo(geo); request.setDevice(device); -// long start = System.currentTimeMillis(); - -// for (int i = 0; i < 10000; i ++) { -// System.out.println(bidService.bid(request).getId()); System.out.println("SUCCESS: got bid response id: " + bidService.bid(request).getId()); -// } - -// System.out.println(">>>>> Total time consumed:" + (System.currentTimeMillis() - start)); try { bidService.throwNPE(); @@ -77,13 +68,7 @@ public void start() throws Exception { } catch (NullPointerException e) { System.out.println("SUCCESS: caught exception " + e.getClass()); } - - User user = new User(1L, "larrypage"); - System.out.println("SUCCESS: registered user with id " + anotherUserRestService.registerUser(user).getId()); - - RpcContext.getContext().setAttachment("clientName", "demo"); - RpcContext.getContext().setAttachment("clientImpl", "dubbox"); - System.out.println("SUCCESS: got user " + anotherUserRestService.getUser(1L)); + Thread.sleep(2000); } } \ No newline at end of file diff --git a/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-action.xml b/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-action.xml index fb7662ca000..3d4725c8393 100644 --- a/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-action.xml +++ b/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-action.xml @@ -22,7 +22,7 @@ - + \ No newline at end of file diff --git a/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-consumer.xml b/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-consumer.xml index 6dd555c68f9..09959c11d9c 100644 --- a/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-consumer.xml +++ b/dubbo-demo/dubbo-demo-consumer/src/main/resources/META-INF/spring/dubbo-demo-consumer.xml @@ -1,21 +1,24 @@ + + - - + + + + - \ No newline at end of file diff --git a/dubbo-demo/dubbo-demo-provider/pom.xml b/dubbo-demo/dubbo-demo-provider/pom.xml index 1d6192f7aec..6451ad4959e 100644 --- a/dubbo-demo/dubbo-demo-provider/pom.xml +++ b/dubbo-demo/dubbo-demo-provider/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-demo - 2.8.4 + 3.0.1 dubbo-demo-provider war diff --git a/dubbo-demo/dubbo-demo-provider/src/main/java/com/alibaba/dubbo/demo/bid/BidServiceImpl.java b/dubbo-demo/dubbo-demo-provider/src/main/java/com/alibaba/dubbo/demo/bid/BidServiceImpl.java index 391ffbc3a81..4ebcdd7ef2c 100644 --- a/dubbo-demo/dubbo-demo-provider/src/main/java/com/alibaba/dubbo/demo/bid/BidServiceImpl.java +++ b/dubbo-demo/dubbo-demo-provider/src/main/java/com/alibaba/dubbo/demo/bid/BidServiceImpl.java @@ -1,12 +1,12 @@ /** * Copyright 1999-2014 dangdang.com. - * + *

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. diff --git a/dubbo-demo/dubbo-demo-provider/src/main/java/com/alibaba/dubbo/demo/user/facade/AnnotationDrivenUserRestServiceImpl.java b/dubbo-demo/dubbo-demo-provider/src/main/java/com/alibaba/dubbo/demo/user/facade/AnnotationDrivenUserRestServiceImpl.java index e7dd278dacd..b9694a17bc1 100644 --- a/dubbo-demo/dubbo-demo-provider/src/main/java/com/alibaba/dubbo/demo/user/facade/AnnotationDrivenUserRestServiceImpl.java +++ b/dubbo-demo/dubbo-demo-provider/src/main/java/com/alibaba/dubbo/demo/user/facade/AnnotationDrivenUserRestServiceImpl.java @@ -32,7 +32,7 @@ /** * @author lishen */ -@Service(protocol = {"rest", "dubbo"}, group = "annotationConfig", validation = "true") +//@Service(protocol = {"rest", "dubbo"}, group = "annotationConfig", validation = "true") @Path("customers") @Consumes({MediaType.APPLICATION_JSON, MediaType.TEXT_XML}) @Produces({ContentType.APPLICATION_JSON_UTF_8, ContentType.TEXT_XML_UTF_8}) diff --git a/dubbo-demo/dubbo-demo-provider/src/main/resources/META-INF/spring/dubbo-demo-provider.xml b/dubbo-demo/dubbo-demo-provider/src/main/resources/META-INF/spring/dubbo-demo-provider.xml index 265645ab00b..ccbb5a1d2df 100644 --- a/dubbo-demo/dubbo-demo-provider/src/main/resources/META-INF/spring/dubbo-demo-provider.xml +++ b/dubbo-demo/dubbo-demo-provider/src/main/resources/META-INF/spring/dubbo-demo-provider.xml @@ -15,28 +15,32 @@ - limitations under the License. --> + + + + - + - + - + @@ -47,32 +51,33 @@ - + + + + + + + - - - + + + - + - + - - + + - + - + @@ -81,4 +86,11 @@ + + + + + + + \ No newline at end of file diff --git a/dubbo-demo/dubbo-demo-provider/src/test/java/com/alibaba/dubbo/demo/provider/DemoProvider.java b/dubbo-demo/dubbo-demo-provider/src/test/java/com/alibaba/dubbo/demo/provider/DemoProvider.java index b00688c9efc..d884a1dde25 100644 --- a/dubbo-demo/dubbo-demo-provider/src/test/java/com/alibaba/dubbo/demo/provider/DemoProvider.java +++ b/dubbo-demo/dubbo-demo-provider/src/test/java/com/alibaba/dubbo/demo/provider/DemoProvider.java @@ -15,11 +15,9 @@ */ package com.alibaba.dubbo.demo.provider; -import com.alibaba.dubbo.config.ProtocolConfig; - public class DemoProvider { - public static void main(String[] args) { + public static void main(String[] args) { // new Thread(new Runnable() { // public void run() { // try { diff --git a/dubbo-demo/pom.xml b/dubbo-demo/pom.xml index 4d77e14ec9a..55d990034a1 100644 --- a/dubbo-demo/pom.xml +++ b/dubbo-demo/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-demo pom diff --git a/dubbo-filter/dubbo-filter-cache/pom.xml b/dubbo-filter/dubbo-filter-cache/pom.xml index 8431bef623d..252f6edeef2 100644 --- a/dubbo-filter/dubbo-filter-cache/pom.xml +++ b/dubbo-filter/dubbo-filter-cache/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-filter - 2.8.4 + 3.0.1 dubbo-filter-cache jar diff --git a/dubbo-filter/dubbo-filter-cache/src/main/java/com/alibaba/dubbo/cache/filter/CacheFilter.java b/dubbo-filter/dubbo-filter-cache/src/main/java/com/alibaba/dubbo/cache/filter/CacheFilter.java index 4d4e4d3b306..59593073ada 100644 --- a/dubbo-filter/dubbo-filter-cache/src/main/java/com/alibaba/dubbo/cache/filter/CacheFilter.java +++ b/dubbo-filter/dubbo-filter-cache/src/main/java/com/alibaba/dubbo/cache/filter/CacheFilter.java @@ -21,16 +21,11 @@ import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.utils.ConfigUtils; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.rpc.Filter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcResult; +import com.alibaba.dubbo.rpc.*; /** * CacheFilter - * + * * @author william.liangf */ @Activate(group = {Constants.CONSUMER, Constants.PROVIDER}, value = Constants.CACHE_KEY) @@ -47,20 +42,17 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept Cache cache = cacheFactory.getCache(invoker.getUrl().addParameter(Constants.METHOD_KEY, invocation.getMethodName())); if (cache != null) { String key = StringUtils.toArgumentString(invocation.getArguments()); - if (cache != null && key != null) { - Object value = cache.get(key); - if (value != null) { - return new RpcResult(value); - } - Result result = invoker.invoke(invocation); - if (! result.hasException()) { - cache.put(key, result.getValue()); - } - return result; + Object value = cache.get(key); + if (value != null) { + return new RpcResult(value); } + Result result = invoker.invoke(invocation); + if (!result.hasException()) { + cache.put(key, result.getValue()); + } + return result; } } return invoker.invoke(invocation); } - } diff --git a/dubbo-filter/dubbo-filter-cache/src/main/java/com/alibaba/dubbo/cache/support/lru/LruCache.java b/dubbo-filter/dubbo-filter-cache/src/main/java/com/alibaba/dubbo/cache/support/lru/LruCache.java index 33609dcc1e1..e6e0cb0b851 100644 --- a/dubbo-filter/dubbo-filter-cache/src/main/java/com/alibaba/dubbo/cache/support/lru/LruCache.java +++ b/dubbo-filter/dubbo-filter-cache/src/main/java/com/alibaba/dubbo/cache/support/lru/LruCache.java @@ -15,28 +15,28 @@ */ package com.alibaba.dubbo.cache.support.lru; -import java.util.LinkedHashMap; -import java.util.Map; -import java.util.Map.Entry; - import com.alibaba.dubbo.cache.Cache; import com.alibaba.dubbo.common.URL; +import java.util.LinkedHashMap; +import java.util.Map; + /** * LruCache - * + * * @author william.liangf */ public class LruCache implements Cache { - + private final Map store; public LruCache(URL url) { final int max = url.getParameter("cache.size", 1000); - this.store = new LinkedHashMap() { + this.store = new LinkedHashMap(16, 0.75f, true) { private static final long serialVersionUID = -3834209229668463829L; + @Override - protected boolean removeEldestEntry(Entry eldest) { + protected boolean removeEldestEntry(Map.Entry eldest) { return size() > max; } }; diff --git a/dubbo-filter/dubbo-filter-validation/pom.xml b/dubbo-filter/dubbo-filter-validation/pom.xml index d3d9cc12134..346242f5a1d 100644 --- a/dubbo-filter/dubbo-filter-validation/pom.xml +++ b/dubbo-filter/dubbo-filter-validation/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-filter - 2.8.4 + 3.0.1 dubbo-filter-validation jar diff --git a/dubbo-filter/pom.xml b/dubbo-filter/pom.xml index 86e2ef12fbf..1061304804e 100644 --- a/dubbo-filter/pom.xml +++ b/dubbo-filter/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-filter pom diff --git a/dubbo-monitor/dubbo-monitor-api/pom.xml b/dubbo-monitor/dubbo-monitor-api/pom.xml index e654f038a54..13babedf362 100644 --- a/dubbo-monitor/dubbo-monitor-api/pom.xml +++ b/dubbo-monitor/dubbo-monitor-api/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-monitor - 2.8.4 + 3.0.1 dubbo-monitor-api jar diff --git a/dubbo-monitor/dubbo-monitor-api/src/main/java/com/alibaba/dubbo/monitor/support/AbstractMonitorFactory.java b/dubbo-monitor/dubbo-monitor-api/src/main/java/com/alibaba/dubbo/monitor/support/AbstractMonitorFactory.java index 3aa81d27b2e..8ded0696f54 100644 --- a/dubbo-monitor/dubbo-monitor-api/src/main/java/com/alibaba/dubbo/monitor/support/AbstractMonitorFactory.java +++ b/dubbo-monitor/dubbo-monitor-api/src/main/java/com/alibaba/dubbo/monitor/support/AbstractMonitorFactory.java @@ -15,28 +15,28 @@ */ package com.alibaba.dubbo.monitor.support; -import java.util.Collection; -import java.util.Collections; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.locks.ReentrantLock; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.monitor.Monitor; import com.alibaba.dubbo.monitor.MonitorFactory; import com.alibaba.dubbo.monitor.MonitorService; +import java.util.Collection; +import java.util.Collections; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.locks.ReentrantLock; + /** * AbstractMonitorFactroy. (SPI, Singleton, ThreadSafe) - * + * * @author william.liangf */ public abstract class AbstractMonitorFactory implements MonitorFactory { // 注册中心获取过程锁 private static final ReentrantLock LOCK = new ReentrantLock(); - + // 注册中心集合 Map private static final Map MONITORS = new ConcurrentHashMap(); @@ -45,8 +45,8 @@ public static Collection getMonitors() { } public Monitor getMonitor(URL url) { - url = url.setPath(MonitorService.class.getName()).addParameter(Constants.INTERFACE_KEY, MonitorService.class.getName()); - String key = url.toServiceString(); + url = url.setPath(MonitorService.class.getName()).addParameter(Constants.INTERFACE_KEY, MonitorService.class.getName()); + String key = url.toServiceString(); LOCK.lock(); try { Monitor monitor = MONITORS.get(key); diff --git a/dubbo-monitor/dubbo-monitor-api/src/main/java/com/alibaba/dubbo/monitor/support/MonitorFilter.java b/dubbo-monitor/dubbo-monitor-api/src/main/java/com/alibaba/dubbo/monitor/support/MonitorFilter.java index 14f2d943196..9cd2110fba9 100644 --- a/dubbo-monitor/dubbo-monitor-api/src/main/java/com/alibaba/dubbo/monitor/support/MonitorFilter.java +++ b/dubbo-monitor/dubbo-monitor-api/src/main/java/com/alibaba/dubbo/monitor/support/MonitorFilter.java @@ -15,10 +15,6 @@ */ package com.alibaba.dubbo.monitor.support; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; -import java.util.concurrent.atomic.AtomicInteger; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.Activate; @@ -28,33 +24,31 @@ import com.alibaba.dubbo.monitor.Monitor; import com.alibaba.dubbo.monitor.MonitorFactory; import com.alibaba.dubbo.monitor.MonitorService; -import com.alibaba.dubbo.rpc.Filter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.support.RpcUtils; - + +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; +import java.util.concurrent.atomic.AtomicInteger; + /** * MonitorFilter. (SPI, Singleton, ThreadSafe) - * + * * @author william.liangf */ @Activate(group = {Constants.PROVIDER, Constants.CONSUMER}) public class MonitorFilter implements Filter { private static final Logger logger = LoggerFactory.getLogger(MonitorFilter.class); - + private final ConcurrentMap concurrents = new ConcurrentHashMap(); - + private MonitorFactory monitorFactory; - + public void setMonitorFactory(MonitorFactory monitorFactory) { this.monitorFactory = monitorFactory; } - + // 调用过程拦截 public Result invoke(Invoker invoker, Invocation invocation) throws RpcException { if (invoker.getUrl().hasParameter(Constants.MONITOR_KEY)) { @@ -75,7 +69,7 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept return invoker.invoke(invocation); } } - + // 信息采集 private void collect(Invoker invoker, Invocation invocation, Result result, RpcContext context, long start, boolean error) { try { @@ -110,22 +104,22 @@ private void collect(Invoker invoker, Invocation invocation, Result result, R output = result.getAttachment(Constants.OUTPUT_KEY); } monitor.collect(new URL(Constants.COUNT_PROTOCOL, - NetUtils.getLocalHost(), localPort, - service + "/" + method, - MonitorService.APPLICATION, application, - MonitorService.INTERFACE, service, - MonitorService.METHOD, method, - remoteKey, remoteValue, - error ? MonitorService.FAILURE : MonitorService.SUCCESS, "1", - MonitorService.ELAPSED, String.valueOf(elapsed), - MonitorService.CONCURRENT, String.valueOf(concurrent), - Constants.INPUT_KEY, input, - Constants.OUTPUT_KEY, output)); + NetUtils.getLocalHost(), localPort, + service + "/" + method, + MonitorService.APPLICATION, application, + MonitorService.INTERFACE, service, + MonitorService.METHOD, method, + remoteKey, remoteValue, + error ? MonitorService.FAILURE : MonitorService.SUCCESS, "1", + MonitorService.ELAPSED, String.valueOf(elapsed), + MonitorService.CONCURRENT, String.valueOf(concurrent), + Constants.INPUT_KEY, input, + Constants.OUTPUT_KEY, output)); } catch (Throwable t) { logger.error("Failed to monitor count service " + invoker.getUrl() + ", cause: " + t.getMessage(), t); } } - + // 获取并发计数器 private AtomicInteger getConcurrent(Invoker invoker, Invocation invocation) { String key = invoker.getInterface().getName() + "." + invocation.getMethodName(); diff --git a/dubbo-monitor/dubbo-monitor-default/pom.xml b/dubbo-monitor/dubbo-monitor-default/pom.xml index 957fda3e422..d3c0e303b34 100644 --- a/dubbo-monitor/dubbo-monitor-default/pom.xml +++ b/dubbo-monitor/dubbo-monitor-default/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-monitor - 2.8.4 + 3.0.1 dubbo-monitor-default jar diff --git a/dubbo-monitor/dubbo-monitor-default/src/main/java/com/alibaba/dubbo/monitor/dubbo/DubboMonitorFactroy.java b/dubbo-monitor/dubbo-monitor-default/src/main/java/com/alibaba/dubbo/monitor/dubbo/DubboMonitorFactory.java similarity index 94% rename from dubbo-monitor/dubbo-monitor-default/src/main/java/com/alibaba/dubbo/monitor/dubbo/DubboMonitorFactroy.java rename to dubbo-monitor/dubbo-monitor-default/src/main/java/com/alibaba/dubbo/monitor/dubbo/DubboMonitorFactory.java index 97558c27122..13dd7bc152b 100644 --- a/dubbo-monitor/dubbo-monitor-default/src/main/java/com/alibaba/dubbo/monitor/dubbo/DubboMonitorFactroy.java +++ b/dubbo-monitor/dubbo-monitor-default/src/main/java/com/alibaba/dubbo/monitor/dubbo/DubboMonitorFactory.java @@ -1,65 +1,65 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.monitor.dubbo; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.monitor.Monitor; -import com.alibaba.dubbo.monitor.MonitorService; -import com.alibaba.dubbo.monitor.support.AbstractMonitorFactory; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Protocol; -import com.alibaba.dubbo.rpc.ProxyFactory; - -/** - * DefaultMonitorFactroy - * - * @author william.liangf - */ -public class DubboMonitorFactroy extends AbstractMonitorFactory { - - private Protocol protocol; - - private ProxyFactory proxyFactory; - - public void setProtocol(Protocol protocol) { - this.protocol = protocol; - } - - public void setProxyFactory(ProxyFactory proxyFactory) { - this.proxyFactory = proxyFactory; - } - - @Override - protected Monitor createMonitor(URL url) { - url = url.setProtocol(url.getParameter(Constants.PROTOCOL_KEY, "dubbo")); - if (url.getPath() == null || url.getPath().length() == 0) { - url = url.setPath(MonitorService.class.getName()); - } - String filter = url.getParameter(Constants.REFERENCE_FILTER_KEY); - if (filter == null || filter.length() == 0) { - filter = ""; - } else { - filter = filter + ","; - } - url = url.addParameters(Constants.CLUSTER_KEY, "failsafe", Constants.CHECK_KEY, String.valueOf(false), - Constants.REFERENCE_FILTER_KEY, filter + "-monitor"); - Invoker monitorInvoker = protocol.refer(MonitorService.class, url); - MonitorService monitorService = proxyFactory.getProxy(monitorInvoker); - return new DubboMonitor(monitorInvoker, monitorService); - } - +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.alibaba.dubbo.monitor.dubbo; + +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.monitor.Monitor; +import com.alibaba.dubbo.monitor.MonitorService; +import com.alibaba.dubbo.monitor.support.AbstractMonitorFactory; +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.Protocol; +import com.alibaba.dubbo.rpc.ProxyFactory; + +/** + * DefaultMonitorFactroy + * + * @author william.liangf + */ +public class DubboMonitorFactory extends AbstractMonitorFactory { + + private Protocol protocol; + + private ProxyFactory proxyFactory; + + public void setProtocol(Protocol protocol) { + this.protocol = protocol; + } + + public void setProxyFactory(ProxyFactory proxyFactory) { + this.proxyFactory = proxyFactory; + } + + @Override + protected Monitor createMonitor(URL url) { + url = url.setProtocol(url.getParameter(Constants.PROTOCOL_KEY, "dubbo")); + if (url.getPath() == null || url.getPath().length() == 0) { + url = url.setPath(MonitorService.class.getName()); + } + String filter = url.getParameter(Constants.REFERENCE_FILTER_KEY); + if (filter == null || filter.length() == 0) { + filter = ""; + } else { + filter = filter + ","; + } + url = url.addParameters(Constants.CLUSTER_KEY, "failsafe", Constants.CHECK_KEY, String.valueOf(false), + Constants.REFERENCE_FILTER_KEY, filter + "-monitor"); + Invoker monitorInvoker = protocol.refer(MonitorService.class, url); + MonitorService monitorService = proxyFactory.getProxy(monitorInvoker); + return new DubboMonitor(monitorInvoker, monitorService); + } + } \ No newline at end of file diff --git a/dubbo-monitor/dubbo-monitor-default/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.monitor.MonitorFactory b/dubbo-monitor/dubbo-monitor-default/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.monitor.MonitorFactory index 25ae258923a..3f759a1f5b2 100644 --- a/dubbo-monitor/dubbo-monitor-default/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.monitor.MonitorFactory +++ b/dubbo-monitor/dubbo-monitor-default/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.monitor.MonitorFactory @@ -1 +1 @@ -dubbo=com.alibaba.dubbo.monitor.dubbo.DubboMonitorFactroy \ No newline at end of file +dubbo=com.alibaba.dubbo.monitor.dubbo.DubboMonitorFactory \ No newline at end of file diff --git a/dubbo-monitor/pom.xml b/dubbo-monitor/pom.xml index 5061c3f5606..ba6c25924a1 100644 --- a/dubbo-monitor/pom.xml +++ b/dubbo-monitor/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-monitor pom diff --git a/dubbo-registry/dubbo-registry-api/pom.xml b/dubbo-registry/dubbo-registry-api/pom.xml index 25572a8b656..0dedb487217 100644 --- a/dubbo-registry/dubbo-registry-api/pom.xml +++ b/dubbo-registry/dubbo-registry-api/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-registry - 2.8.4 + 3.0.1 dubbo-registry-api jar diff --git a/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/integration/RegistryDirectory.java b/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/integration/RegistryDirectory.java index 307ffadf764..23c5a1fe7ac 100644 --- a/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/integration/RegistryDirectory.java +++ b/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/integration/RegistryDirectory.java @@ -15,17 +15,6 @@ */ package com.alibaba.dubbo.registry.integration; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.Comparator; -import java.util.HashMap; -import java.util.HashSet; -import java.util.Iterator; -import java.util.List; -import java.util.Map; -import java.util.Set; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; @@ -36,34 +25,28 @@ import com.alibaba.dubbo.common.utils.StringUtils; import com.alibaba.dubbo.registry.NotifyListener; import com.alibaba.dubbo.registry.Registry; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Protocol; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.cluster.Cluster; -import com.alibaba.dubbo.rpc.cluster.Configurator; -import com.alibaba.dubbo.rpc.cluster.ConfiguratorFactory; -import com.alibaba.dubbo.rpc.cluster.Router; -import com.alibaba.dubbo.rpc.cluster.RouterFactory; +import com.alibaba.dubbo.rpc.*; +import com.alibaba.dubbo.rpc.cluster.*; import com.alibaba.dubbo.rpc.cluster.directory.AbstractDirectory; import com.alibaba.dubbo.rpc.cluster.directory.StaticDirectory; import com.alibaba.dubbo.rpc.cluster.support.ClusterUtils; import com.alibaba.dubbo.rpc.protocol.InvokerWrapper; import com.alibaba.dubbo.rpc.support.RpcUtils; +import java.util.*; + /** * RegistryDirectory - * + * * @author william.liangf * @author chao.liuc */ public class RegistryDirectory extends AbstractDirectory implements NotifyListener { private static final Logger logger = LoggerFactory.getLogger(RegistryDirectory.class); - + private static final Cluster cluster = ExtensionLoader.getExtensionLoader(Cluster.class).getAdaptiveExtension(); - + private static final RouterFactory routerFactory = ExtensionLoader.getExtensionLoader(RouterFactory.class).getAdaptiveExtension(); private static final ConfiguratorFactory configuratorFactory = ExtensionLoader.getExtensionLoader(ConfiguratorFactory.class).getAdaptiveExtension(); @@ -75,17 +58,17 @@ public class RegistryDirectory extends AbstractDirectory implements Notify private final String serviceKey; // 构造时初始化,断言不为null private final Class serviceType; // 构造时初始化,断言不为null - + private final Map queryMap; // 构造时初始化,断言不为null private final URL directoryUrl; // 构造时初始化,断言不为null,并且总是赋非null值 - + private final String[] serviceMethods; private final boolean multiGroup; private volatile boolean forbidden = false; - + private volatile URL overrideDirectoryUrl; // 构造时初始化,断言不为null,并且总是赋非null值 /*override规则 @@ -94,28 +77,28 @@ public class RegistryDirectory extends AbstractDirectory implements Notify * 第二种规则:针对所有provider <* ,timeout=5000> */ private volatile List configurators; // 初始为null以及中途可能被赋为null,请使用局部变量引用 - + // Map cache service url to invoker mapping. private volatile Map> urlInvokerMap; // 初始为null以及中途可能被赋为null,请使用局部变量引用 - + // Map cache service method to invokers mapping. private volatile Map>> methodInvokerMap; // 初始为null以及中途可能被赋为null,请使用局部变量引用 - + // Set cache invokeUrls to invokers mapping. private volatile Set cachedInvokerUrls; // 初始为null以及中途可能被赋为null,请使用局部变量引用 public RegistryDirectory(Class serviceType, URL url) { super(url); - if(serviceType == null ) + if (serviceType == null) throw new IllegalArgumentException("service type is null."); - if(url.getServiceKey() == null || url.getServiceKey().length() == 0) + if (url.getServiceKey() == null || url.getServiceKey().length() == 0) throw new IllegalArgumentException("registry serviceKey is null."); this.serviceType = serviceType; this.serviceKey = url.getServiceKey(); this.queryMap = StringUtils.parseQueryString(url.getParameterAndDecoded(Constants.REFER_KEY)); this.overrideDirectoryUrl = this.directoryUrl = url.setPath(url.getServiceInterface()).clearParameters().addParameters(queryMap).removeParameter(Constants.MONITOR_KEY); - String group = directoryUrl.getParameter( Constants.GROUP_KEY, "" ); - this.multiGroup = group != null && ("*".equals(group) || group.contains( "," )); + String group = directoryUrl.getParameter(Constants.GROUP_KEY, ""); + this.multiGroup = group != null && (group.contains(",")); String methods = queryMap.get(Constants.METHODS_KEY); this.serviceMethods = methods == null ? null : Constants.COMMA_SPLIT_PATTERN.split(methods); } @@ -127,19 +110,19 @@ public void setProtocol(Protocol protocol) { public void setRegistry(Registry registry) { this.registry = registry; } - + public void subscribe(URL url) { setConsumerUrl(url); registry.subscribe(url, this); } public void destroy() { - if(isDestroyed()) { + if (isDestroyed()) { return; } // unsubscribe. try { - if(getConsumerUrl() != null && registry != null && registry.isAvailable()) { + if (getConsumerUrl() != null && registry != null && registry.isAvailable()) { registry.unsubscribe(getConsumerUrl(), this); } } catch (Throwable t) { @@ -160,10 +143,10 @@ public synchronized void notify(List urls) { for (URL url : urls) { String protocol = url.getProtocol(); String category = url.getParameter(Constants.CATEGORY_KEY, Constants.DEFAULT_CATEGORY); - if (Constants.ROUTERS_CATEGORY.equals(category) + if (Constants.ROUTERS_CATEGORY.equals(category) || Constants.ROUTE_PROTOCOL.equals(protocol)) { routerUrls.add(url); - } else if (Constants.CONFIGURATORS_CATEGORY.equals(category) + } else if (Constants.CONFIGURATORS_CATEGORY.equals(category) || Constants.OVERRIDE_PROTOCOL.equals(protocol)) { configuratorUrls.add(url); } else if (Constants.PROVIDERS_CATEGORY.equals(category)) { @@ -173,13 +156,13 @@ public synchronized void notify(List urls) { } } // configurators - if (configuratorUrls != null && configuratorUrls.size() >0 ){ + if (configuratorUrls.size() > 0) { this.configurators = toConfigurators(configuratorUrls); } // routers - if (routerUrls != null && routerUrls.size() >0 ){ + if (routerUrls.size() > 0) { List routers = toRouters(routerUrls); - if(routers != null){ // null - do nothing + if (routers != null) { // null - do nothing setRouters(routers); } } @@ -194,16 +177,17 @@ public synchronized void notify(List urls) { // providers refreshInvoker(invokerUrls); } - - + + /** * 根据invokerURL列表转换为invoker列表。转换规则如下: * 1.如果url已经被转换为invoker,则不在重新引用,直接从缓存中获取,注意如果url中任何一个参数变更也会重新引用 * 2.如果传入的invoker列表不为空,则表示最新的invoker列表 * 3.如果传入的invokerUrl列表是空,则表示只是下发的override规则或route规则,需要重新交叉对比,决定是否需要重新引用。 + * * @param invokerUrls 传入的参数不能为null */ - private void refreshInvoker(List invokerUrls){ + private void refreshInvoker(List invokerUrls) { if (invokerUrls != null && invokerUrls.size() == 1 && invokerUrls.get(0) != null && Constants.EMPTY_PROTOCOL.equals(invokerUrls.get(0).getProtocol())) { this.forbidden = true; // 禁止访问 @@ -212,33 +196,34 @@ private void refreshInvoker(List invokerUrls){ } else { this.forbidden = false; // 允许访问 Map> oldUrlInvokerMap = this.urlInvokerMap; // local reference - if (invokerUrls.size() == 0 && this.cachedInvokerUrls != null){ + assert invokerUrls != null; + if (invokerUrls.size() == 0 && this.cachedInvokerUrls != null) { invokerUrls.addAll(this.cachedInvokerUrls); } else { this.cachedInvokerUrls = new HashSet(); this.cachedInvokerUrls.addAll(invokerUrls);//缓存invokerUrls列表,便于交叉对比 } - if (invokerUrls.size() ==0 ){ - return; + if (invokerUrls.size() == 0) { + return; } - Map> newUrlInvokerMap = toInvokers(invokerUrls) ;// 将URL列表转成Invoker列表 + Map> newUrlInvokerMap = toInvokers(invokerUrls);// 将URL列表转成Invoker列表 Map>> newMethodInvokerMap = toMethodInvokers(newUrlInvokerMap); // 换方法名映射Invoker列表 // state change //如果计算错误,则不进行处理. - if (newUrlInvokerMap == null || newUrlInvokerMap.size() == 0 ){ - logger.error(new IllegalStateException("urls to invokers error .invokerUrls.size :"+invokerUrls.size() + ", invoker.size :0. urls :"+invokerUrls.toString())); - return ; + if (newUrlInvokerMap == null || newUrlInvokerMap.size() == 0) { + logger.error(new IllegalStateException("urls to invokers error .invokerUrls.size :" + invokerUrls.size() + ", invoker.size :0. urls :" + invokerUrls.toString())); + return; } this.methodInvokerMap = multiGroup ? toMergeMethodInvokerMap(newMethodInvokerMap) : newMethodInvokerMap; this.urlInvokerMap = newUrlInvokerMap; - try{ - destroyUnusedInvokers(oldUrlInvokerMap,newUrlInvokerMap); // 关闭未使用的Invoker - }catch (Exception e) { + try { + destroyUnusedInvokers(oldUrlInvokerMap, newUrlInvokerMap); // 关闭未使用的Invoker + } catch (Exception e) { logger.warn("destroyUnusedInvokers error. ", e); } } } - + private Map>> toMergeMethodInvokerMap(Map>> methodMap) { Map>> result = new HashMap>>(); for (Map.Entry>> entry : methodMap.entrySet()) { @@ -268,32 +253,32 @@ private Map>> toMergeMethodInvokerMap(Map1.override://0.0.0.0/...(或override://ip:port...?anyhost=true)¶1=value1...表示全局规则(对所有的提供者全部生效) - *
2.override://ip:port...?anyhost=false 特例规则(只针对某个提供者生效) - *
3.不支持override://规则... 需要注册中心自行计算. - *
4.不带参数的override://0.0.0.0/ 表示清除override + * + * @param urls 契约: + *
1.override://0.0.0.0/...(或override://ip:port...?anyhost=true)¶1=value1...表示全局规则(对所有的提供者全部生效) + *
2.override://ip:port...?anyhost=false 特例规则(只针对某个提供者生效) + *
3.不支持override://规则... 需要注册中心自行计算. + *
4.不带参数的override://0.0.0.0/ 表示清除override * @return */ - public static List toConfigurators(List urls){ + public static List toConfigurators(List urls) { List configurators = new ArrayList(urls.size()); - if (urls == null || urls.size() == 0){ + if (urls.size() == 0) { return configurators; } - for(URL url : urls){ + for (URL url : urls) { if (Constants.EMPTY_PROTOCOL.equals(url.getProtocol())) { configurators.clear(); break; } - Map override = new HashMap(url.getParameters()); + Map override = new HashMap(url.getParameters()); //override 上的anyhost可能是自动添加的,不能影响改变url判断 override.remove(Constants.ANYHOST_KEY); - if (override.size() == 0){ + if (override.size() == 0) { configurators.clear(); continue; } @@ -302,79 +287,76 @@ public static List toConfigurators(List urls){ Collections.sort(configurators); return configurators; } - + /** - * * @param urls * @return null : no routers ,do nothing - * else :routers list + * else :routers list */ private List toRouters(List urls) { List routers = new ArrayList(); - if(urls == null || urls.size() < 1){ - return routers ; + if (urls == null || urls.size() < 1) { + return routers; } - if (urls != null && urls.size() > 0) { + if (urls.size() > 0) { for (URL url : urls) { if (Constants.EMPTY_PROTOCOL.equals(url.getProtocol())) { continue; } String routerType = url.getParameter(Constants.ROUTER_KEY); - if (routerType != null && routerType.length() > 0){ + if (routerType != null && routerType.length() > 0) { url = url.setProtocol(routerType); } - try{ + try { Router router = routerFactory.getRouter(url); if (!routers.contains(router)) routers.add(router); } catch (Throwable t) { - logger.error("convert router url to router error, url: "+ url, t); + logger.error("convert router url to router error, url: " + url, t); } } } return routers; } - + /** * 将urls转成invokers,如果url已经被refer过,不再重新引用。 - * + * * @param urls - * @param overrides - * @param query * @return invokers */ private Map> toInvokers(List urls) { Map> newUrlInvokerMap = new HashMap>(); - if(urls == null || urls.size() == 0){ + if (urls == null || urls.size() == 0) { return newUrlInvokerMap; } Set keys = new HashSet(); String queryProtocols = this.queryMap.get(Constants.PROTOCOL_KEY); for (URL providerUrl : urls) { - //如果reference端配置了protocol,则只选择匹配的protocol - if (queryProtocols != null && queryProtocols.length() >0) { - boolean accept = false; - String[] acceptProtocols = queryProtocols.split(","); - for (String acceptProtocol : acceptProtocols) { - if (providerUrl.getProtocol().equals(acceptProtocol)) { - accept = true; - break; - } - } - if (!accept) { - continue; - } - } + //如果reference端配置了protocol,则只选择匹配的protocol + if (queryProtocols != null && queryProtocols.length() > 0) { + boolean accept = false; + String[] acceptProtocols = queryProtocols.split(","); + for (String acceptProtocol : acceptProtocols) { + if (providerUrl.getProtocol().equals(acceptProtocol)) { + accept = true; + break; + } + } + if (!accept) { + continue; + } + } if (Constants.EMPTY_PROTOCOL.equals(providerUrl.getProtocol())) { continue; } - if (! ExtensionLoader.getExtensionLoader(Protocol.class).hasExtension(providerUrl.getProtocol())) { - logger.error(new IllegalStateException("Unsupported protocol " + providerUrl.getProtocol() + " in notified url: " + providerUrl + " from registry " + getUrl().getAddress() + " to consumer " + NetUtils.getLocalHost() - + ", supported protocol: "+ExtensionLoader.getExtensionLoader(Protocol.class).getSupportedExtensions())); + if (!ExtensionLoader.getExtensionLoader(Protocol.class).hasExtension(providerUrl.getProtocol())) { + logger.error(new IllegalStateException("Unsupported protocol " + providerUrl.getProtocol() + " in notified url: " + providerUrl + " from registry " + getUrl().getAddress() + " to consumer " + NetUtils.getLocalHost() + + ", supported protocol: " + ExtensionLoader.getExtensionLoader(Protocol.class).getSupportedExtensions())); continue; } URL url = mergeUrl(providerUrl); - + String key = url.toFullString(); // URL参数是排序的 if (keys.contains(key)) { // 重复URL continue; @@ -385,50 +367,50 @@ private Map> toInvokers(List urls) { Invoker invoker = localUrlInvokerMap == null ? null : localUrlInvokerMap.get(key); if (invoker == null) { // 缓存中没有,重新refer try { - boolean enabled = true; - if (url.hasParameter(Constants.DISABLED_KEY)) { - enabled = ! url.getParameter(Constants.DISABLED_KEY, false); - } else { - enabled = url.getParameter(Constants.ENABLED_KEY, true); - } - if (enabled) { - invoker = new InvokerDelegete(protocol.refer(serviceType, url), url, providerUrl); - } + boolean enabled = true; + if (url.hasParameter(Constants.DISABLED_KEY)) { + enabled = !url.getParameter(Constants.DISABLED_KEY, false); + } else { + enabled = url.getParameter(Constants.ENABLED_KEY, true); + } + if (enabled) { + invoker = new InvokerDelegate(protocol.refer(serviceType, url), url, providerUrl); + } } catch (Throwable t) { - logger.error("Failed to refer invoker for interface:"+serviceType+",url:("+url+")" + t.getMessage(), t); + logger.error("Failed to refer invoker for interface:" + serviceType + ",url:(" + url + ")" + t.getMessage(), t); } if (invoker != null) { // 将新的引用放入缓存 newUrlInvokerMap.put(key, invoker); } - }else { + } else { newUrlInvokerMap.put(key, invoker); } } keys.clear(); return newUrlInvokerMap; } - + /** * 合并url参数 顺序为override > -D >Consumer > Provider + * * @param providerUrl - * @param overrides * @return */ - private URL mergeUrl(URL providerUrl){ + private URL mergeUrl(URL providerUrl) { providerUrl = ClusterUtils.mergeUrl(providerUrl, queryMap); // 合并消费端参数 - + List localConfigurators = this.configurators; // local reference if (localConfigurators != null && localConfigurators.size() > 0) { for (Configurator configurator : localConfigurators) { providerUrl = configurator.configure(providerUrl); } } - + providerUrl = providerUrl.addParameter(Constants.CHECK_KEY, String.valueOf(false)); // 不检查连接是否成功,总是创建Invoker! - + //directoryUrl 与 override 合并是在notify的最后,这里不能够处理 this.overrideDirectoryUrl = this.overrideDirectoryUrl.addParametersIfAbsent(providerUrl.getParameters()); // 合并提供者参数 - + if ((providerUrl.getPath() == null || providerUrl.getPath().length() == 0) && "dubbo".equals(providerUrl.getProtocol())) { // 兼容1.0 //fix by tony.chenl DUBBO-44 @@ -450,10 +432,10 @@ private URL mergeUrl(URL providerUrl){ private List> route(List> invokers, String method) { Invocation invocation = new RpcInvocation(method, new Class[0], new Object[0]); - List routers = getRouters(); + List routers = getRouters(); if (routers != null) { for (Router router : routers) { - if (router.getUrl() != null && ! router.getUrl().getParameter(Constants.RUNTIME_KEY, true)) { + if (router.getUrl() != null && !router.getUrl().getParameter(Constants.RUNTIME_KEY, true)) { invokers = router.route(invokers, getConsumerUrl(), invocation); } } @@ -463,7 +445,7 @@ private List> route(List> invokers, String method) { /** * 将invokers列表转成与方法的映射关系 - * + * * @param invokersMap Invoker列表 * @return Invoker与方法的映射关系 */ @@ -478,8 +460,8 @@ private Map>> toMethodInvokers(Map> i String[] methods = Constants.COMMA_SPLIT_PATTERN.split(parameter); if (methods != null && methods.length > 0) { for (String method : methods) { - if (method != null && method.length() > 0 - && ! Constants.ANY_VALUE.equals(method)) { + if (method != null && method.length() > 0 + && !Constants.ANY_VALUE.equals(method)) { List> methodInvokers = newMethodInvokerMap.get(method); if (methodInvokers == null) { methodInvokers = new ArrayList>(); @@ -517,7 +499,7 @@ private Map>> toMethodInvokers(Map> i */ private void destroyAllInvokers() { Map> localUrlInvokerMap = this.urlInvokerMap; // local reference - if(localUrlInvokerMap != null) { + if (localUrlInvokerMap != null) { for (Invoker invoker : new ArrayList>(localUrlInvokerMap.values())) { try { invoker.destroy(); @@ -529,12 +511,10 @@ private void destroyAllInvokers() { } methodInvokerMap = null; } - + /** * 检查缓存中的invoker是否需要被destroy * 如果url中指定refer.autodestroy=false,则只增加不减少,可能会有refer泄漏, - * - * @param invokers */ private void destroyUnusedInvokers(Map> oldUrlInvokerMap, Map> newUrlInvokerMap) { if (newUrlInvokerMap == null || newUrlInvokerMap.size() == 0) { @@ -545,8 +525,8 @@ private void destroyUnusedInvokers(Map> oldUrlInvokerMap, Map List deleted = null; if (oldUrlInvokerMap != null) { Collection> newInvokers = newUrlInvokerMap.values(); - for (Map.Entry> entry : oldUrlInvokerMap.entrySet()){ - if (! newInvokers.contains(entry.getValue())) { + for (Map.Entry> entry : oldUrlInvokerMap.entrySet()) { + if (!newInvokers.contains(entry.getValue())) { if (deleted == null) { deleted = new ArrayList(); } @@ -554,19 +534,19 @@ private void destroyUnusedInvokers(Map> oldUrlInvokerMap, Map } } } - + if (deleted != null) { - for (String url : deleted){ - if (url != null ) { + for (String url : deleted) { + if (url != null) { Invoker invoker = oldUrlInvokerMap.remove(url); if (invoker != null) { try { invoker.destroy(); - if(logger.isDebugEnabled()){ - logger.debug("destory invoker["+invoker.getUrl()+"] success. "); + if (logger.isDebugEnabled()) { + logger.debug("destory invoker[" + invoker.getUrl() + "] success. "); } } catch (Exception e) { - logger.warn("destory invoker["+invoker.getUrl()+"] faild. " + e.getMessage(), e); + logger.warn("destory invoker[" + invoker.getUrl() + "] faild. " + e.getMessage(), e); } } } @@ -576,24 +556,24 @@ private void destroyUnusedInvokers(Map> oldUrlInvokerMap, Map public List> doList(Invocation invocation) { if (forbidden) { - throw new RpcException(RpcException.FORBIDDEN_EXCEPTION, "Forbid consumer " + NetUtils.getLocalHost() + " access service " + getInterface().getName() + " from registry " + getUrl().getAddress() + " use dubbo version " + Version.getVersion() + ", Please check registry access list (whitelist/blacklist)."); + throw new RpcException(RpcException.FORBIDDEN_EXCEPTION, "Forbid consumer " + NetUtils.getLocalHost() + " access service " + getInterface().getName() + " from registry " + getUrl().getAddress() + " use dubbo version " + Version.getVersion() + ", Please check registry access list (whitelist/blacklist)."); } List> invokers = null; Map>> localMethodInvokerMap = this.methodInvokerMap; // local reference if (localMethodInvokerMap != null && localMethodInvokerMap.size() > 0) { String methodName = RpcUtils.getMethodName(invocation); Object[] args = RpcUtils.getArguments(invocation); - if(args != null && args.length > 0 && args[0] != null + if (args != null && args.length > 0 && args[0] != null && (args[0] instanceof String || args[0].getClass().isEnum())) { invokers = localMethodInvokerMap.get(methodName + "." + args[0]); // 可根据第一个参数枚举路由 } - if(invokers == null) { + if (invokers == null) { invokers = localMethodInvokerMap.get(methodName); } - if(invokers == null) { + if (invokers == null) { invokers = localMethodInvokerMap.get(Constants.ANY_VALUE); } - if(invokers == null) { + if (invokers == null) { Iterator>> iterator = localMethodInvokerMap.values().iterator(); if (iterator.hasNext()) { invokers = iterator.next(); @@ -602,13 +582,13 @@ public List> doList(Invocation invocation) { } return invokers == null ? new ArrayList>(0) : invokers; } - + public Class getInterface() { return serviceType; } public URL getUrl() { - return this.overrideDirectoryUrl; + return this.overrideDirectoryUrl; } public boolean isAvailable() { @@ -625,50 +605,52 @@ public boolean isAvailable() { } return false; } - + /** * Haomin: added for test purpose */ - public Map> getUrlInvokerMap(){ + public Map> getUrlInvokerMap() { return urlInvokerMap; } - + /** * Haomin: added for test purpose */ - public Map>> getMethodInvokerMap(){ + public Map>> getMethodInvokerMap() { return methodInvokerMap; - } - + } + private static class InvokerComparator implements Comparator> { - + private static final InvokerComparator comparator = new InvokerComparator(); - + public static InvokerComparator getComparator() { return comparator; } - - private InvokerComparator() {} + + private InvokerComparator() { + } public int compare(Invoker o1, Invoker o2) { return o1.getUrl().toString().compareTo(o2.getUrl().toString()); } } - + /** * 代理类,主要用于存储注册中心下发的url地址,用于重新重新refer时能够根据providerURL queryMap overrideMap重新组装 - * - * @author chao.liuc * * @param + * @author chao.liuc */ - private static class InvokerDelegete extends InvokerWrapper{ + private static class InvokerDelegate extends InvokerWrapper { private URL providerUrl; - public InvokerDelegete(Invoker invoker, URL url, URL providerUrl) { + + public InvokerDelegate(Invoker invoker, URL url, URL providerUrl) { super(invoker, url); this.providerUrl = providerUrl; } + public URL getProviderUrl() { return providerUrl; } diff --git a/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/integration/RegistryProtocol.java b/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/integration/RegistryProtocol.java index 5f908b3de6a..485fee0fb07 100644 --- a/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/integration/RegistryProtocol.java +++ b/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/integration/RegistryProtocol.java @@ -15,11 +15,6 @@ */ package com.alibaba.dubbo.registry.integration; -import java.util.ArrayList; -import java.util.List; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; @@ -32,43 +27,44 @@ import com.alibaba.dubbo.registry.Registry; import com.alibaba.dubbo.registry.RegistryFactory; import com.alibaba.dubbo.registry.RegistryService; -import com.alibaba.dubbo.rpc.Exporter; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Protocol; -import com.alibaba.dubbo.rpc.ProxyFactory; -import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.cluster.Cluster; import com.alibaba.dubbo.rpc.cluster.Configurator; import com.alibaba.dubbo.rpc.protocol.InvokerWrapper; +import java.util.ArrayList; +import java.util.List; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; + /** * RegistryProtocol - * + * * @author william.liangf * @author chao.liuc */ public class RegistryProtocol implements Protocol { private Cluster cluster; - + public void setCluster(Cluster cluster) { this.cluster = cluster; } - + private Protocol protocol; - + public void setProtocol(Protocol protocol) { this.protocol = protocol; } private RegistryFactory registryFactory; - + public void setRegistryFactory(RegistryFactory registryFactory) { this.registryFactory = registryFactory; } private ProxyFactory proxyFactory; - + public void setProxyFactory(ProxyFactory proxyFactory) { this.proxyFactory = proxyFactory; } @@ -76,38 +72,38 @@ public void setProxyFactory(ProxyFactory proxyFactory) { public int getDefaultPort() { return 9090; } - + private static RegistryProtocol INSTANCE; public RegistryProtocol() { INSTANCE = this; } - + public static RegistryProtocol getRegistryProtocol() { if (INSTANCE == null) { ExtensionLoader.getExtensionLoader(Protocol.class).getExtension(Constants.REGISTRY_PROTOCOL); // load } return INSTANCE; } - + private final Map overrideListeners = new ConcurrentHashMap(); - + public Map getOverrideListeners() { - return overrideListeners; - } + return overrideListeners; + } - //用于解决rmi重复暴露端口冲突的问题,已经暴露过的服务不再重新暴露 + //用于解决rmi重复暴露端口冲突的问题,已经暴露过的服务不再重新暴露 //providerurl <--> exporter private final Map> bounds = new ConcurrentHashMap>(); - + private final static Logger logger = LoggerFactory.getLogger(RegistryProtocol.class); - + public Exporter export(final Invoker originInvoker) throws RpcException { //export invoker final ExporterChangeableWrapper exporter = doLocalExport(originInvoker); //registry provider final Registry registry = getRegistry(originInvoker); - final URL registedProviderUrl = getRegistedProviderUrl(originInvoker); + final URL registedProviderUrl = getRegisteredProviderUrl(originInvoker); registry.register(registedProviderUrl); // 订阅override数据 // FIXME 提供者订阅时,会影响同一JVM即暴露服务,又引用同一服务的的场景,因为subscribed以服务名为缓存的key,导致订阅信息覆盖。 @@ -120,68 +116,70 @@ public Exporter export(final Invoker originInvoker) throws RpcExceptio public Invoker getInvoker() { return exporter.getInvoker(); } + public void unexport() { - try { - exporter.unexport(); - } catch (Throwable t) { - logger.warn(t.getMessage(), t); + try { + exporter.unexport(); + } catch (Throwable t) { + logger.warn(t.getMessage(), t); } try { - registry.unregister(registedProviderUrl); + registry.unregister(registedProviderUrl); } catch (Throwable t) { - logger.warn(t.getMessage(), t); + logger.warn(t.getMessage(), t); } try { - overrideListeners.remove(overrideSubscribeUrl); - registry.unsubscribe(overrideSubscribeUrl, overrideSubscribeListener); + overrideListeners.remove(overrideSubscribeUrl); + registry.unsubscribe(overrideSubscribeUrl, overrideSubscribeListener); } catch (Throwable t) { - logger.warn(t.getMessage(), t); + logger.warn(t.getMessage(), t); } } }; } - + @SuppressWarnings("unchecked") - private ExporterChangeableWrapper doLocalExport(final Invoker originInvoker){ + private ExporterChangeableWrapper doLocalExport(final Invoker originInvoker) { String key = getCacheKey(originInvoker); ExporterChangeableWrapper exporter = (ExporterChangeableWrapper) bounds.get(key); if (exporter == null) { synchronized (bounds) { exporter = (ExporterChangeableWrapper) bounds.get(key); if (exporter == null) { - final Invoker invokerDelegete = new InvokerDelegete(originInvoker, getProviderUrl(originInvoker)); - exporter = new ExporterChangeableWrapper((Exporter)protocol.export(invokerDelegete), originInvoker); + final Invoker invokerDelegate = new InvokerDelegate(originInvoker, getProviderUrl(originInvoker)); + exporter = new ExporterChangeableWrapper((Exporter) protocol.export(invokerDelegate), originInvoker); bounds.put(key, exporter); } } } - return (ExporterChangeableWrapper) exporter; + return exporter; } - + /** * 对修改了url的invoker重新export + * * @param originInvoker * @param newInvokerUrl */ @SuppressWarnings("unchecked") - private void doChangeLocalExport(final Invoker originInvoker, URL newInvokerUrl){ + private void doChangeLocalExport(final Invoker originInvoker, URL newInvokerUrl) { String key = getCacheKey(originInvoker); final ExporterChangeableWrapper exporter = (ExporterChangeableWrapper) bounds.get(key); - if (exporter == null){ + if (exporter == null) { logger.warn(new IllegalStateException("error state, exporter should not be null")); - return ;//不存在是异常场景 直接返回 } else { - final Invoker invokerDelegete = new InvokerDelegete(originInvoker, newInvokerUrl); + final Invoker invokerDelegete = new InvokerDelegate(originInvoker, newInvokerUrl); exporter.setExporter(protocol.export(invokerDelegete)); } } /** * 根据invoker的地址获取registry实例 + * * @param originInvoker * @return */ - private Registry getRegistry(final Invoker originInvoker){ + private Registry getRegistry(final Invoker originInvoker) { URL registryUrl = originInvoker.getUrl(); if (Constants.REGISTRY_PROTOCOL.equals(registryUrl.getProtocol())) { String protocol = registryUrl.getParameter(Constants.REGISTRY_KEY, Constants.DEFAULT_DIRECTORY); @@ -192,86 +190,85 @@ private Registry getRegistry(final Invoker originInvoker){ /** * 返回注册到注册中心的URL,对URL参数进行一次过滤 + * * @param originInvoker * @return */ - private URL getRegistedProviderUrl(final Invoker originInvoker){ + private URL getRegisteredProviderUrl(final Invoker originInvoker) { URL providerUrl = getProviderUrl(originInvoker); //注册中心看到的地址 - final URL registedProviderUrl = providerUrl.removeParameters(getFilteredKeys(providerUrl)).removeParameter(Constants.MONITOR_KEY); - return registedProviderUrl; + return providerUrl.removeParameters(getFilteredKeys(providerUrl)).removeParameter(Constants.MONITOR_KEY); } - - private URL getSubscribedOverrideUrl(URL registedProviderUrl){ - return registedProviderUrl.setProtocol(Constants.PROVIDER_PROTOCOL) - .addParameters(Constants.CATEGORY_KEY, Constants.CONFIGURATORS_CATEGORY, + + private URL getSubscribedOverrideUrl(URL registeredProviderUrl) { + return registeredProviderUrl.setProtocol(Constants.PROVIDER_PROTOCOL) + .addParameters(Constants.CATEGORY_KEY, Constants.CONFIGURATORS_CATEGORY, Constants.CHECK_KEY, String.valueOf(false)); } /** * 通过invoker的url 获取 providerUrl的地址 + * * @param origininvoker * @return */ - private URL getProviderUrl(final Invoker origininvoker){ + private URL getProviderUrl(final Invoker origininvoker) { String export = origininvoker.getUrl().getParameterAndDecoded(Constants.EXPORT_KEY); if (export == null || export.length() == 0) { throw new IllegalArgumentException("The registry export url is null! registry: " + origininvoker.getUrl()); } - - URL providerUrl = URL.valueOf(export); - return providerUrl; + + return URL.valueOf(export); } /** * 获取invoker在bounds中缓存的key + * * @param originInvoker * @return */ - private String getCacheKey(final Invoker originInvoker){ + private String getCacheKey(final Invoker originInvoker) { URL providerUrl = getProviderUrl(originInvoker); - String key = providerUrl.removeParameters("dynamic", "enabled").toFullString(); - return key; + return providerUrl.removeParameters("dynamic", "enabled").toFullString(); } - + @SuppressWarnings("unchecked") - public Invoker refer(Class type, URL url) throws RpcException { + public Invoker refer(Class type, URL url) throws RpcException { url = url.setProtocol(url.getParameter(Constants.REGISTRY_KEY, Constants.DEFAULT_REGISTRY)).removeParameter(Constants.REGISTRY_KEY); Registry registry = registryFactory.getRegistry(url); if (RegistryService.class.equals(type)) { - return proxyFactory.getInvoker((T) registry, type, url); + return proxyFactory.getInvoker((T) registry, type, url); } // group="a,b" or group="*" Map qs = StringUtils.parseQueryString(url.getParameterAndDecoded(Constants.REFER_KEY)); String group = qs.get(Constants.GROUP_KEY); - if (group != null && group.length() > 0 ) { - if ( ( Constants.COMMA_SPLIT_PATTERN.split( group ) ).length > 1 - || "*".equals( group ) ) { - return doRefer( getMergeableCluster(), registry, type, url ); + if (group != null && group.length() > 0) { + if ((Constants.COMMA_SPLIT_PATTERN.split(group)).length > 1 || Constants.ANY_VALUE.equals(group)) { + return doRefer(getCluster("mergeable"), registry, type, url); } } return doRefer(cluster, registry, type, url); } - - private Cluster getMergeableCluster() { - return ExtensionLoader.getExtensionLoader(Cluster.class).getExtension("mergeable"); + + private Cluster getCluster(String cluster) { + return ExtensionLoader.getExtensionLoader(Cluster.class).getExtension(cluster); } - + private Invoker doRefer(Cluster cluster, Registry registry, Class type, URL url) { RegistryDirectory directory = new RegistryDirectory(type, url); directory.setRegistry(registry); directory.setProtocol(protocol); URL subscribeUrl = new URL(Constants.CONSUMER_PROTOCOL, NetUtils.getLocalHost(), 0, type.getName(), directory.getUrl().getParameters()); - if (! Constants.ANY_VALUE.equals(url.getServiceInterface()) + if (!Constants.ANY_VALUE.equals(url.getServiceInterface()) && url.getParameter(Constants.REGISTER_KEY, true)) { registry.register(subscribeUrl.addParameters(Constants.CATEGORY_KEY, Constants.CONSUMERS_CATEGORY, Constants.CHECK_KEY, String.valueOf(false))); } - directory.subscribe(subscribeUrl.addParameter(Constants.CATEGORY_KEY, - Constants.PROVIDERS_CATEGORY - + "," + Constants.CONFIGURATORS_CATEGORY - + "," + Constants.ROUTERS_CATEGORY)); + directory.subscribe(subscribeUrl.addParameter(Constants.CATEGORY_KEY, + Constants.PROVIDERS_CATEGORY + + "," + Constants.CONFIGURATORS_CATEGORY + + "," + Constants.ROUTERS_CATEGORY)); return cluster.join(directory); } @@ -287,81 +284,81 @@ private static String[] getFilteredKeys(URL url) { } return filteredKeys.toArray(new String[filteredKeys.size()]); } else { - return new String[] {}; + return new String[]{}; } } - + public void destroy() { List> exporters = new ArrayList>(bounds.values()); - for(Exporter exporter :exporters){ + for (Exporter exporter : exporters) { exporter.unexport(); } bounds.clear(); } - - + + /*重新export 1.protocol中的exporter destory问题 *1.要求registryprotocol返回的exporter可以正常destroy *2.notify后不需要重新向注册中心注册 *3.export 方法传入的invoker最好能一直作为exporter的invoker. */ private class OverrideListener implements NotifyListener { - - private volatile List configurators; - - private final URL subscribeUrl; - public OverrideListener(URL subscribeUrl) { - this.subscribeUrl = subscribeUrl; - } + private volatile List configurators; + + private final URL subscribeUrl; + + public OverrideListener(URL subscribeUrl) { + this.subscribeUrl = subscribeUrl; + } - /* + /* * provider 端可识别的override url只有这两种. * override://0.0.0.0/serviceName?timeout=10 * override://0.0.0.0/?timeout=10 */ public void notify(List urls) { - List result = null; - for (URL url : urls) { - URL overrideUrl = url; - if (url.getParameter(Constants.CATEGORY_KEY) == null - && Constants.OVERRIDE_PROTOCOL.equals(url.getProtocol())) { - // 兼容旧版本 - overrideUrl = url.addParameter(Constants.CATEGORY_KEY, Constants.CONFIGURATORS_CATEGORY); - } - if (! UrlUtils.isMatch(subscribeUrl, overrideUrl)) { - if (result == null) { - result = new ArrayList(urls); - } - result.remove(url); - logger.warn("Subsribe category=configurator, but notifed non-configurator urls. may be registry bug. unexcepted url: " + url); - } - } - if (result != null) { - urls = result; - } - this.configurators = RegistryDirectory.toConfigurators(urls); + List result = null; + for (URL url : urls) { + URL overrideUrl = url; + if (url.getParameter(Constants.CATEGORY_KEY) == null + && Constants.OVERRIDE_PROTOCOL.equals(url.getProtocol())) { + // 兼容旧版本 + overrideUrl = url.addParameter(Constants.CATEGORY_KEY, Constants.CONFIGURATORS_CATEGORY); + } + if (!UrlUtils.isMatch(subscribeUrl, overrideUrl)) { + if (result == null) { + result = new ArrayList(urls); + } + result.remove(url); + logger.warn("Subscribe category=configurator, but notified non-configurator urls. may be registry bug. unexcepted url: " + url); + } + } + if (result != null) { + urls = result; + } + this.configurators = RegistryDirectory.toConfigurators(urls); List> exporters = new ArrayList>(bounds.values()); - for (ExporterChangeableWrapper exporter : exporters){ + for (ExporterChangeableWrapper exporter : exporters) { Invoker invoker = exporter.getOriginInvoker(); - final Invoker originInvoker ; - if (invoker instanceof InvokerDelegete){ - originInvoker = ((InvokerDelegete)invoker).getInvoker(); - }else { + final Invoker originInvoker; + if (invoker instanceof InvokerDelegate) { + originInvoker = ((InvokerDelegate) invoker).getInvoker(); + } else { originInvoker = invoker; } - + URL originUrl = RegistryProtocol.this.getProviderUrl(originInvoker); URL newUrl = getNewInvokerUrl(originUrl, urls); - - if (! originUrl.equals(newUrl)){ + + if (!originUrl.equals(newUrl)) { RegistryProtocol.this.doChangeLocalExport(originInvoker, newUrl); } } } - - private URL getNewInvokerUrl(URL url, List urls){ - List localConfigurators = this.configurators; // local reference + + private URL getNewInvokerUrl(URL url, List urls) { + List localConfigurators = this.configurators; // local reference // 合并override参数 if (localConfigurators != null && localConfigurators.size() > 0) { for (Configurator configurator : localConfigurators) { @@ -371,44 +368,45 @@ private URL getNewInvokerUrl(URL url, List urls){ return url; } } - - public static class InvokerDelegete extends InvokerWrapper{ + + public static class InvokerDelegate extends InvokerWrapper { private final Invoker invoker; + /** - * @param invoker - * @param url invoker.getUrl返回此值 + * @param invoker + * @param url invoker.getUrl返回此值 */ - public InvokerDelegete(Invoker invoker, URL url){ + public InvokerDelegate(Invoker invoker, URL url) { super(invoker, url); this.invoker = invoker; } - public Invoker getInvoker(){ - if (invoker instanceof InvokerDelegete){ - return ((InvokerDelegete)invoker).getInvoker(); + + public Invoker getInvoker() { + if (invoker instanceof InvokerDelegate) { + return ((InvokerDelegate) invoker).getInvoker(); } else { return invoker; } } } - + /** * exporter代理,建立返回的exporter与protocol export出的exporter的对应关系,在override时可以进行关系修改. - * - * @author chao.liuc * * @param + * @author chao.liuc */ - private class ExporterChangeableWrapper implements Exporter{ - + private class ExporterChangeableWrapper implements Exporter { + private Exporter exporter; - + private final Invoker originInvoker; - public ExporterChangeableWrapper(Exporter exporter, Invoker originInvoker){ + public ExporterChangeableWrapper(Exporter exporter, Invoker originInvoker) { this.exporter = exporter; this.originInvoker = originInvoker; } - + public Invoker getOriginInvoker() { return originInvoker; } @@ -416,8 +414,8 @@ public Invoker getOriginInvoker() { public Invoker getInvoker() { return exporter.getInvoker(); } - - public void setExporter(Exporter exporter){ + + public void setExporter(Exporter exporter) { this.exporter = exporter; } diff --git a/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/support/AbstractRegistry.java b/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/support/AbstractRegistry.java index f83256fa19c..89914dbf1e4 100644 --- a/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/support/AbstractRegistry.java +++ b/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/support/AbstractRegistry.java @@ -15,28 +15,6 @@ */ package com.alibaba.dubbo.registry.support; -import java.io.File; -import java.io.FileInputStream; -import java.io.FileOutputStream; -import java.io.IOException; -import java.io.InputStream; -import java.io.RandomAccessFile; -import java.nio.channels.FileChannel; -import java.nio.channels.FileLock; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.Properties; -import java.util.Set; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; -import java.util.concurrent.ExecutorService; -import java.util.concurrent.Executors; -import java.util.concurrent.atomic.AtomicLong; -import java.util.concurrent.atomic.AtomicReference; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; @@ -48,9 +26,20 @@ import com.alibaba.dubbo.registry.NotifyListener; import com.alibaba.dubbo.registry.Registry; +import java.io.*; +import java.nio.channels.FileChannel; +import java.nio.channels.FileLock; +import java.util.*; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; +import java.util.concurrent.ExecutorService; +import java.util.concurrent.Executors; +import java.util.concurrent.atomic.AtomicLong; +import java.util.concurrent.atomic.AtomicReference; + /** * AbstractRegistry. (SPI, Prototype, ThreadSafe) - * + * * @author chao.liuc * @author william.liangf */ @@ -77,8 +66,8 @@ public abstract class AbstractRegistry implements Registry { private final ExecutorService registryCacheExecutor = Executors.newFixedThreadPool(1, new NamedThreadFactory("DubboSaveRegistryCache", true)); //是否是同步保存文件 - private final boolean syncSaveFile ; - + private final boolean syncSaveFile; + private final AtomicLong lastCacheChanged = new AtomicLong(); private final Set registered = new ConcurrentHashSet(); @@ -95,8 +84,8 @@ public AbstractRegistry(URL url) { File file = null; if (ConfigUtils.isNotEmpty(filename)) { file = new File(filename); - if(! file.exists() && file.getParentFile() != null && ! file.getParentFile().exists()){ - if(! file.getParentFile().mkdirs()){ + if (!file.exists() && file.getParentFile() != null && !file.getParentFile().exists()) { + if (!file.getParentFile().mkdirs()) { throw new IllegalArgumentException("Invalid registry store file " + file + ", cause: Failed to create directory " + file.getParentFile() + "!"); } } @@ -137,22 +126,24 @@ public Properties getCacheProperties() { return properties; } - public AtomicLong getLastCacheChanged(){ + public AtomicLong getLastCacheChanged() { return lastCacheChanged; } - private class SaveProperties implements Runnable{ + private class SaveProperties implements Runnable { private long version; - private SaveProperties(long version){ + + private SaveProperties(long version) { this.version = version; } + public void run() { doSaveProperties(version); } } - + public void doSaveProperties(long version) { - if(version < lastCacheChanged.get()){ + if (version < lastCacheChanged.get()) { return; } if (file == null) { @@ -176,35 +167,35 @@ public void doSaveProperties(long version) { logger.warn(e.getMessage(), e); } } - } - // 保存 + } + // 保存 try { - newProperties.putAll(properties); + newProperties.putAll(properties); File lockfile = new File(file.getAbsolutePath() + ".lock"); if (!lockfile.exists()) { - lockfile.createNewFile(); + lockfile.createNewFile(); } RandomAccessFile raf = new RandomAccessFile(lockfile, "rw"); try { FileChannel channel = raf.getChannel(); try { FileLock lock = channel.tryLock(); - if (lock == null) { + if (lock == null) { throw new IOException("Can not lock the registry cache file " + file.getAbsolutePath() + ", ignore and retry later, maybe multi java process use the file, please config: dubbo.registry.file=xxx.properties"); } - // 保存 + // 保存 try { - if (! file.exists()) { + if (!file.exists()) { file.createNewFile(); } - FileOutputStream outputFile = new FileOutputStream(file); + FileOutputStream outputFile = new FileOutputStream(file); try { newProperties.store(outputFile, "Dubbo Registry Cache"); } finally { - outputFile.close(); + outputFile.close(); } } finally { - lock.release(); + lock.release(); } } finally { channel.close(); @@ -269,7 +260,7 @@ public List lookup(URL url) { if (notifiedUrls != null && notifiedUrls.size() > 0) { for (List urls : notifiedUrls.values()) { for (URL u : urls) { - if (! Constants.EMPTY_PROTOCOL.equals(u.getProtocol())) { + if (!Constants.EMPTY_PROTOCOL.equals(u.getProtocol())) { result.add(u); } } @@ -285,7 +276,7 @@ public void notify(List urls) { List urls = reference.get(); if (urls != null && urls.size() > 0) { for (URL u : urls) { - if (! Constants.EMPTY_PROTOCOL.equals(u.getProtocol())) { + if (!Constants.EMPTY_PROTOCOL.equals(u.getProtocol())) { result.add(u); } } @@ -298,7 +289,7 @@ public void register(URL url) { if (url == null) { throw new IllegalArgumentException("register url == null"); } - if (logger.isInfoEnabled()){ + if (logger.isInfoEnabled()) { logger.info("Register: " + url); } registered.add(url); @@ -308,7 +299,7 @@ public void unregister(URL url) { if (url == null) { throw new IllegalArgumentException("unregister url == null"); } - if (logger.isInfoEnabled()){ + if (logger.isInfoEnabled()) { logger.info("Unregister: " + url); } registered.remove(url); @@ -321,7 +312,7 @@ public void subscribe(URL url, NotifyListener listener) { if (listener == null) { throw new IllegalArgumentException("subscribe listener == null"); } - if (logger.isInfoEnabled()){ + if (logger.isInfoEnabled()) { logger.info("Subscribe: " + url); } Set listeners = subscribed.get(url); @@ -339,7 +330,7 @@ public void unsubscribe(URL url, NotifyListener listener) { if (listener == null) { throw new IllegalArgumentException("unsubscribe listener == null"); } - if (logger.isInfoEnabled()){ + if (logger.isInfoEnabled()) { logger.info("Unsubscribe: " + url); } Set listeners = subscribed.get(url); @@ -351,7 +342,7 @@ public void unsubscribe(URL url, NotifyListener listener) { protected void recover() throws Exception { // register Set recoverRegistered = new HashSet(getRegistered()); - if (! recoverRegistered.isEmpty()) { + if (!recoverRegistered.isEmpty()) { if (logger.isInfoEnabled()) { logger.info("Recover register url " + recoverRegistered); } @@ -361,7 +352,7 @@ protected void recover() throws Exception { } // subscribe Map> recoverSubscribed = new HashMap>(getSubscribed()); - if (! recoverSubscribed.isEmpty()) { + if (!recoverSubscribed.isEmpty()) { if (logger.isInfoEnabled()) { logger.info("Recover subscribe url " + recoverSubscribed.keySet()); } @@ -384,22 +375,22 @@ protected static List filterEmpty(URL url, List urls) { } protected void notify(List urls) { - if(urls == null || urls.isEmpty()) return; - + if (urls == null || urls.isEmpty()) return; + for (Map.Entry> entry : getSubscribed().entrySet()) { URL url = entry.getKey(); - - if(! UrlUtils.isMatch(url, urls.get(0))) { + + if (!UrlUtils.isMatch(url, urls.get(0))) { continue; } - + Set listeners = entry.getValue(); if (listeners != null) { for (NotifyListener listener : listeners) { try { notify(url, listener, filterEmpty(url, urls)); } catch (Throwable t) { - logger.error("Failed to notify registry event, urls: " + urls + ", cause: " + t.getMessage(), t); + logger.error("Failed to notify registry event, urls: " + urls + ", cause: " + t.getMessage(), t); } } } @@ -413,8 +404,8 @@ protected void notify(URL url, NotifyListener listener, List urls) { if (listener == null) { throw new IllegalArgumentException("notify listener == null"); } - if ((urls == null || urls.size() == 0) - && ! Constants.ANY_VALUE.equals(url.getServiceInterface())) { + if ((urls == null || urls.size() == 0) + && !Constants.ANY_VALUE.equals(url.getServiceInterface())) { logger.warn("Ignore empty notify urls for subscribe url " + url); return; } @@ -424,13 +415,13 @@ protected void notify(URL url, NotifyListener listener, List urls) { Map> result = new HashMap>(); for (URL u : urls) { if (UrlUtils.isMatch(url, u)) { - String category = u.getParameter(Constants.CATEGORY_KEY, Constants.DEFAULT_CATEGORY); - List categoryList = result.get(category); - if (categoryList == null) { - categoryList = new ArrayList(); - result.put(category, categoryList); - } - categoryList.add(u); + String category = u.getParameter(Constants.CATEGORY_KEY, Constants.DEFAULT_CATEGORY); + List categoryList = result.get(category); + if (categoryList == null) { + categoryList = new ArrayList(); + result.put(category, categoryList); + } + categoryList.add(u); } } if (result.size() == 0) { @@ -454,7 +445,7 @@ private void saveProperties(URL url) { if (file == null) { return; } - + try { StringBuilder buf = new StringBuilder(); Map> categoryNotified = notified.get(url); @@ -481,11 +472,11 @@ private void saveProperties(URL url) { } public void destroy() { - if (logger.isInfoEnabled()){ + if (logger.isInfoEnabled()) { logger.info("Destroy registry:" + getUrl()); } Set destroyRegistered = new HashSet(getRegistered()); - if (! destroyRegistered.isEmpty()) { + if (!destroyRegistered.isEmpty()) { for (URL url : new HashSet(getRegistered())) { if (url.getParameter(Constants.DYNAMIC_KEY, true)) { try { @@ -500,7 +491,7 @@ public void destroy() { } } Map> destroySubscribed = new HashMap>(getSubscribed()); - if (! destroySubscribed.isEmpty()) { + if (!destroySubscribed.isEmpty()) { for (Map.Entry> entry : destroySubscribed.entrySet()) { URL url = entry.getKey(); for (NotifyListener listener : entry.getValue()) { @@ -510,7 +501,7 @@ public void destroy() { logger.info("Destroy unsubscribe url " + url); } } catch (Throwable t) { - logger.warn("Failed to unsubscribe url " + url + " to registry " + getUrl() + " on destroy, cause: " +t.getMessage(), t); + logger.warn("Failed to unsubscribe url " + url + " to registry " + getUrl() + " on destroy, cause: " + t.getMessage(), t); } } } diff --git a/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/support/FailbackRegistry.java b/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/support/FailbackRegistry.java index 7930ae71d95..755b06b2b39 100644 --- a/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/support/FailbackRegistry.java +++ b/dubbo-registry/dubbo-registry-api/src/main/java/com/alibaba/dubbo/registry/support/FailbackRegistry.java @@ -15,28 +15,18 @@ */ package com.alibaba.dubbo.registry.support; -import java.util.HashMap; -import java.util.HashSet; -import java.util.List; -import java.util.Map; -import java.util.Set; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; -import java.util.concurrent.Executors; -import java.util.concurrent.Future; -import java.util.concurrent.ScheduledExecutorService; -import java.util.concurrent.ScheduledFuture; -import java.util.concurrent.TimeUnit; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.utils.ConcurrentHashSet; import com.alibaba.dubbo.common.utils.NamedThreadFactory; import com.alibaba.dubbo.registry.NotifyListener; +import java.util.*; +import java.util.concurrent.*; + /** * FailbackRegistry. (SPI, Prototype, ThreadSafe) - * + * * @author william.liangf */ public abstract class FailbackRegistry extends AbstractRegistry { @@ -134,10 +124,10 @@ public void register(URL url) { // 如果开启了启动时检测,则直接抛出异常 boolean check = getUrl().getParameter(Constants.CHECK_KEY, true) && url.getParameter(Constants.CHECK_KEY, true) - && ! Constants.CONSUMER_PROTOCOL.equals(url.getProtocol()); + && !Constants.CONSUMER_PROTOCOL.equals(url.getProtocol()); boolean skipFailback = t instanceof SkipFailbackWrapperException; if (check || skipFailback) { - if(skipFailback) { + if (skipFailback) { t = t.getCause(); } throw new IllegalStateException("Failed to register " + url + " to registry " + getUrl().getAddress() + ", cause: " + t.getMessage(), t); @@ -164,10 +154,10 @@ public void unregister(URL url) { // 如果开启了启动时检测,则直接抛出异常 boolean check = getUrl().getParameter(Constants.CHECK_KEY, true) && url.getParameter(Constants.CHECK_KEY, true) - && ! Constants.CONSUMER_PROTOCOL.equals(url.getProtocol()); + && !Constants.CONSUMER_PROTOCOL.equals(url.getProtocol()); boolean skipFailback = t instanceof SkipFailbackWrapperException; if (check || skipFailback) { - if(skipFailback) { + if (skipFailback) { t = t.getCause(); } throw new IllegalStateException("Failed to unregister " + url + " to registry " + getUrl().getAddress() + ", cause: " + t.getMessage(), t); @@ -200,7 +190,7 @@ public void subscribe(URL url, NotifyListener listener) { && url.getParameter(Constants.CHECK_KEY, true); boolean skipFailback = t instanceof SkipFailbackWrapperException; if (check || skipFailback) { - if(skipFailback) { + if (skipFailback) { t = t.getCause(); } throw new IllegalStateException("Failed to subscribe " + url + ", cause: " + t.getMessage(), t); @@ -229,7 +219,7 @@ public void unsubscribe(URL url, NotifyListener listener) { && url.getParameter(Constants.CHECK_KEY, true); boolean skipFailback = t instanceof SkipFailbackWrapperException; if (check || skipFailback) { - if(skipFailback) { + if (skipFailback) { t = t.getCause(); } throw new IllegalStateException("Failed to unsubscribe " + url + " to registry " + getUrl().getAddress() + ", cause: " + t.getMessage(), t); @@ -256,7 +246,7 @@ protected void notify(URL url, NotifyListener listener, List urls) { throw new IllegalArgumentException("notify listener == null"); } try { - doNotify(url, listener, urls); + doNotify(url, listener, urls); } catch (Exception t) { // 将失败的通知请求记录到失败列表,定时重试 Map> listeners = failedNotified.get(url); @@ -268,16 +258,16 @@ protected void notify(URL url, NotifyListener listener, List urls) { logger.error("Failed to notify for subscribe " + url + ", waiting for retry, cause: " + t.getMessage(), t); } } - + protected void doNotify(URL url, NotifyListener listener, List urls) { - super.notify(url, listener, urls); + super.notify(url, listener, urls); } - + @Override protected void recover() throws Exception { // register Set recoverRegistered = new HashSet(getRegistered()); - if (! recoverRegistered.isEmpty()) { + if (!recoverRegistered.isEmpty()) { if (logger.isInfoEnabled()) { logger.info("Recover register url " + recoverRegistered); } @@ -287,7 +277,7 @@ protected void recover() throws Exception { } // subscribe Map> recoverSubscribed = new HashMap>(getSubscribed()); - if (! recoverSubscribed.isEmpty()) { + if (!recoverSubscribed.isEmpty()) { if (logger.isInfoEnabled()) { logger.info("Recover subscribe url " + recoverSubscribed.keySet()); } @@ -302,7 +292,7 @@ protected void recover() throws Exception { // 重试失败的动作 protected void retry() { - if (! failedRegistered.isEmpty()) { + if (!failedRegistered.isEmpty()) { Set failed = new HashSet(failedRegistered); if (failed.size() > 0) { if (logger.isInfoEnabled()) { @@ -322,7 +312,7 @@ protected void retry() { } } } - if(! failedUnregistered.isEmpty()) { + if (!failedUnregistered.isEmpty()) { Set failed = new HashSet(failedUnregistered); if (failed.size() > 0) { if (logger.isInfoEnabled()) { @@ -342,7 +332,7 @@ protected void retry() { } } } - if (! failedSubscribed.isEmpty()) { + if (!failedSubscribed.isEmpty()) { Map> failed = new HashMap>(failedSubscribed); for (Map.Entry> entry : new HashMap>(failed).entrySet()) { if (entry.getValue() == null || entry.getValue().size() == 0) { @@ -371,7 +361,7 @@ protected void retry() { } } } - if (! failedUnsubscribed.isEmpty()) { + if (!failedUnsubscribed.isEmpty()) { Map> failed = new HashMap>(failedUnsubscribed); for (Map.Entry> entry : new HashMap>(failed).entrySet()) { if (entry.getValue() == null || entry.getValue().size() == 0) { @@ -400,7 +390,7 @@ protected void retry() { } } } - if (! failedNotified.isEmpty()) { + if (!failedNotified.isEmpty()) { Map>> failed = new HashMap>>(failedNotified); for (Map.Entry>> entry : new HashMap>>(failed).entrySet()) { if (entry.getValue() == null || entry.getValue().size() == 0) { diff --git a/dubbo-registry/dubbo-registry-default/pom.xml b/dubbo-registry/dubbo-registry-default/pom.xml index 2ee2515bed9..074e2d74690 100644 --- a/dubbo-registry/dubbo-registry-default/pom.xml +++ b/dubbo-registry/dubbo-registry-default/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-registry - 2.8.4 + 3.0.1 dubbo-registry-default jar diff --git a/dubbo-registry/dubbo-registry-default/src/test/java/com/alibaba/dubbo/registry/dubbo/MockChannel.java b/dubbo-registry/dubbo-registry-default/src/test/java/com/alibaba/dubbo/registry/dubbo/MockChannel.java index 19e1b5bdcb9..5c33053bcd4 100644 --- a/dubbo-registry/dubbo-registry-default/src/test/java/com/alibaba/dubbo/registry/dubbo/MockChannel.java +++ b/dubbo-registry/dubbo-registry-default/src/test/java/com/alibaba/dubbo/registry/dubbo/MockChannel.java @@ -1,28 +1,28 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.registry.dubbo; import java.net.InetSocketAddress; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; -import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.exchange.*; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; public class MockChannel implements ExchangeChannel { @@ -64,19 +64,18 @@ public URL getUrl() { return null; } - public ResponseFuture send(Object request, int timeout) throws RemotingException { - return null; - } - + @Override public ChannelHandler getChannelHandler() { return null; } - public ResponseFuture request(Object request) throws RemotingException { + @Override + public Response request(Request request) throws RemotingException { return null; } - public ResponseFuture request(Object request, int timeout) throws RemotingException { + @Override + public Response request(Request request, int timeout) throws RemotingException { return null; } diff --git a/dubbo-registry/dubbo-registry-default/src/test/java/com/alibaba/dubbo/registry/dubbo/MockedClient.java b/dubbo-registry/dubbo-registry-default/src/test/java/com/alibaba/dubbo/registry/dubbo/MockedClient.java index 0d677d8cc72..3c4ef04a1fa 100644 --- a/dubbo-registry/dubbo-registry-default/src/test/java/com/alibaba/dubbo/registry/dubbo/MockedClient.java +++ b/dubbo-registry/dubbo-registry-default/src/test/java/com/alibaba/dubbo/registry/dubbo/MockedClient.java @@ -1,67 +1,68 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.registry.dubbo; -import java.net.InetSocketAddress; -import java.util.Map; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Codec; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.ExchangeClient; -import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.ResponseCallback; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; -import com.alibaba.dubbo.remoting.exchange.support.Replier; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.remoting.Codec; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.exchange.ExchangeClient; +import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; +import com.alibaba.dubbo.remoting.exchange.support.Replier; +import com.alibaba.dubbo.remoting.message.Interceptor; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; + +import java.net.InetSocketAddress; +import java.util.Map; /** * MockedClient - * + * * @author william.liangf */ public class MockedClient implements ExchangeClient { - + //private String host; //private int port; - + private boolean connected; - + private Object received; private Object sent; - + private Object invoked; - + private Replier handler; - + private InetSocketAddress address; - + private boolean closed = false; //private ChannelListener listener; - + public MockedClient(String host, int port, boolean connected) { - this(host, port, connected, null); + this(host, port, connected, null); } public MockedClient(String host, int port, boolean connected, Object received) { - this.address = new InetSocketAddress(host, port); + this.address = new InetSocketAddress(host, port); this.connected = connected; this.received = received; } @@ -77,25 +78,14 @@ public void send(Object msg) throws RemotingException { this.sent = msg; } - public ResponseFuture request(Object msg) throws RemotingException { - return request(msg, 0); + @Override + public Response request(Request request) throws RemotingException { + return null; } - public ResponseFuture request(Object msg, int timeout) throws RemotingException { - this.invoked = msg; - return new ResponseFuture() { - public Object get() throws RemotingException { - return received; - } - public Object get(int timeoutInMillis) throws RemotingException { - return received; - } - public boolean isDone() { - return true; - } - public void setCallback(ResponseCallback callback) { - } - }; + @Override + public Response request(Request request, int timeout) throws RemotingException { + return null; } public void registerHandler(Replier handler) { @@ -130,39 +120,39 @@ public Object getInvoked() { return invoked; } - public InetSocketAddress getRemoteAddress() { - return address; - } + public InetSocketAddress getRemoteAddress() { + return address; + } - public String getName() { - return "mocked"; - } + public String getName() { + return "mocked"; + } - public InetSocketAddress getLocalAddress() { - return null; - } + public InetSocketAddress getLocalAddress() { + return null; + } - public void setTimeout(int timeout) { - } + public void setTimeout(int timeout) { + } - public int getTimeout() { - return 0; - } + public int getTimeout() { + return 0; + } - public void close(int timeout) { - close(); - } + public void close(int timeout) { + close(); + } - public boolean isOpen() { - return closed; - } + public boolean isOpen() { + return closed; + } - public Codec getCodec() { - return null; - } + public Codec getCodec() { + return null; + } - public void setCodec(Codec codec) { - } + public void setCodec(Codec codec) { + } public void setHost(String host) { } @@ -216,7 +206,7 @@ public Object getAttribute(String key) { } public void setAttribute(String key, Object value) { - + } public boolean hasAttribute(String key) { @@ -228,8 +218,9 @@ public boolean isClosed() { } public void removeAttribute(String key) { - + } + /** * @return the received */ @@ -255,10 +246,14 @@ public void send(Object message, boolean sent) throws RemotingException { } public void reset(URL url) { - } - - @Deprecated - public void reset(com.alibaba.dubbo.common.Parameters parameters) { } - + + @Deprecated + public void reset(com.alibaba.dubbo.common.Parameters parameters) { + } + + @Override + public void addInterceptor(Interceptor interceptor) { + // NOP + } } \ No newline at end of file diff --git a/dubbo-registry/dubbo-registry-multicast/pom.xml b/dubbo-registry/dubbo-registry-multicast/pom.xml index 478d4fb67b7..d606f6c2f0a 100644 --- a/dubbo-registry/dubbo-registry-multicast/pom.xml +++ b/dubbo-registry/dubbo-registry-multicast/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-registry - 2.8.4 + 3.0.1 dubbo-registry-multicast jar diff --git a/dubbo-registry/dubbo-registry-redis/pom.xml b/dubbo-registry/dubbo-registry-redis/pom.xml index 10c9fa26b49..fe11221e05c 100644 --- a/dubbo-registry/dubbo-registry-redis/pom.xml +++ b/dubbo-registry/dubbo-registry-redis/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-registry - 2.8.4 + 3.0.1 dubbo-registry-redis jar diff --git a/dubbo-registry/dubbo-registry-zookeeper/pom.xml b/dubbo-registry/dubbo-registry-zookeeper/pom.xml index 774d0b73bda..27e12d3039e 100644 --- a/dubbo-registry/dubbo-registry-zookeeper/pom.xml +++ b/dubbo-registry/dubbo-registry-zookeeper/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-registry - 2.8.4 + 3.0.1 dubbo-registry-zookeeper jar diff --git a/dubbo-registry/dubbo-registry-zookeeper/src/main/java/com/alibaba/dubbo/registry/zookeeper/ZookeeperRegistry.java b/dubbo-registry/dubbo-registry-zookeeper/src/main/java/com/alibaba/dubbo/registry/zookeeper/ZookeeperRegistry.java index 1a39435f964..ecf42042c65 100644 --- a/dubbo-registry/dubbo-registry-zookeeper/src/main/java/com/alibaba/dubbo/registry/zookeeper/ZookeeperRegistry.java +++ b/dubbo-registry/dubbo-registry-zookeeper/src/main/java/com/alibaba/dubbo/registry/zookeeper/ZookeeperRegistry.java @@ -15,12 +15,6 @@ */ package com.alibaba.dubbo.registry.zookeeper; -import java.util.ArrayList; -import java.util.List; -import java.util.Set; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; @@ -30,14 +24,20 @@ import com.alibaba.dubbo.registry.NotifyListener; import com.alibaba.dubbo.registry.support.FailbackRegistry; import com.alibaba.dubbo.remoting.zookeeper.ChildListener; -import com.alibaba.dubbo.remoting.zookeeper.ZookeeperClient; import com.alibaba.dubbo.remoting.zookeeper.StateListener; +import com.alibaba.dubbo.remoting.zookeeper.ZookeeperClient; import com.alibaba.dubbo.remoting.zookeeper.ZookeeperTransporter; import com.alibaba.dubbo.rpc.RpcException; +import java.util.ArrayList; +import java.util.List; +import java.util.Set; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; + /** * ZookeeperRegistry - * + * * @author william.liangf */ public class ZookeeperRegistry extends FailbackRegistry { @@ -45,37 +45,37 @@ public class ZookeeperRegistry extends FailbackRegistry { private final static Logger logger = LoggerFactory.getLogger(ZookeeperRegistry.class); private final static int DEFAULT_ZOOKEEPER_PORT = 2181; - + private final static String DEFAULT_ROOT = "dubbo"; - private final String root; - + private final String root; + private final Set anyServices = new ConcurrentHashSet(); private final ConcurrentMap> zkListeners = new ConcurrentHashMap>(); - + private final ZookeeperClient zkClient; - + public ZookeeperRegistry(URL url, ZookeeperTransporter zookeeperTransporter) { super(url); if (url.isAnyHost()) { - throw new IllegalStateException("registry address == null"); - } + throw new IllegalStateException("registry address == null"); + } String group = url.getParameter(Constants.GROUP_KEY, DEFAULT_ROOT); - if (! group.startsWith(Constants.PATH_SEPARATOR)) { + if (!group.startsWith(Constants.PATH_SEPARATOR)) { group = Constants.PATH_SEPARATOR + group; } this.root = group; zkClient = zookeeperTransporter.connect(url); zkClient.addStateListener(new StateListener() { public void stateChanged(int state) { - if (state == RECONNECTED) { - try { - recover(); - } catch (Exception e) { - logger.error(e.getMessage(), e); - } - } + if (state == RECONNECTED) { + try { + recover(); + } catch (Exception e) { + logger.error(e.getMessage(), e); + } + } } }); } @@ -95,7 +95,7 @@ public void destroy() { protected void doRegister(URL url) { try { - zkClient.create(toUrlPath(url), url.getParameter(Constants.DYNAMIC_KEY, true)); + zkClient.create(toUrlPath(url), url.getParameter(Constants.DYNAMIC_KEY, true)); } catch (Throwable e) { throw new RpcException("Failed to register " + url + " to zookeeper " + getUrl() + ", cause: " + e.getMessage(), e); } @@ -123,10 +123,10 @@ protected void doSubscribe(final URL url, final NotifyListener listener) { listeners.putIfAbsent(listener, new ChildListener() { public void childChanged(String parentPath, List currentChilds) { for (String child : currentChilds) { - child = URL.decode(child); - if (! anyServices.contains(child)) { + child = URL.decode(child); + if (!anyServices.contains(child)) { anyServices.add(child); - subscribe(url.setPath(child).addParameters(Constants.INTERFACE_KEY, child, + subscribe(url.setPath(child).addParameters(Constants.INTERFACE_KEY, child, Constants.CHECK_KEY, String.valueOf(false)), listener); } } @@ -138,9 +138,9 @@ public void childChanged(String parentPath, List currentChilds) { List services = zkClient.addChildListener(root, zkListener); if (services != null && services.size() > 0) { for (String service : services) { - service = URL.decode(service); - anyServices.add(service); - subscribe(url.setPath(service).addParameters(Constants.INTERFACE_KEY, service, + service = URL.decode(service); + anyServices.add(service); + subscribe(url.setPath(service).addParameters(Constants.INTERFACE_KEY, service, Constants.CHECK_KEY, String.valueOf(false)), listener); } } @@ -156,7 +156,7 @@ public void childChanged(String parentPath, List currentChilds) { if (zkListener == null) { listeners.putIfAbsent(listener, new ChildListener() { public void childChanged(String parentPath, List currentChilds) { - ZookeeperRegistry.this.notify(url, listener, toUrlsWithEmpty(url, parentPath, currentChilds)); + ZookeeperRegistry.this.notify(url, listener, toUrlsWithEmpty(url, parentPath, currentChilds)); } }); zkListener = listeners.get(listener); @@ -164,7 +164,7 @@ public void childChanged(String parentPath, List currentChilds) { zkClient.create(path, false); List children = zkClient.addChildListener(path, zkListener); if (children != null) { - urls.addAll(toUrlsWithEmpty(url, path, children)); + urls.addAll(toUrlsWithEmpty(url, path, children)); } } notify(url, listener, urls); @@ -191,28 +191,28 @@ public List lookup(URL url) { try { List providers = new ArrayList(); for (String path : toCategoriesPath(url)) { - List children = zkClient.getChildren(path); - if (children != null) { - providers.addAll(children); - } + List children = zkClient.getChildren(path); + if (children != null) { + providers.addAll(children); + } } return toUrlsWithoutEmpty(url, providers); } catch (Throwable e) { throw new RpcException("Failed to lookup " + url + " from zookeeper " + getUrl() + ", cause: " + e.getMessage(), e); } } - + private String toRootDir() { if (root.equals(Constants.PATH_SEPARATOR)) { return root; } return root + Constants.PATH_SEPARATOR; } - + private String toRootPath() { return root; } - + private String toServicePath(URL url) { String name = url.getServiceInterface(); if (Constants.ANY_VALUE.equals(name)) { @@ -224,13 +224,13 @@ private String toServicePath(URL url) { private String[] toCategoriesPath(URL url) { String[] categroies; if (Constants.ANY_VALUE.equals(url.getParameter(Constants.CATEGORY_KEY))) { - categroies = new String[] {Constants.PROVIDERS_CATEGORY, Constants.CONSUMERS_CATEGORY, + categroies = new String[]{Constants.PROVIDERS_CATEGORY, Constants.CONSUMERS_CATEGORY, Constants.ROUTERS_CATEGORY, Constants.CONFIGURATORS_CATEGORY}; } else { - categroies = url.getParameter(Constants.CATEGORY_KEY, new String[] {Constants.DEFAULT_CATEGORY}); + categroies = url.getParameter(Constants.CATEGORY_KEY, new String[]{Constants.DEFAULT_CATEGORY}); } String[] paths = new String[categroies.length]; - for (int i = 0; i < categroies.length; i ++) { + for (int i = 0; i < categroies.length; i++) { paths[i] = toServicePath(url) + Constants.PATH_SEPARATOR + categroies[i]; } return paths; @@ -243,9 +243,9 @@ private String toCategoryPath(URL url) { private String toUrlPath(URL url) { return toCategoryPath(url) + Constants.PATH_SEPARATOR + URL.encode(url.toFullString()); } - + private List toUrlsWithoutEmpty(URL consumer, List providers) { - List urls = new ArrayList(); + List urls = new ArrayList(); if (providers != null && providers.size() > 0) { for (String provider : providers) { provider = URL.decode(provider); @@ -263,9 +263,9 @@ private List toUrlsWithoutEmpty(URL consumer, List providers) { private List toUrlsWithEmpty(URL consumer, String path, List providers) { List urls = toUrlsWithoutEmpty(consumer, providers); if (urls.isEmpty()) { - int i = path.lastIndexOf('/'); - String category = i < 0 ? path : path.substring(i + 1); - URL empty = consumer.setProtocol(Constants.EMPTY_PROTOCOL).addParameter(Constants.CATEGORY_KEY, category); + int i = path.lastIndexOf('/'); + String category = i < 0 ? path : path.substring(i + 1); + URL empty = consumer.setProtocol(Constants.EMPTY_PROTOCOL).addParameter(Constants.CATEGORY_KEY, category); urls.add(empty); } return urls; diff --git a/dubbo-registry/pom.xml b/dubbo-registry/pom.xml index 4dedf4fc732..56f985cc928 100644 --- a/dubbo-registry/pom.xml +++ b/dubbo-registry/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-registry pom diff --git a/dubbo-remoting/dubbo-remoting-api/pom.xml b/dubbo-remoting/dubbo-remoting-api/pom.xml index c8fe1460033..9556c423297 100644 --- a/dubbo-remoting/dubbo-remoting-api/pom.xml +++ b/dubbo-remoting/dubbo-remoting-api/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-remoting - 2.8.4 + 3.0.1 dubbo-remoting-api jar @@ -34,5 +34,20 @@ dubbo-common ${project.parent.version} + + com.alibaba + dubbo-remoting-common + ${project.parent.version} + + + com.alibaba + dubbo-tracker-api + ${project.parent.version} + + + + + + \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Codec.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Codec.java index 29e7be83eba..9771c8fcb16 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Codec.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Codec.java @@ -22,6 +22,7 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.extension.Adaptive; import com.alibaba.dubbo.common.extension.SPI; +import com.alibaba.dubbo.remoting.transport.Channel; /** * Codec. (SPI, Singleton, ThreadSafe) diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Codec2.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Codec2.java index bfdc7871d77..7da41bf452c 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Codec2.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Codec2.java @@ -21,6 +21,7 @@ import com.alibaba.dubbo.common.extension.Adaptive; import com.alibaba.dubbo.common.extension.SPI; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; +import com.alibaba.dubbo.remoting.transport.Channel; /** * @author kimi diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Decodeable.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Decodeable.java index 7020ee851f2..3f8fc737436 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Decodeable.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Decodeable.java @@ -21,6 +21,6 @@ */ public interface Decodeable { - public void decode() throws Exception; + void decode() throws Exception; } diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Dispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Dispatcher.java index 2699fcb0e12..556d1106848 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Dispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Dispatcher.java @@ -19,6 +19,7 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.Adaptive; import com.alibaba.dubbo.common.extension.SPI; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.transport.dispatcher.all.AllDispatcher; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Transporters.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Transporters.java index 5f1d99c5c74..b6b8ee774de 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Transporters.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Transporters.java @@ -18,6 +18,11 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.extension.ExtensionLoader; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.transport.Server; +import com.alibaba.dubbo.remoting.transport.Transporter; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.ChannelHandlerAdapter; import com.alibaba.dubbo.remoting.transport.ChannelHandlerDispatcher; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeChannel.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeChannel.java index b62cb2c7633..3181accc28b 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeChannel.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeChannel.java @@ -15,45 +15,47 @@ */ package com.alibaba.dubbo.remoting.exchange; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.Channel; /** * ExchangeChannel. (API/SPI, Prototype, ThreadSafe) - * + * * @author william.liangf */ public interface ExchangeChannel extends Channel { /** - * send request. - * + * send request and receive response sync + * * @param request - * @return response future + * @return * @throws RemotingException */ - ResponseFuture request(Object request) throws RemotingException; + Response request(Request request) throws RemotingException; /** - * send request. - * + * send request and receive response sync + * * @param request * @param timeout - * @return response future + * @return * @throws RemotingException */ - ResponseFuture request(Object request, int timeout) throws RemotingException; + Response request(Request request, int timeout) throws RemotingException; /** * get message handler. - * + * * @return message handler */ ExchangeHandler getExchangeHandler(); /** * graceful close. - * + * * @param timeout */ void close(int timeout); diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeClient.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeClient.java index 6e0d61c7d46..072a7170287 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeClient.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeClient.java @@ -15,13 +15,15 @@ */ package com.alibaba.dubbo.remoting.exchange; -import com.alibaba.dubbo.remoting.Client; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.message.Interceptor; /** * ExchangeClient. (API/SPI, Prototype, ThreadSafe) - * + * * @author william.liangf */ public interface ExchangeClient extends Client, ExchangeChannel { + void addInterceptor(Interceptor interceptor); } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeHandler.java index b5e183bf77a..3259c20e933 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeHandler.java @@ -15,8 +15,8 @@ */ package com.alibaba.dubbo.remoting.exchange; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeServer.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeServer.java index 55ff1ba549b..53db6aeafcf 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeServer.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ExchangeServer.java @@ -18,7 +18,7 @@ import java.net.InetSocketAddress; import java.util.Collection; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.transport.Server; /** * ExchangeServer. (API/SPI, Prototype, ThreadSafe) diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Exchanger.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Exchanger.java index c303e420408..942de3035e1 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Exchanger.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Exchanger.java @@ -19,7 +19,7 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.Adaptive; import com.alibaba.dubbo.common.extension.SPI; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.support.header.HeaderExchanger; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Exchangers.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Exchangers.java index 4f6c21a6e58..3217ed8013a 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Exchangers.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Exchangers.java @@ -19,8 +19,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.support.ExchangeHandlerDispatcher; import com.alibaba.dubbo.remoting.exchange.support.Replier; import com.alibaba.dubbo.remoting.transport.ChannelHandlerAdapter; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Request.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Request.java deleted file mode 100644 index 33c0072f287..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Request.java +++ /dev/null @@ -1,133 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting.exchange; - -import java.util.concurrent.atomic.AtomicLong; - -import com.alibaba.dubbo.common.utils.StringUtils; - -/** - * Request. - * - * @author qian.lei - * @author william.liangf - */ -public class Request { - - public static final String HEARTBEAT_EVENT = null; - - public static final String READONLY_EVENT = "R"; - - private static final AtomicLong INVOKE_ID = new AtomicLong(0); - - private final long mId; - - private String mVersion; - - private boolean mTwoWay = true; - - private boolean mEvent = false; - - private boolean mBroken = false; - - private Object mData; - - public Request() { - mId = newId(); - } - - public Request(long id){ - mId = id; - } - - public long getId() { - return mId; - } - - public String getVersion() { - return mVersion; - } - - public void setVersion(String version) { - mVersion = version; - } - - public boolean isTwoWay() { - return mTwoWay; - } - - public void setTwoWay(boolean twoWay) { - mTwoWay = twoWay; - } - - public boolean isEvent() { - return mEvent; - } - - public void setEvent(String event) { - mEvent = true; - mData = event; - } - - public boolean isBroken() { - return mBroken; - } - - public void setBroken(boolean mBroken) { - this.mBroken = mBroken; - } - - public Object getData() { - return mData; - } - - public void setData(Object msg) { - mData = msg; - } - - public boolean isHeartbeat() { - return mEvent && HEARTBEAT_EVENT == mData; - } - - public void setHeartbeat(boolean isHeartbeat) { - if (isHeartbeat) { - setEvent(HEARTBEAT_EVENT); - } - } - - private static long newId() { - // getAndIncrement()增长到MAX_VALUE时,再增长会变为MIN_VALUE,负数也可以做为ID - return INVOKE_ID.getAndIncrement(); - } - - @Override - public String toString() { - return "Request [id=" + mId + ", version=" + mVersion + ", twoway=" + mTwoWay + ", event=" + mEvent - + ", broken=" + mBroken + ", data=" + (mData == this ? "this" : safeToString(mData)) + "]"; - } - - private static String safeToString(Object data) { - if (data == null) return null; - String dataStr; - try { - dataStr = data.toString(); - } catch (Throwable e) { - dataStr = ""; - } - return dataStr; - } -} diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Response.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Response.java deleted file mode 100644 index 0ac70708bac..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/Response.java +++ /dev/null @@ -1,164 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting.exchange; - -/** - * Response - * - * @author qian.lei - * @author william.liangf - */ -public class Response { - - public static final String HEARTBEAT_EVENT = null; - - public static final String READONLY_EVENT = "R"; - - /** - * ok. - */ - public static final byte OK = 20; - - /** - * clien side timeout. - */ - public static final byte CLIENT_TIMEOUT = 30; - - /** - * server side timeout. - */ - public static final byte SERVER_TIMEOUT = 31; - - /** - * request format error. - */ - public static final byte BAD_REQUEST = 40; - - /** - * response format error. - */ - public static final byte BAD_RESPONSE = 50; - - /** - * service not found. - */ - public static final byte SERVICE_NOT_FOUND = 60; - - /** - * service error. - */ - public static final byte SERVICE_ERROR = 70; - - /** - * internal server error. - */ - public static final byte SERVER_ERROR = 80; - - /** - * internal server error. - */ - public static final byte CLIENT_ERROR = 90; - - private long mId = 0; - - private String mVersion; - - private byte mStatus = OK; - - private boolean mEvent = false; - - private String mErrorMsg; - - private Object mResult; - - public Response(){ - } - - public Response(long id){ - mId = id; - } - - public Response(long id, String version){ - mId = id; - mVersion = version; - } - - public long getId() { - return mId; - } - - public void setId(long id) { - mId = id; - } - - public String getVersion() { - return mVersion; - } - - public void setVersion(String version) { - mVersion = version; - } - - public byte getStatus() { - return mStatus; - } - - public void setStatus(byte status) { - mStatus = status; - } - - public boolean isEvent() { - return mEvent; - } - - public void setEvent(String event) { - mEvent = true; - mResult = event; - } - - public boolean isHeartbeat() { - return mEvent && HEARTBEAT_EVENT == mResult; - } - - @Deprecated - public void setHeartbeat(boolean isHeartbeat) { - if (isHeartbeat) { - setEvent(HEARTBEAT_EVENT); - } - } - - public Object getResult() { - return mResult; - } - - public void setResult(Object msg) { - mResult = msg; - } - - public String getErrorMessage() { - return mErrorMsg; - } - - public void setErrorMessage(String msg) { - mErrorMsg = msg; - } - - @Override - public String toString() { - return "Response [id=" + mId + ", version=" + mVersion + ", status=" + mStatus + ", event=" + mEvent - + ", error=" + mErrorMsg + ", result=" + (mResult == this ? "this" : mResult) + "]"; - } -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ResponseCallback.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ResponseCallback.java deleted file mode 100644 index efe3d8b5168..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ResponseCallback.java +++ /dev/null @@ -1,39 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting.exchange; - -/** - * Callback - * - * @author william.liangf - */ -public interface ResponseCallback { - - /** - * done. - * - * @param response - */ - void done(Object response); - - /** - * caught exception. - * - * @param exception - */ - void caught(Throwable exception); - -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ResponseFuture.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ResponseFuture.java deleted file mode 100644 index 69eb691c6cc..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/ResponseFuture.java +++ /dev/null @@ -1,59 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting.exchange; - -import com.alibaba.dubbo.remoting.RemotingException; - -/** - * Future. (API/SPI, Prototype, ThreadSafe) - * - * @see com.alibaba.dubbo.remoting.exchange.ExchangeChannel#request(Object) - * @see com.alibaba.dubbo.remoting.exchange.ExchangeChannel#request(Object, int) - * @author qian.lei - * @author william.liangf - */ -public interface ResponseFuture { - - /** - * get result. - * - * @return result. - */ - Object get() throws RemotingException; - - /** - * get result with the specified timeout. - * - * @param timeoutInMillis timeout. - * @return result. - */ - Object get(int timeoutInMillis) throws RemotingException; - - /** - * set callback. - * - * @param callback - */ - void setCallback(ResponseCallback callback); - - /** - * check is done. - * - * @return done or not. - */ - boolean isDone(); - -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/codec/ExchangeCodec.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/codec/ExchangeCodec.java index e2db42b06f5..37e944d1835 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/codec/ExchangeCodec.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/codec/ExchangeCodec.java @@ -15,9 +15,7 @@ */ package com.alibaba.dubbo.remoting.exchange.codec; -import java.io.IOException; -import java.io.InputStream; - +import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.io.Bytes; import com.alibaba.dubbo.common.io.StreamUtils; import com.alibaba.dubbo.common.logger.Logger; @@ -27,45 +25,44 @@ import com.alibaba.dubbo.common.serialize.ObjectOutput; import com.alibaba.dubbo.common.serialize.Serialization; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; import com.alibaba.dubbo.remoting.buffer.ChannelBufferInputStream; import com.alibaba.dubbo.remoting.buffer.ChannelBufferOutputStream; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.remoting.exchange.support.DefaultFuture; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; import com.alibaba.dubbo.remoting.telnet.codec.TelnetCodec; import com.alibaba.dubbo.remoting.transport.CodecSupport; +import java.io.IOException; +import java.io.InputStream; + /** * ExchangeCodec. - * + * * @author qianlei * @author william.liangf */ public class ExchangeCodec extends TelnetCodec { - private static final Logger logger = LoggerFactory.getLogger(ExchangeCodec.class); - + private static final Logger logger = LoggerFactory.getLogger(ExchangeCodec.class); // header length. - protected static final int HEADER_LENGTH = 16; - + protected static final int HEADER_LENGTH = 16; // magic header. - protected static final short MAGIC = (short) 0xdabb; - - protected static final byte MAGIC_HIGH = Bytes.short2bytes(MAGIC)[0]; - - protected static final byte MAGIC_LOW = Bytes.short2bytes(MAGIC)[1]; + protected static final short MAGIC = (short) 0xdabb; + + protected static final byte MAGIC_HIGH = Bytes.short2bytes(MAGIC)[0]; + protected static final byte MAGIC_LOW = Bytes.short2bytes(MAGIC)[1]; // message flag. - protected static final byte FLAG_REQUEST = (byte) 0x80; + protected static final byte FLAG_REQUEST = (byte) 0x80; - protected static final byte FLAG_TWOWAY = (byte) 0x40; + protected static final byte FLAG_TWOWAY = (byte) 0x40; - protected static final byte FLAG_EVENT = (byte) 0x20; + protected static final byte FLAG_EVENT = (byte) 0x20; - protected static final int SERIALIZATION_MASK = 0x1f; + protected static final int SERIALIZATION_MASK = 0x1f; public Short getMagicCode() { return MAGIC; @@ -79,13 +76,9 @@ public void encode(Channel channel, ChannelBuffer buffer, Object msg) throws IOE } else { super.encode(channel, buffer, msg); } - - // TODO modified by lishen -// System.out.println(">>>>>>>>>>>>>>>>>>>>>> the resulting byte size of encoding is " + buffer.readableBytes()); if (logger.isTraceEnabled()) { logger.trace("the resulting byte size of encoding is " + buffer.readableBytes()); } - } public Object decode(Channel channel, ChannelBuffer buffer) throws IOException { @@ -94,17 +87,16 @@ public Object decode(Channel channel, ChannelBuffer buffer) throws IOException { buffer.readBytes(header); return decode(channel, buffer, readable, header); } - + protected Object decode(Channel channel, ChannelBuffer buffer, int readable, byte[] header) throws IOException { // check magic number. - if (readable > 0 && header[0] != MAGIC_HIGH - || readable > 1 && header[1] != MAGIC_LOW) { + if (readable > 0 && header[0] != MAGIC_HIGH || readable > 1 && header[1] != MAGIC_LOW) { int length = header.length; if (header.length < readable) { header = Bytes.copyOf(header, readable); buffer.readBytes(header, length, readable - length); } - for (int i = 1; i < header.length - 1; i ++) { + for (int i = 1; i < header.length - 1; i++) { if (header[i] == MAGIC_HIGH && header[i + 1] == MAGIC_LOW) { buffer.readerIndex(buffer.readerIndex() - header.length + i); header = Bytes.copyOf(header, i); @@ -123,7 +115,7 @@ protected Object decode(Channel channel, ChannelBuffer buffer, int readable, byt checkPayload(channel, len); int tt = len + HEADER_LENGTH; - if( readable < tt ) { + if (readable < tt) { return DecodeResult.NEED_MORE_INPUT; } @@ -154,85 +146,69 @@ protected Object decodeBody(Channel channel, InputStream is, byte[] header) thro long id = Bytes.bytes2long(header, 4); if ((flag & FLAG_REQUEST) == 0) { // decode response. - Response res = new Response(id); - if ((flag & FLAG_EVENT) != 0) { - res.setEvent(Response.HEARTBEAT_EVENT); + Response.Builder builder = new Response.Builder(id); + boolean isEvent = (flag & FLAG_EVENT) != 0; + builder.isEvent(isEvent); + if (isEvent) { + builder.result(Response.HEARTBEAT_EVENT); } // get status. byte status = header[3]; - res.setStatus(status); + builder.status(status); if (status == Response.OK) { try { Object data; - if (res.isHeartbeat()) { - data = decodeHeartbeatData(channel, in); - } else if (res.isEvent()) { + if (isEvent) { data = decodeEventData(channel, in); } else { - data = decodeResponseData(channel, in, getRequestData(id)); + data = decodeResponseData(channel, in); } - res.setResult(data); + builder.result(data); } catch (Throwable t) { - res.setStatus(Response.CLIENT_ERROR); - res.setErrorMessage(StringUtils.toString(t)); + builder.status(Response.CLIENT_ERROR); + builder.errorMsg(StringUtils.toString(t)); } } else { - res.setErrorMessage(in.readUTF()); + builder.errorMsg(in.readUTF()); } - return res; + return builder.build(); } else { // decode request. - Request req = new Request(id); - req.setVersion("2.0.0"); - req.setTwoWay((flag & FLAG_TWOWAY) != 0); - if ((flag & FLAG_EVENT) != 0) { - req.setEvent(Request.HEARTBEAT_EVENT); + Request.Builder builder = new Request.Builder(id); + builder.version(Version.getVersion()).twoWay((flag & FLAG_TWOWAY) != 0); + boolean isEvent = (flag & FLAG_EVENT) != 0; + if (isEvent) { + builder.isEvent(true).data(Request.HEARTBEAT_EVENT); } try { Object data; - if (req.isHeartbeat()) { - data = decodeHeartbeatData(channel, in); - } else if (req.isEvent()) { + if (isEvent) { data = decodeEventData(channel, in); } else { data = decodeRequestData(channel, in); } - req.setData(data); + builder.data(data); } catch (Throwable t) { // bad request - req.setBroken(true); - req.setData(t); + builder.broken(true); + builder.data(t); } - return req; + return builder.build(); } } - protected Object getRequestData(long id) { - DefaultFuture future = DefaultFuture.getFuture(id); - if (future == null) - return null; - Request req = future.getRequest(); - if (req == null) - return null; - return req.getData(); - } - protected void encodeRequest(Channel channel, ChannelBuffer buffer, Request req) throws IOException { Serialization serialization = getSerialization(channel); // header. byte[] header = new byte[HEADER_LENGTH]; // set magic number. Bytes.short2bytes(MAGIC, header); - // set request and serialization flag. header[2] = (byte) (FLAG_REQUEST | serialization.getContentTypeId()); - if (req.isTwoWay()) header[2] |= FLAG_TWOWAY; if (req.isEvent()) header[2] |= FLAG_EVENT; - // set request id. Bytes.long2bytes(req.getId(), header, 4); - // encode request data. int savedWriteIndex = buffer.writerIndex(); buffer.writerIndex(savedWriteIndex + HEADER_LENGTH); @@ -288,12 +264,11 @@ protected void encodeResponse(Channel channel, ChannelBuffer buffer, Response re // encode response data or error message. if (status == Response.OK) { if (res.isHeartbeat()) { - encodeHeartbeatData(channel, out, res.getResult()); + encodeEventData(channel, out, res.getResult()); } else { encodeResponseData(channel, out, res.getResult()); } - } - else out.writeUTF(res.getErrorMessage()); + } else out.writeUTF(res.getErrorMessage()); out.flushBuffer(); } finally { // modified by lishen @@ -314,22 +289,19 @@ protected void encodeResponse(Channel channel, ChannelBuffer buffer, Response re buffer.writerIndex(savedWriteIndex + HEADER_LENGTH + len); } catch (Throwable t) { // 发送失败信息给Consumer,否则Consumer只能等超时了 - if (! res.isEvent() && res.getStatus() != Response.BAD_RESPONSE) { + if (!res.isEvent() && res.getStatus() != Response.BAD_RESPONSE) { try { - // FIXME 在Codec中打印出错日志?在IoHanndler的caught中统一处理? logger.warn("Fail to encode response: " + res + ", send bad_response info instead, cause: " + t.getMessage(), t); - - Response r = new Response(res.getId(), res.getVersion()); - r.setStatus(Response.BAD_RESPONSE); - r.setErrorMessage("Failed to send response: " + res + ", cause: " + StringUtils.toString(t)); - channel.send(r); - + Response.Builder builder = new Response.Builder(res.getId()); + builder.version(res.getVersion()).status(Response.BAD_RESPONSE); + builder.errorMsg("Failed to send response: " + res + ", cause: " + StringUtils.toString(t)); + channel.send(builder.build()); return; } catch (RemotingException e) { logger.warn("Failed to send bad_response info back: " + res + ", cause: " + e.getMessage(), e); } } - + // 重新抛出收到的异常 if (t instanceof IOException) { throw (IOException) t; @@ -337,26 +309,17 @@ protected void encodeResponse(Channel channel, ChannelBuffer buffer, Response re throw (RuntimeException) t; } else if (t instanceof Error) { throw (Error) t; - } else { + } else { throw new RuntimeException(t.getMessage(), t); } } } - + @Override protected Object decodeData(ObjectInput in) throws IOException { return decodeRequestData(in); } - @Deprecated - protected Object decodeHeartbeatData(ObjectInput in) throws IOException { - try { - return in.readObject(); - } catch (ClassNotFoundException e) { - throw new IOException(StringUtils.toString("Read object failed.", e)); - } - } - protected Object decodeRequestData(ObjectInput in) throws IOException { try { return in.readObject(); @@ -372,20 +335,15 @@ protected Object decodeResponseData(ObjectInput in) throws IOException { throw new IOException(StringUtils.toString("Read object failed.", e)); } } - + @Override protected void encodeData(ObjectOutput out, Object data) throws IOException { encodeRequestData(out, data); } - + private void encodeEventData(ObjectOutput out, Object data) throws IOException { out.writeObject(data); } - - @Deprecated - protected void encodeHeartbeatData(ObjectOutput out, Object data) throws IOException { - encodeEventData(out, data); - } protected void encodeRequestData(ObjectOutput out, Object data) throws IOException { out.writeObject(data); @@ -394,22 +352,13 @@ protected void encodeRequestData(ObjectOutput out, Object data) throws IOExcepti protected void encodeResponseData(ObjectOutput out, Object data) throws IOException { out.writeObject(data); } - + @Override protected Object decodeData(Channel channel, ObjectInput in) throws IOException { - return decodeRequestData(channel ,in); - } - - protected Object decodeEventData(Channel channel, ObjectInput in) throws IOException { - try { - return in.readObject(); - } catch (ClassNotFoundException e) { - throw new IOException(StringUtils.toString("Read object failed.", e)); - } + return decodeRequestData(channel, in); } - @Deprecated - protected Object decodeHeartbeatData(Channel channel, ObjectInput in) throws IOException { + protected Object decodeEventData(Channel channel, ObjectInput in) throws IOException { try { return in.readObject(); } catch (ClassNotFoundException e) { @@ -425,10 +374,6 @@ protected Object decodeResponseData(Channel channel, ObjectInput in) throws IOEx return decodeResponseData(in); } - protected Object decodeResponseData(Channel channel, ObjectInput in, Object requestData) throws IOException { - return decodeResponseData(channel, in); - } - @Override protected void encodeData(Channel channel, ObjectOutput out, Object data) throws IOException { encodeRequestData(channel, out, data); @@ -437,10 +382,6 @@ protected void encodeData(Channel channel, ObjectOutput out, Object data) throws private void encodeEventData(Channel channel, ObjectOutput out, Object data) throws IOException { encodeEventData(out, data); } - @Deprecated - protected void encodeHeartbeatData(Channel channel, ObjectOutput out, Object data) throws IOException { - encodeHeartbeatData(out, data); - } protected void encodeRequestData(Channel channel, ObjectOutput out, Object data) throws IOException { encodeRequestData(out, data); diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/DefaultFuture.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/DefaultFuture.java deleted file mode 100644 index d1bc6e4f724..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/DefaultFuture.java +++ /dev/null @@ -1,314 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting.exchange.support; - -import java.text.SimpleDateFormat; -import java.util.Date; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.TimeUnit; -import java.util.concurrent.locks.Condition; -import java.util.concurrent.locks.Lock; -import java.util.concurrent.locks.ReentrantLock; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.TimeoutException; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.remoting.exchange.ResponseCallback; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; - -/** - * DefaultFuture. - * - * @author qian.lei - * @author chao.liuc - */ -public class DefaultFuture implements ResponseFuture { - - private static final Logger logger = LoggerFactory.getLogger(DefaultFuture.class); - - private static final Map CHANNELS = new ConcurrentHashMap(); - - private static final Map FUTURES = new ConcurrentHashMap(); - - // invoke id. - private final long id; - - private final Channel channel; - - private final Request request; - - private final int timeout; - - private final Lock lock = new ReentrantLock(); - - private final Condition done = lock.newCondition(); - - private final long start = System.currentTimeMillis(); - - private volatile long sent; - - private volatile Response response; - - private volatile ResponseCallback callback; - - public DefaultFuture(Channel channel, Request request, int timeout){ - this.channel = channel; - this.request = request; - this.id = request.getId(); - this.timeout = timeout > 0 ? timeout : channel.getUrl().getPositiveParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); - // put into waiting map. - FUTURES.put(id, this); - CHANNELS.put(id, channel); - } - - public Object get() throws RemotingException { - return get(timeout); - } - - public Object get(int timeout) throws RemotingException { - if (timeout <= 0) { - timeout = Constants.DEFAULT_TIMEOUT; - } - if (! isDone()) { - long start = System.currentTimeMillis(); - lock.lock(); - try { - while (! isDone()) { - done.await(timeout, TimeUnit.MILLISECONDS); - if (isDone() || System.currentTimeMillis() - start > timeout) { - break; - } - } - } catch (InterruptedException e) { - throw new RuntimeException(e); - } finally { - lock.unlock(); - } - if (! isDone()) { - throw new TimeoutException(sent > 0, channel, getTimeoutMessage(false)); - } - } - return returnFromResponse(); - } - - public void cancel(){ - Response errorResult = new Response(id); - errorResult.setErrorMessage("request future has been canceled."); - response = errorResult ; - FUTURES.remove(id); - CHANNELS.remove(id); - } - - public boolean isDone() { - return response != null; - } - - public void setCallback(ResponseCallback callback) { - if (isDone()) { - invokeCallback(callback); - } else { - boolean isdone = false; - lock.lock(); - try{ - if (!isDone()) { - this.callback = callback; - } else { - isdone = true; - } - }finally { - lock.unlock(); - } - if (isdone){ - invokeCallback(callback); - } - } - } - private void invokeCallback(ResponseCallback c){ - ResponseCallback callbackCopy = c; - if (callbackCopy == null){ - throw new NullPointerException("callback cannot be null."); - } - c = null; - Response res = response; - if (res == null) { - throw new IllegalStateException("response cannot be null. url:"+channel.getUrl()); - } - - if (res.getStatus() == Response.OK) { - try { - callbackCopy.done(res.getResult()); - } catch (Exception e) { - logger.error("callback invoke error .reasult:" + res.getResult() + ",url:" + channel.getUrl(), e); - } - } else if (res.getStatus() == Response.CLIENT_TIMEOUT || res.getStatus() == Response.SERVER_TIMEOUT) { - try { - TimeoutException te = new TimeoutException(res.getStatus() == Response.SERVER_TIMEOUT, channel, res.getErrorMessage()); - callbackCopy.caught(te); - } catch (Exception e) { - logger.error("callback invoke error ,url:" + channel.getUrl(), e); - } - } else { - try { - RuntimeException re = new RuntimeException(res.getErrorMessage()); - callbackCopy.caught(re); - } catch (Exception e) { - logger.error("callback invoke error ,url:" + channel.getUrl(), e); - } - } - } - - private Object returnFromResponse() throws RemotingException { - Response res = response; - if (res == null) { - throw new IllegalStateException("response cannot be null"); - } - if (res.getStatus() == Response.OK) { - return res.getResult(); - } - if (res.getStatus() == Response.CLIENT_TIMEOUT || res.getStatus() == Response.SERVER_TIMEOUT) { - throw new TimeoutException(res.getStatus() == Response.SERVER_TIMEOUT, channel, res.getErrorMessage()); - } - throw new RemotingException(channel, res.getErrorMessage()); - } - - private long getId() { - return id; - } - - private Channel getChannel() { - return channel; - } - - private boolean isSent() { - return sent > 0; - } - - public Request getRequest() { - return request; - } - - private int getTimeout() { - return timeout; - } - - private long getStartTimestamp() { - return start; - } - - public static DefaultFuture getFuture(long id) { - return FUTURES.get(id); - } - - public static boolean hasFuture(Channel channel) { - return CHANNELS.containsValue(channel); - } - - public static void sent(Channel channel, Request request) { - DefaultFuture future = FUTURES.get(request.getId()); - if (future != null) { - future.doSent(); - } - } - - private void doSent() { - sent = System.currentTimeMillis(); - } - - public static void received(Channel channel, Response response) { - try { - DefaultFuture future = FUTURES.remove(response.getId()); - if (future != null) { - future.doReceived(response); - } else { - logger.warn("The timeout response finally returned at " - + (new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS").format(new Date())) - + ", response " + response - + (channel == null ? "" : ", channel: " + channel.getLocalAddress() - + " -> " + channel.getRemoteAddress())); - } - } finally { - CHANNELS.remove(response.getId()); - } - } - - private void doReceived(Response res) { - lock.lock(); - try { - response = res; - if (done != null) { - done.signal(); - } - } finally { - lock.unlock(); - } - if (callback != null) { - invokeCallback(callback); - } - } - - private String getTimeoutMessage(boolean scan) { - long nowTimestamp = System.currentTimeMillis(); - return (sent > 0 ? "Waiting server-side response timeout" : "Sending request timeout in client-side") - + (scan ? " by scan timer" : "") + ". start time: " - + (new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS").format(new Date(start))) + ", end time: " - + (new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS").format(new Date())) + "," - + (sent > 0 ? " client elapsed: " + (sent - start) - + " ms, server elapsed: " + (nowTimestamp - sent) - : " elapsed: " + (nowTimestamp - start)) + " ms, timeout: " - + timeout + " ms, request: " + request + ", channel: " + channel.getLocalAddress() - + " -> " + channel.getRemoteAddress(); - } - - private static class RemotingInvocationTimeoutScan implements Runnable { - - public void run() { - while (true) { - try { - for (DefaultFuture future : FUTURES.values()) { - if (future == null || future.isDone()) { - continue; - } - if (System.currentTimeMillis() - future.getStartTimestamp() > future.getTimeout()) { - // create exception response. - Response timeoutResponse = new Response(future.getId()); - // set timeout status. - timeoutResponse.setStatus(future.isSent() ? Response.SERVER_TIMEOUT : Response.CLIENT_TIMEOUT); - timeoutResponse.setErrorMessage(future.getTimeoutMessage(true)); - // handle response. - DefaultFuture.received(future.getChannel(), timeoutResponse); - } - } - Thread.sleep(30); - } catch (Throwable e) { - logger.error("Exception when scan the timeout invocation of remoting.", e); - } - } - } - } - - static { - Thread th = new Thread(new RemotingInvocationTimeoutScan(), "DubboResponseTimeoutScanTimer"); - th.setDaemon(true); - th.start(); - } - -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeHandlerAdapter.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeHandlerAdapter.java index 378d7fbb6fd..0c9cc135977 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeHandlerAdapter.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeHandlerAdapter.java @@ -15,7 +15,7 @@ */ package com.alibaba.dubbo.remoting.exchange.support; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; import com.alibaba.dubbo.remoting.telnet.support.TelnetHandlerAdapter; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeHandlerDispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeHandlerDispatcher.java index 895b1904a6b..b6b214f6e86 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeHandlerDispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeHandlerDispatcher.java @@ -15,9 +15,9 @@ */ package com.alibaba.dubbo.remoting.exchange.support; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeServerDelegate.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeServerDelegate.java index b15efcd8f32..8893df5407a 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeServerDelegate.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ExchangeServerDelegate.java @@ -19,9 +19,9 @@ import java.util.Collection; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/Replier.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/Replier.java index 01a3c95cd00..995009c3865 100755 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/Replier.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/Replier.java @@ -15,7 +15,7 @@ */ package com.alibaba.dubbo.remoting.exchange.support; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ReplierDispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ReplierDispatcher.java index 8a7ff7c521b..68dd9bbf132 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ReplierDispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/ReplierDispatcher.java @@ -18,7 +18,7 @@ import java.util.Map; import java.util.concurrent.ConcurrentHashMap; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/SimpleFuture.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/SimpleFuture.java deleted file mode 100644 index c09a0f04c7a..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/SimpleFuture.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting.exchange.support; - -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.ResponseCallback; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; - -/** - * SimpleFuture - * - * @author william.liangf - */ -public class SimpleFuture implements ResponseFuture { - - private final Object value; - - public SimpleFuture(Object value){ - this.value = value; - } - - public Object get() throws RemotingException { - return value; - } - - public Object get(int timeoutInMillis) throws RemotingException { - return value; - } - - public void setCallback(ResponseCallback callback) { - callback.done(value); - } - - public boolean isDone() { - return true; - } - -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeChannel.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeChannel.java index aa8341b72b4..fe2a920b451 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeChannel.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeChannel.java @@ -15,42 +15,46 @@ */ package com.alibaba.dubbo.remoting.exchange.support.header; -import java.net.InetSocketAddress; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.exception.TimeoutException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; -import com.alibaba.dubbo.remoting.exchange.support.DefaultFuture; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; + +import java.net.InetSocketAddress; +import java.util.concurrent.TimeUnit; /** * ExchangeReceiver - * + * * @author william.liangf */ final class HeaderExchangeChannel implements ExchangeChannel { - private static final Logger logger = LoggerFactory.getLogger(HeaderExchangeChannel.class); + private static final Logger logger = LoggerFactory.getLogger(HeaderExchangeChannel.class); private static final String CHANNEL_KEY = HeaderExchangeChannel.class.getName() + ".CHANNEL"; - private final Channel channel; + private final ReplyManager replyManager = ReplyManager.get(); + + private final Channel channel; - private volatile boolean closed = false; + private volatile boolean closed = false; - HeaderExchangeChannel(Channel channel){ + HeaderExchangeChannel(Channel channel) { if (channel == null) { throw new IllegalArgumentException("channel == null"); } this.channel = channel; + replyManager.initReplyCounter(channel); } static HeaderExchangeChannel getOrAddChannel(Channel ch) { @@ -66,55 +70,75 @@ static HeaderExchangeChannel getOrAddChannel(Channel ch) { } return ret; } - + static void removeChannelIfDisconnected(Channel ch) { - if (ch != null && ! ch.isConnected()) { + if (ch != null && !ch.isConnected()) { ch.removeAttribute(CHANNEL_KEY); } } - + public void send(Object message) throws RemotingException { send(message, getUrl().getParameter(Constants.SENT_KEY, false)); } - + public void send(Object message, boolean sent) throws RemotingException { if (closed) { - throw new RemotingException(this.getLocalAddress(), null, "Failed to send message " + message + ", cause: The channel " + this + " is closed!"); + throw new RemotingException(this.getLocalAddress(), null, "Failed to send message " + message + + ", cause: The channel " + this + " is closed!"); } if (message instanceof Request || message instanceof Response || message instanceof String) { channel.send(message, sent); } else { - Request request = new Request(); - request.setVersion("2.0.0"); - request.setTwoWay(false); - request.setData(message); + Request.Builder builder = new Request.Builder(); + builder.newId().version(Version.getVersion()).twoWay(false).data(message); + Request request = builder.build(); channel.send(request, sent); } } - public ResponseFuture request(Object request) throws RemotingException { + @Override + public Response request(Request request) throws RemotingException { return request(request, channel.getUrl().getPositiveParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT)); } - public ResponseFuture request(Object request, int timeout) throws RemotingException { + @Override + public Response request(Request request, int timeout) throws RemotingException { if (closed) { - throw new RemotingException(this.getLocalAddress(), null, "Failed to send request " + request + ", cause: The channel " + this + " is closed!"); + throw new RemotingException(this.getLocalAddress(), null, "Failed to send request " + request + + ", cause: The channel " + this + " is closed!"); } - // create request. - Request req = new Request(); - req.setVersion("2.0.0"); - req.setTwoWay(true); - req.setData(request); - DefaultFuture future = new DefaultFuture(channel, req, timeout); - try{ - channel.send(req); - }catch (RemotingException e) { - future.cancel(); + PendingReply pendingReply = new PendingReply(); + pendingReply.setMessageId(request.getId()); + replyManager.addPendingReply(request.getId(), pendingReply, channel); + long startTimeMs = System.currentTimeMillis(); + try { + channel.send(request); + } catch (RemotingException e) { + replyManager.removePendingReply(pendingReply, channel); throw e; } - return future; + Response response = null; + try { + response = pendingReply.get(timeout, TimeUnit.MILLISECONDS); + } catch (InterruptedException e) { + throw new RemotingException(this, e); + } finally { + replyManager.removePendingReply(pendingReply, channel); + } + // timeout + if (response == null) { + throw new TimeoutException(channel, getTimeoutMessage(request, timeout, startTimeMs)); + } + return response; + } + + public String getTimeoutMessage(Request request, int timeout, long startTimeMs) { + long nowTimestamp = System.currentTimeMillis(); + return "elapsed: " + (nowTimestamp - startTimeMs) + " ms, timeout: " + + timeout + " ms, request: " + request + ", channel: " + channel.getLocalAddress() + + " -> " + channel.getRemoteAddress(); } public boolean isClosed() { @@ -126,10 +150,12 @@ public void close() { channel.close(); } catch (Throwable e) { logger.warn(e.getMessage(), e); + } finally { + replyManager.destroyReplyCounter(channel); } } - // graceful close + // gracefully close public void close(int timeout) { if (closed) { return; @@ -137,8 +163,7 @@ public void close(int timeout) { closed = true; if (timeout > 0) { long start = System.currentTimeMillis(); - while (DefaultFuture.hasFuture(HeaderExchangeChannel.this) - && System.currentTimeMillis() - start < timeout) { + while (shouldWait(start, timeout)) { try { Thread.sleep(10); } catch (InterruptedException e) { @@ -149,6 +174,11 @@ public void close(int timeout) { close(); } + private boolean shouldWait(long start, long timeout) { + return System.currentTimeMillis() - start <= timeout && + replyManager.isChannelHoldingReplies(channel); + } + public InetSocketAddress getLocalAddress() { return channel.getLocalAddress(); } @@ -172,7 +202,7 @@ public ChannelHandler getChannelHandler() { public ExchangeHandler getExchangeHandler() { return (ExchangeHandler) channel.getChannelHandler(); } - + public Object getAttribute(String key) { return channel.getAttribute(key); } @@ -193,7 +223,7 @@ public boolean hasAttribute(String key) { public int hashCode() { final int prime = 31; int result = 1; - result = prime * result + ((channel == null) ? 0 : channel.hashCode()); + result = prime * result + (channel.hashCode()); return result; } @@ -203,10 +233,7 @@ public boolean equals(Object obj) { if (obj == null) return false; if (getClass() != obj.getClass()) return false; HeaderExchangeChannel other = (HeaderExchangeChannel) obj; - if (channel == null) { - if (other.channel != null) return false; - } else if (!channel.equals(other.channel)) return false; - return true; + return channel.equals(other.channel); } @Override diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeClient.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeClient.java index b1e7f167121..77017360b2c 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeClient.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeClient.java @@ -15,68 +15,71 @@ */ package com.alibaba.dubbo.remoting.exchange.support.header; -import java.net.InetSocketAddress; -import java.util.Collection; -import java.util.Collections; -import java.util.concurrent.ScheduledFuture; -import java.util.concurrent.ScheduledThreadPoolExecutor; -import java.util.concurrent.TimeUnit; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.NamedThreadFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; +import com.alibaba.dubbo.remoting.message.Interceptor; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Client; + +import java.net.InetSocketAddress; +import java.util.ArrayList; +import java.util.Collection; +import java.util.Collections; +import java.util.List; +import java.util.concurrent.ScheduledFuture; +import java.util.concurrent.ScheduledThreadPoolExecutor; +import java.util.concurrent.TimeUnit; /** * DefaultMessageClient - * + * * @author william.liangf * @author chao.liuc */ public class HeaderExchangeClient implements ExchangeClient { - private static final Logger logger = LoggerFactory.getLogger( HeaderExchangeClient.class ); + private static final Logger logger = LoggerFactory.getLogger(HeaderExchangeClient.class); - private static final ScheduledThreadPoolExecutor scheduled = new ScheduledThreadPoolExecutor(2, new NamedThreadFactory("dubbo-remoting-client-heartbeat", true)); + private static final ScheduledThreadPoolExecutor scheduled = new ScheduledThreadPoolExecutor(2, + new NamedThreadFactory("dubbo-remoting-client-heartbeat", true)); // 心跳定时器 - private ScheduledFuture heatbeatTimer; + private ScheduledFuture heartbeatTimer; // 心跳超时,毫秒。缺省0,不会执行心跳。 - private int heartbeat; + private final int heartbeat; + + private final int heartbeatTimeout; - private int heartbeatTimeout; - private final Client client; private final ExchangeChannel channel; - public HeaderExchangeClient(Client client){ + private final List interceptors = new ArrayList(); + + public HeaderExchangeClient(Client client) { if (client == null) { throw new IllegalArgumentException("client == null"); } this.client = client; this.channel = new HeaderExchangeChannel(client); String dubbo = client.getUrl().getParameter(Constants.DUBBO_VERSION_KEY); - this.heartbeat = client.getUrl().getParameter( Constants.HEARTBEAT_KEY, dubbo != null && dubbo.startsWith("1.0.") ? Constants.DEFAULT_HEARTBEAT : 0 ); - this.heartbeatTimeout = client.getUrl().getParameter( Constants.HEARTBEAT_TIMEOUT_KEY, heartbeat * 3 ); - if ( heartbeatTimeout < heartbeat * 2 ) { - throw new IllegalStateException( "heartbeatTimeout < heartbeatInterval * 2" ); + this.heartbeat = client.getUrl().getParameter(Constants.HEARTBEAT_KEY, dubbo != null && dubbo.startsWith("1.0.") ? Constants.DEFAULT_HEARTBEAT : 0); + this.heartbeatTimeout = client.getUrl().getParameter(Constants.HEARTBEAT_TIMEOUT_KEY, heartbeat * 3); + if (heartbeatTimeout < heartbeat * 2) { + throw new IllegalStateException("heartbeatTimeout < heartbeatInterval * 2"); } - startHeatbeatTimer(); - } - - public ResponseFuture request(Object request) throws RemotingException { - return channel.request(request); + startHeartbeatTimer(); } public URL getUrl() { @@ -87,10 +90,6 @@ public InetSocketAddress getRemoteAddress() { return channel.getRemoteAddress(); } - public ResponseFuture request(Object request, int timeout) throws RemotingException { - return channel.request(request, timeout); - } - public ChannelHandler getChannelHandler() { return channel.getChannelHandler(); } @@ -106,11 +105,11 @@ public InetSocketAddress getLocalAddress() { public ExchangeHandler getExchangeHandler() { return channel.getExchangeHandler(); } - + public void send(Object message) throws RemotingException { channel.send(message); } - + public void send(Object message, boolean sent) throws RemotingException { channel.send(message, sent); } @@ -132,9 +131,9 @@ public void close(int timeout) { public void reset(URL url) { client.reset(url); } - + @Deprecated - public void reset(com.alibaba.dubbo.common.Parameters parameters){ + public void reset(com.alibaba.dubbo.common.Parameters parameters) { reset(getUrl().addParameters(parameters.getParameters())); } @@ -158,39 +157,102 @@ public boolean hasAttribute(String key) { return channel.hasAttribute(key); } - private void startHeatbeatTimer() { + private void startHeartbeatTimer() { stopHeartbeatTimer(); - if ( heartbeat > 0 ) { - heatbeatTimer = scheduled.scheduleWithFixedDelay( - new HeartBeatTask( new HeartBeatTask.ChannelProvider() { + if (heartbeat > 0) { + heartbeatTimer = scheduled.scheduleWithFixedDelay( + new HeartBeatTask(new HeartBeatTask.ChannelProvider() { public Collection getChannels() { - return Collections.singletonList( HeaderExchangeClient.this ); + return Collections.singletonList(HeaderExchangeClient.this); } }, heartbeat, heartbeatTimeout), - heartbeat, heartbeat, TimeUnit.MILLISECONDS ); + heartbeat, heartbeat, TimeUnit.MILLISECONDS); } } private void stopHeartbeatTimer() { - if (heatbeatTimer != null && ! heatbeatTimer.isCancelled()) { + if (heartbeatTimer != null && !heartbeatTimer.isCancelled()) { try { - heatbeatTimer.cancel(true); + heartbeatTimer.cancel(true); scheduled.purge(); - } catch ( Throwable e ) { + } catch (Throwable e) { if (logger.isWarnEnabled()) { logger.warn(e.getMessage(), e); } } } - heatbeatTimer =null; + heartbeatTimer = null; + } + + @Override + public Response request(Request request) throws RemotingException { + return request(request, channel.getUrl().getPositiveParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT)); + } + + @Override + public Response request(Request request, int timeout) throws RemotingException { + Interceptor.Chain chain = new ExchangeClientInterceptorChain(0, request, timeout); + return chain.proceed(request, timeout); + } + + public void addInterceptor(Interceptor interceptor) { + this.interceptors.add(interceptor); + } + + /** + * @author Xs request interceptor + */ + class ExchangeClientInterceptorChain implements Interceptor.Chain { + + private final int index; + + private final Request request; + + private final int timeout; + + ExchangeClientInterceptorChain(int index, Request request, int timeout) { + this.index = index; + this.request = request; + this.timeout = timeout; + } + + @Override + public Request request() { + return request; + } + + @Override + public int timeout() { + return timeout; + } + + @Override + public Response proceed(Request request, int timeout) throws RemotingException { + if (index < interceptors.size()) { + Interceptor.Chain chain = new ExchangeClientInterceptorChain(index + 1, request, timeout); + Interceptor interceptor = interceptors.get(index); + Response response = interceptor.intercept(chain); + if (response == null) { + throw new NullPointerException("interceptor " + interceptor + " returned null"); + } + return response; + } + return channel.request(request, timeout); + } + + @Override + public Response proceed(Request request) { + throw new UnsupportedOperationException("This is server side method"); + } } + private void doClose() { stopHeartbeatTimer(); } - @Override - public String toString() { - return "HeaderExchangeClient [channel=" + channel + "]"; - } + @Override + public String toString() { + return "HeaderExchangeClient [channel=" + channel + "]"; + } } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeHandler.java index d47d46881f4..005d2532465 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeHandler.java @@ -15,85 +15,91 @@ */ package com.alibaba.dubbo.remoting.exchange.support.header; -import java.net.InetSocketAddress; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.NetUtils; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.ExecutionException; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.ExecutionException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.remoting.exchange.support.DefaultFuture; +import com.alibaba.dubbo.remoting.message.Interceptor; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.transport.ChannelHandlerDelegate; +import java.net.InetSocketAddress; +import java.util.ArrayList; +import java.util.List; + /** * ExchangeReceiver - * + * * @author william.liangf * @author chao.liuc */ public class HeaderExchangeHandler implements ChannelHandlerDelegate { - protected static final Logger logger = LoggerFactory.getLogger(HeaderExchangeHandler.class); + protected static final Logger logger = LoggerFactory.getLogger(HeaderExchangeHandler.class); - public static String KEY_READ_TIMESTAMP = HeartbeatHandler.KEY_READ_TIMESTAMP; + public static String KEY_READ_TIMESTAMP = HeartbeatHandler.KEY_READ_TIMESTAMP; - public static String KEY_WRITE_TIMESTAMP = HeartbeatHandler.KEY_WRITE_TIMESTAMP; + public static String KEY_WRITE_TIMESTAMP = HeartbeatHandler.KEY_WRITE_TIMESTAMP; + + private final List interceptors = new ArrayList(); private final ExchangeHandler handler; - public HeaderExchangeHandler(ExchangeHandler handler){ + private final ReplyManager replyManager = ReplyManager.get(); + + public HeaderExchangeHandler(ExchangeHandler handler) { if (handler == null) { throw new IllegalArgumentException("handler == null"); } this.handler = handler; } - void handlerEvent(Channel channel, Request req) throws RemotingException { + private void handlerEvent(Channel channel, Request req) throws RemotingException { if (req.getData() != null && req.getData().equals(Request.READONLY_EVENT)) { channel.setAttribute(Constants.CHANNEL_ATTRIBUTE_READONLY_KEY, Boolean.TRUE); } } - Response handleRequest(ExchangeChannel channel, Request req) throws RemotingException { - Response res = new Response(req.getId(), req.getVersion()); + private Response handleRequest(ExchangeChannel channel, Request req) throws RemotingException { + Response.Builder builder = new Response.Builder(req.getId()); + builder.version(req.getVersion()); if (req.isBroken()) { Object data = req.getData(); - String msg; if (data == null) msg = null; else if (data instanceof Throwable) msg = StringUtils.toString((Throwable) data); else msg = data.toString(); - res.setErrorMessage("Fail to decode request due to: " + msg); - res.setStatus(Response.BAD_REQUEST); - - return res; + builder.errorMsg("Fail to decode request due to: " + msg); + builder.status(Response.BAD_REQUEST); + return builder.build(); } // find handler by message class. Object msg = req.getData(); try { // handle data. Object result = handler.reply(channel, msg); - res.setStatus(Response.OK); - res.setResult(result); + builder.status(Response.OK).result(result); } catch (Throwable e) { - res.setStatus(Response.SERVICE_ERROR); - res.setErrorMessage(StringUtils.toString(e)); + builder.status(Response.SERVICE_ERROR).errorMsg(StringUtils.toString(e)); } - return res; + return builder.build(); } - static void handleResponse(Channel channel, Response response) throws RemotingException { + private void handleResponse(Response response) throws RemotingException { if (response != null && !response.isHeartbeat()) { - DefaultFuture.received(channel, response); + PendingReply pendingReply = replyManager.getPendingReply(response.getId()); + if (pendingReply != null) { + pendingReply.reply(response); + } } } @@ -132,10 +138,6 @@ public void sent(Channel channel, Object message) throws RemotingException { } catch (Throwable t) { exception = t; } - if (message instanceof Request) { - Request request = (Request) message; - DefaultFuture.sent(channel, request); - } if (exception != null) { if (exception instanceof RuntimeException) { throw (RuntimeException) exception; @@ -143,7 +145,7 @@ public void sent(Channel channel, Object message) throws RemotingException { throw (RemotingException) exception; } else { throw new RemotingException(channel.getLocalAddress(), channel.getRemoteAddress(), - exception.getMessage(), exception); + exception.getMessage(), exception); } } } @@ -151,9 +153,9 @@ public void sent(Channel channel, Object message) throws RemotingException { private static boolean isClientSide(Channel channel) { InetSocketAddress address = channel.getRemoteAddress(); URL url = channel.getUrl(); - return url.getPort() == address.getPort() && - NetUtils.filterLocalHost(url.getIp()) - .equals(NetUtils.filterLocalHost(address.getAddress().getHostAddress())); + return url.getPort() == address.getPort() && + NetUtils.filterLocalHost(url.getIp()) + .equals(NetUtils.filterLocalHost(address.getAddress().getHostAddress())); } public void received(Channel channel, Object message) throws RemotingException { @@ -161,23 +163,24 @@ public void received(Channel channel, Object message) throws RemotingException { ExchangeChannel exchangeChannel = HeaderExchangeChannel.getOrAddChannel(channel); try { if (message instanceof Request) { - // handle request. Request request = (Request) message; if (request.isEvent()) { handlerEvent(channel, request); } else { if (request.isTwoWay()) { - Response response = handleRequest(exchangeChannel, request); + Interceptor.Chain chain = new ExchangeHandlerChain(0, exchangeChannel, request); + Response response = chain.proceed(request); channel.send(response); } else { handler.received(exchangeChannel, request.getData()); } } } else if (message instanceof Response) { - handleResponse(channel, (Response) message); + handleResponse((Response) message); } else if (message instanceof String) { if (isClientSide(channel)) { - Exception e = new Exception("Dubbo client can not supported string message: " + message + " in channel: " + channel + ", url: " + channel.getUrl()); + Exception e = new Exception("Dubbo client can not supported string message: " + + message + " in channel: " + channel + ", url: " + channel.getUrl()); logger.error(e.getMessage(), e); } else { String echo = handler.telnet(channel, (String) message); @@ -193,17 +196,61 @@ public void received(Channel channel, Object message) throws RemotingException { } } + public void addInterceptor(Interceptor interceptor) { + interceptors.add(interceptor); + } + + class ExchangeHandlerChain implements Interceptor.Chain { + private final int index; + private final ExchangeChannel exchangeChannel; + private final Request request; + + public ExchangeHandlerChain(int index, ExchangeChannel exchangeChannel, Request request) { + this.index = index; + this.exchangeChannel = exchangeChannel; + this.request = request; + } + + @Override + public Request request() { + return request; + } + + @Override + public int timeout() { + return 0; + } + + @Override + public Response proceed(Request request, int timeout) throws RemotingException { + throw new UnsupportedOperationException("This is client side method"); + } + + @Override + public Response proceed(Request request) throws RemotingException { + if (index < interceptors.size()) { + Interceptor.Chain chain = new ExchangeHandlerChain(index + 1, exchangeChannel, request); + Interceptor interceptor = interceptors.get(index); + Response response = interceptor.intercept(chain); + if (response == null) { + throw new NullPointerException("interceptor " + interceptor + " returned null"); + } + return response; + } + return handleRequest(exchangeChannel, request); + } + } + public void caught(Channel channel, Throwable exception) throws RemotingException { if (exception instanceof ExecutionException) { ExecutionException e = (ExecutionException) exception; Object msg = e.getRequest(); if (msg instanceof Request) { Request req = (Request) msg; - if (req.isTwoWay() && ! req.isHeartbeat()) { - Response res = new Response(req.getId(), req.getVersion()); - res.setStatus(Response.SERVER_ERROR); - res.setErrorMessage(StringUtils.toString(e)); - channel.send(res); + if (req.isTwoWay() && !req.isHeartbeat()) { + Response.Builder builder = new Response.Builder(req.getId()); + builder.version(req.getVersion()).status(Response.SERVER_ERROR).errorMsg(StringUtils.toString(e)); + channel.send(builder.build()); return; } } diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeServer.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeServer.java index 08a32fd6ec7..b4173480048 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeServer.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchangeServer.java @@ -15,54 +15,55 @@ */ package com.alibaba.dubbo.remoting.exchange.support.header; -import java.net.InetSocketAddress; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.concurrent.Executors; -import java.util.concurrent.ScheduledExecutorService; -import java.util.concurrent.ScheduledFuture; -import java.util.concurrent.TimeUnit; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.NamedThreadFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.support.DefaultFuture; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Server; + +import java.net.InetSocketAddress; +import java.util.ArrayList; +import java.util.Collection; +import java.util.Collections; +import java.util.concurrent.Executors; +import java.util.concurrent.ScheduledExecutorService; +import java.util.concurrent.ScheduledFuture; +import java.util.concurrent.TimeUnit; /** * ExchangeServerImpl - * + * * @author william.liangf */ public class HeaderExchangeServer implements ExchangeServer { - - protected final Logger logger = LoggerFactory.getLogger(getClass()); - private final ScheduledExecutorService scheduled = Executors.newScheduledThreadPool(1, - new NamedThreadFactory( - "dubbo-remoting-server-heartbeat", - true)); + protected final Logger logger = LoggerFactory.getLogger(getClass()); + + private final ScheduledExecutorService scheduled = Executors.newScheduledThreadPool(1, + new NamedThreadFactory( + "dubbo-remoting-server-heartbeat", + true)); // 心跳定时器 - private ScheduledFuture heatbeatTimer; + private ScheduledFuture heartbeatTimer; // 心跳超时,毫秒。缺省0,不会执行心跳。 - private int heartbeat; + private int heartbeat; + + private int heartbeatTimeout; - private int heartbeatTimeout; - private final Server server; + private final ReplyManager replyManager = ReplyManager.get(); + private volatile boolean closed = false; public HeaderExchangeServer(Server server) { @@ -75,9 +76,9 @@ public HeaderExchangeServer(Server server) { if (heartbeatTimeout < heartbeat * 2) { throw new IllegalStateException("heartbeatTimeout < heartbeatInterval * 2"); } - startHeatbeatTimer(); + startHeartbeatTimer(); } - + public Server getServer() { return server; } @@ -89,7 +90,7 @@ public boolean isClosed() { private boolean isRunning() { Collection channels = getChannels(); for (Channel channel : channels) { - if (DefaultFuture.hasFuture(channel)) { + if (replyManager.isChannelHoldingReplies(channel)) { return true; } } @@ -105,10 +106,10 @@ public void close(final int timeout) { if (timeout > 0) { final long max = (long) timeout; final long start = System.currentTimeMillis(); - if (getUrl().getParameter(Constants.CHANNEL_SEND_READONLYEVENT_KEY, false)){ + if (getUrl().getParameter(Constants.CHANNEL_SEND_READONLYEVENT_KEY, false)) { sendChannelReadOnlyEvent(); } - while (HeaderExchangeServer.this.isRunning() + while (HeaderExchangeServer.this.isRunning() && System.currentTimeMillis() - start < max) { try { Thread.sleep(10); @@ -120,23 +121,23 @@ public void close(final int timeout) { doClose(); server.close(timeout); } - - private void sendChannelReadOnlyEvent(){ - Request request = new Request(); - request.setEvent(Request.READONLY_EVENT); - request.setTwoWay(false); - request.setVersion(Version.getVersion()); - + + private void sendChannelReadOnlyEvent() { + Request.Builder builder = new Request.Builder(); + builder.newId().twoWay(false).version(Version.getVersion()).isEvent(true).data(Request.READONLY_EVENT); + Request request = builder.build(); + Collection channels = getChannels(); for (Channel channel : channels) { try { - if (channel.isConnected())channel.send(request, getUrl().getParameter(Constants.CHANNEL_READONLYEVENT_SENT_KEY, true)); + if (channel.isConnected()) + channel.send(request, getUrl().getParameter(Constants.CHANNEL_READONLYEVENT_SENT_KEY, true)); } catch (RemotingException e) { - logger.warn("send connot write messge error.", e); + logger.warn("send cannot write message error.", e); } } } - + private void doClose() { if (closed) { return; @@ -151,7 +152,7 @@ private void doClose() { } public Collection getExchangeChannels() { - Collection exchangeChannels = new ArrayList(); + Collection exchangeChannels = new ArrayList(); Collection channels = server.getChannels(); if (channels != null && channels.size() > 0) { for (Channel channel : channels) { @@ -166,9 +167,9 @@ public ExchangeChannel getExchangeChannel(InetSocketAddress remoteAddress) { return HeaderExchangeChannel.getOrAddChannel(channel); } - @SuppressWarnings({ "unchecked", "rawtypes" }) + @SuppressWarnings({"unchecked", "rawtypes"}) public Collection getChannels() { - return (Collection)getExchangeChannels(); + return (Collection) getExchangeChannels(); } public Channel getChannel(InetSocketAddress remoteAddress) { @@ -204,16 +205,16 @@ public void reset(URL url) { if (h != heartbeat || t != heartbeatTimeout) { heartbeat = h; heartbeatTimeout = t; - startHeatbeatTimer(); + startHeartbeatTimer(); } } } catch (Throwable t) { logger.error(t.getMessage(), t); } } - + @Deprecated - public void reset(com.alibaba.dubbo.common.Parameters parameters){ + public void reset(com.alibaba.dubbo.common.Parameters parameters) { reset(getUrl().addParameters(parameters.getParameters())); } @@ -231,30 +232,30 @@ public void send(Object message, boolean sent) throws RemotingException { server.send(message, sent); } - private void startHeatbeatTimer() { + private void startHeartbeatTimer() { stopHeartbeatTimer(); if (heartbeat > 0) { - heatbeatTimer = scheduled.scheduleWithFixedDelay( - new HeartBeatTask( new HeartBeatTask.ChannelProvider() { + heartbeatTimer = scheduled.scheduleWithFixedDelay( + new HeartBeatTask(new HeartBeatTask.ChannelProvider() { public Collection getChannels() { return Collections.unmodifiableCollection( - HeaderExchangeServer.this.getChannels() ); + HeaderExchangeServer.this.getChannels()); } }, heartbeat, heartbeatTimeout), - heartbeat, heartbeat,TimeUnit.MILLISECONDS); + heartbeat, heartbeat, TimeUnit.MILLISECONDS); } } private void stopHeartbeatTimer() { try { - ScheduledFuture timer = heatbeatTimer; - if (timer != null && ! timer.isCancelled()) { + ScheduledFuture timer = heartbeatTimer; + if (timer != null && !timer.isCancelled()) { timer.cancel(true); } } catch (Throwable t) { logger.warn(t.getMessage(), t); } finally { - heatbeatTimer =null; + heartbeatTimer = null; } } diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchanger.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchanger.java index 786bf2f425b..e3de69482d9 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchanger.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeaderExchanger.java @@ -16,29 +16,51 @@ package com.alibaba.dubbo.remoting.exchange.support.header; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; import com.alibaba.dubbo.remoting.Transporters; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; import com.alibaba.dubbo.remoting.exchange.Exchanger; +import com.alibaba.dubbo.remoting.message.Interceptor; import com.alibaba.dubbo.remoting.transport.DecodeHandler; +import com.alibaba.dubbo.tracker.DubboRequestInterceptorBuilder; +import com.alibaba.dubbo.tracker.DubboRequestSpanNameProvider; /** * DefaultMessenger - * + * * @author william.liangf */ public class HeaderExchanger implements Exchanger { - + public static final String NAME = "header"; + private DubboRequestInterceptorBuilder dubboRequestInterceptorBuilder; + + public void setDubboRequestInterceptorBuilder(DubboRequestInterceptorBuilder dubboRequestInterceptorBuilder) { + this.dubboRequestInterceptorBuilder = dubboRequestInterceptorBuilder; + } + public ExchangeClient connect(URL url, ExchangeHandler handler) throws RemotingException { - return new HeaderExchangeClient(Transporters.connect(url, new DecodeHandler(new HeaderExchangeHandler(handler)))); + HeaderExchangeClient headerExchangeClient = new HeaderExchangeClient(Transporters.connect(url, new DecodeHandler(new HeaderExchangeHandler(handler)))); + if (dubboRequestInterceptorBuilder != null) { + Interceptor interceptor = dubboRequestInterceptorBuilder.build(url, DubboRequestSpanNameProvider.getInstance()); + if (interceptor != null) { + headerExchangeClient.addInterceptor(interceptor); + } + } + return headerExchangeClient; } public ExchangeServer bind(URL url, ExchangeHandler handler) throws RemotingException { - return new HeaderExchangeServer(Transporters.bind(url, new DecodeHandler(new HeaderExchangeHandler(handler)))); + HeaderExchangeHandler exchangeHandler = new HeaderExchangeHandler(handler); + if (dubboRequestInterceptorBuilder != null) { + Interceptor interceptor = dubboRequestInterceptorBuilder.build(url, DubboRequestSpanNameProvider.getInstance()); + if (interceptor != null) { + exchangeHandler.addInterceptor(interceptor); + } + } + return new HeaderExchangeServer(Transporters.bind(url, new DecodeHandler(exchangeHandler))); } - } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartBeatTask.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartBeatTask.java index 3d1445e8c35..14d7cce5b39 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartBeatTask.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartBeatTask.java @@ -16,28 +16,29 @@ package com.alibaba.dubbo.remoting.exchange.support.header; -import java.util.Collection; - +import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.exchange.Request; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.message.Request; + +import java.util.Collection; /** * @author kimi */ final class HeartBeatTask implements Runnable { - private static final Logger logger = LoggerFactory.getLogger( HeartBeatTask.class ); + private static final Logger logger = LoggerFactory.getLogger(HeartBeatTask.class); private ChannelProvider channelProvider; - private int heartbeat; + private int heartbeat; - private int heartbeatTimeout; + private int heartbeatTimeout; - HeartBeatTask( ChannelProvider provider, int heartbeat, int heartbeatTimeout ) { + HeartBeatTask(ChannelProvider provider, int heartbeat, int heartbeatTimeout) { this.channelProvider = provider; this.heartbeat = heartbeat; this.heartbeatTimeout = heartbeatTimeout; @@ -46,46 +47,46 @@ final class HeartBeatTask implements Runnable { public void run() { try { long now = System.currentTimeMillis(); - for ( Channel channel : channelProvider.getChannels() ) { + for (Channel channel : channelProvider.getChannels()) { if (channel.isClosed()) { continue; } try { - Long lastRead = ( Long ) channel.getAttribute( - HeaderExchangeHandler.KEY_READ_TIMESTAMP ); - Long lastWrite = ( Long ) channel.getAttribute( - HeaderExchangeHandler.KEY_WRITE_TIMESTAMP ); - if ( ( lastRead != null && now - lastRead > heartbeat ) - || ( lastWrite != null && now - lastWrite > heartbeat ) ) { - Request req = new Request(); - req.setVersion( "2.0.0" ); - req.setTwoWay( true ); - req.setEvent( Request.HEARTBEAT_EVENT ); - channel.send( req ); - if ( logger.isDebugEnabled() ) { - logger.debug( "Send heartbeat to remote channel " + channel.getRemoteAddress() - + ", cause: The channel has no data-transmission exceeds a heartbeat period: " + heartbeat + "ms" ); + Long lastRead = (Long) channel.getAttribute( + HeaderExchangeHandler.KEY_READ_TIMESTAMP); + Long lastWrite = (Long) channel.getAttribute( + HeaderExchangeHandler.KEY_WRITE_TIMESTAMP); + if ((lastRead != null && now - lastRead > heartbeat) + || (lastWrite != null && now - lastWrite > heartbeat)) { + Request.Builder builder = new Request.Builder(); + builder.newId().version(Version.getVersion()). + twoWay(true).isEvent(true).data(Request.HEARTBEAT_EVENT); + Request request = builder.build(); + channel.send(request); + if (logger.isDebugEnabled()) { + logger.debug("Send heartbeat to remote channel " + channel.getRemoteAddress() + + ", cause: The channel has no data-transmission exceeds a heartbeat period: " + heartbeat + "ms"); } } - if ( lastRead != null && now - lastRead > heartbeatTimeout ) { - logger.warn( "Close channel " + channel - + ", because heartbeat read idle time out: " + heartbeatTimeout + "ms" ); + if (lastRead != null && now - lastRead > heartbeatTimeout) { + logger.warn("Close channel " + channel + + ", because heartbeat read idle time out: " + heartbeatTimeout + "ms"); if (channel instanceof Client) { - try { - ((Client)channel).reconnect(); - }catch (Exception e) { - //do nothing - } + try { + ((Client) channel).reconnect(); + } catch (Exception e) { + //do nothing + } } else { - channel.close(); + channel.close(); } } - } catch ( Throwable t ) { - logger.warn( "Exception when heartbeat to remote channel " + channel.getRemoteAddress(), t ); + } catch (Throwable t) { + logger.warn("Exception when heartbeat to remote channel " + channel.getRemoteAddress(), t); } } - } catch ( Throwable t ) { - logger.warn( "Unhandled exception when heartbeat, cause: " + t.getMessage(), t ); + } catch (Throwable t) { + logger.warn("Unhandled exception when heartbeat, cause: " + t.getMessage(), t); } } diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartbeatHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartbeatHandler.java index c357470d728..0c18f1a21ec 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartbeatHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartbeatHandler.java @@ -19,11 +19,11 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; import com.alibaba.dubbo.remoting.transport.AbstractChannelHandlerDelegate; /** @@ -63,8 +63,10 @@ public void received(Channel channel, Object message) throws RemotingException { if (isHeartbeatRequest(message)) { Request req = (Request) message; if (req.isTwoWay()) { - Response res = new Response(req.getId(), req.getVersion()); - res.setEvent(Response.HEARTBEAT_EVENT); + Response res = new Response.Builder(req.getId()). + version(req.getVersion()). + isEvent(true). + result(Response.HEARTBEAT_EVENT).build(); channel.send(res); if (logger.isInfoEnabled()) { int heartbeat = channel.getUrl().getParameter(Constants.HEARTBEAT_KEY, 0); diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/PendingReply.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/PendingReply.java new file mode 100644 index 00000000000..7bfe276ba56 --- /dev/null +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/PendingReply.java @@ -0,0 +1,38 @@ +package com.alibaba.dubbo.remoting.exchange.support.header; + + +import com.alibaba.dubbo.remoting.message.Response; + +import java.util.concurrent.ArrayBlockingQueue; +import java.util.concurrent.BlockingQueue; +import java.util.concurrent.TimeUnit; + +/** + * @author Xs. + */ +public class PendingReply { + + private volatile Long messageId; + + private final BlockingQueue queue = new ArrayBlockingQueue(1); + + public Long getMessageId() { + return messageId; + } + + public void setMessageId(Long messageId) { + this.messageId = messageId; + } + + public void reply(Response reply) { + this.queue.add(reply); + } + + public Response get(long timeout, TimeUnit unit) throws InterruptedException { + return (timeout <= 0) ? queue.take() : queue.poll(timeout, unit); + } + + public Response get() throws InterruptedException { + return queue.take(); + } +} diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/ReplyManager.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/ReplyManager.java new file mode 100644 index 00000000000..796c75cb107 --- /dev/null +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/exchange/support/header/ReplyManager.java @@ -0,0 +1,99 @@ +package com.alibaba.dubbo.remoting.exchange.support.header; + +import com.alibaba.dubbo.remoting.transport.Channel; + +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.atomic.AtomicInteger; + +public class ReplyManager { + + private static final ReplyManager instance = new ReplyManager(); + + private final Map replyStore = new StrictConcurrentHashMap(); + + private final Map channelReplyCounters = new ConcurrentHashMap(); + + private ReplyManager() { + } + + public static ReplyManager get() { + return instance; + } + + public void initReplyCounter(Channel channel) { + ChannelReplyCounter counter = channelReplyCounters.get(channel); + if (counter == null) { + counter = new ChannelReplyCounter(channel); + channelReplyCounters.put(channel, counter); + } + } + + public void destroyReplyCounter(Channel channel) { + channelReplyCounters.remove(channel); + } + + public void addPendingReply(Long id, PendingReply pendingReply, Channel channel) { + replyStore.put(id, pendingReply); + ChannelReplyCounter counter = channelReplyCounters.get(channel); + if (counter == null) { + throw new IllegalStateException("channelReplyCounter should not be null here"); + } + counter.increment(); + } + + public PendingReply getPendingReply(Long messageId) { + return replyStore.get(messageId); + } + + public void removePendingReply(PendingReply pendingReply, Channel channel) { + replyStore.remove(pendingReply.getMessageId()); + ChannelReplyCounter counter = channelReplyCounters.get(channel); + if (counter == null) { + throw new IllegalStateException("channelReplyCounter should not be null here"); + } + counter.decrement(); + } + + public boolean isChannelHoldingReplies(Channel channel) { + ChannelReplyCounter counter = channelReplyCounters.get(channel); + return counter != null && counter.get() > 0; + } + + private class StrictConcurrentHashMap extends ConcurrentHashMap { + public V put(K key, V value) { + if (contains(key)) { + throw new IllegalArgumentException("contains value for key: " + key); + } + return super.put(key, value); + } + } + + + private class ChannelReplyCounter { + + private final Channel channel; + + private final AtomicInteger counter = new AtomicInteger(0); + + private ChannelReplyCounter(Channel channel) { + this.channel = channel; + } + + public Channel getChannel() { + return channel; + } + + public void increment() { + counter.incrementAndGet(); + } + + public void decrement() { + counter.decrementAndGet(); + } + + public int get() { + return counter.get(); + } + } +} diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/TelnetHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/TelnetHandler.java index da73d398a19..84885e3ef31 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/TelnetHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/TelnetHandler.java @@ -16,8 +16,8 @@ package com.alibaba.dubbo.remoting.telnet; import com.alibaba.dubbo.common.extension.SPI; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * TelnetHandler diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/codec/TelnetCodec.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/codec/TelnetCodec.java index 3cb8ca064d3..a49f671d29c 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/codec/TelnetCodec.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/codec/TelnetCodec.java @@ -15,45 +15,45 @@ */ package com.alibaba.dubbo.remoting.telnet.codec; -import java.io.IOException; -import java.io.UnsupportedEncodingException; -import java.nio.charset.Charset; -import java.util.Arrays; -import java.util.LinkedList; -import java.util.List; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; import com.alibaba.dubbo.remoting.transport.codec.TransportCodec; +import java.io.IOException; +import java.io.UnsupportedEncodingException; +import java.nio.charset.Charset; +import java.util.Arrays; +import java.util.LinkedList; +import java.util.List; + /** * TelnetCodec - * + * * @author heyman * @author william.liangf * @author chao.liuc */ public class TelnetCodec extends TransportCodec { - private static final Logger logger = LoggerFactory.getLogger(TelnetCodec.class); - + private static final Logger logger = LoggerFactory.getLogger(TelnetCodec.class); + private static final String HISTORY_LIST_KEY = "telnet.history.list"; private static final String HISTORY_INDEX_KEY = "telnet.history.index"; - - private static final byte[] UP = new byte[] {27, 91, 65}; - - private static final byte[] DOWN = new byte[] {27, 91, 66}; - private static final List ENTER = Arrays.asList(new Object[] { new byte[] { '\r', '\n' } /* Windows Enter */, new byte[] { '\n' } /* Linux Enter */ }); + private static final byte[] UP = new byte[]{27, 91, 65}; + + private static final byte[] DOWN = new byte[]{27, 91, 66}; + + private static final List ENTER = Arrays.asList(new byte[]{'\r', '\n'} /* Windows Enter */, new byte[]{'\n'} /* Linux Enter */); - private static final List EXIT = Arrays.asList(new Object[] { new byte[] { 3 } /* Windows Ctrl+C */, new byte[] { -1, -12, -1, -3, 6 } /* Linux Ctrl+C */, new byte[] { -1, -19, -1, -3, 6 } /* Linux Pause */ }); + private static final List EXIT = Arrays.asList(new byte[]{3} /* Windows Ctrl+C */, new byte[]{-1, -12, -1, -3, 6} /* Linux Ctrl+C */, new byte[]{-1, -19, -1, -3, 6} /* Linux Pause */); public void encode(Channel channel, ChannelBuffer buffer, Object message) throws IOException { if (message instanceof String) { @@ -66,7 +66,7 @@ public void encode(Channel channel, ChannelBuffer buffer, Object message) throws super.encode(channel, buffer, message); } } - + public Object decode(Channel channel, ChannelBuffer buffer) throws IOException { int readable = buffer.readableBytes(); byte[] message = new byte[readable]; @@ -83,27 +83,27 @@ protected Object decode(Channel channel, ChannelBuffer buffer, int readable, byt if (message == null || message.length == 0) { return DecodeResult.NEED_MORE_INPUT; } - + if (message[message.length - 1] == '\b') { // Windows backspace echo try { boolean doublechar = message.length >= 3 && message[message.length - 3] < 0; // double byte char - channel.send(new String(doublechar ? new byte[] {32, 32, 8, 8} : new byte[] {32, 8}, getCharset(channel).name())); + channel.send(new String(doublechar ? new byte[]{32, 32, 8, 8} : new byte[]{32, 8}, getCharset(channel).name())); } catch (RemotingException e) { throw new IOException(StringUtils.toString(e)); } return DecodeResult.NEED_MORE_INPUT; } - + for (Object command : EXIT) { if (isEquals(message, (byte[]) command)) { if (logger.isInfoEnabled()) { - logger.info(new Exception("Close channel " + channel + " on exit command: " + Arrays.toString((byte[])command))); + logger.info(new Exception("Close channel " + channel + " on exit command: " + Arrays.toString((byte[]) command))); } channel.close(); return null; } } - + boolean up = endsWith(message, UP); boolean down = endsWith(message, DOWN); if (up || down) { @@ -128,19 +128,19 @@ protected Object decode(Channel channel, ChannelBuffer buffer, int readable, byt } } } - if (old == null || ! old.equals(index)) { + if (old == null || !old.equals(index)) { channel.setAttribute(HISTORY_INDEX_KEY, index); String value = history.get(index); if (old != null && old >= 0 && old < history.size()) { String ov = history.get(old); StringBuilder buf = new StringBuilder(); - for (int i = 0; i < ov.length(); i ++) { + for (int i = 0; i < ov.length(); i++) { buf.append("\b"); } - for (int i = 0; i < ov.length(); i ++) { + for (int i = 0; i < ov.length(); i++) { buf.append(" "); } - for (int i = 0; i < ov.length(); i ++) { + for (int i = 0; i < ov.length(); i++) { buf.append("\b"); } value = buf.toString() + value; @@ -179,7 +179,7 @@ protected Object decode(Channel channel, ChannelBuffer buffer, int readable, byt String value = history.get(index); if (value != null) { byte[] b1 = value.getBytes(); - if (message != null && message.length > 0) { + if (message.length > 0) { byte[] b2 = new byte[b1.length + message.length]; System.arraycopy(b1, 0, b2, 0, b1.length); System.arraycopy(message, 0, b2, b1.length, message.length); @@ -190,14 +190,14 @@ protected Object decode(Channel channel, ChannelBuffer buffer, int readable, byt } } String result = toString(message, getCharset(channel)); - if (result != null && result.trim().length() > 0) { + if (result.trim().length() > 0) { if (history == null) { history = new LinkedList(); channel.setAttribute(HISTORY_LIST_KEY, history); } if (history.size() == 0) { history.addLast(result); - } else if (! result.equals(history.getLast())) { + } else if (!result.equals(history.getLast())) { history.remove(result); history.addLast(result); if (history.size() > 10) { @@ -207,7 +207,7 @@ protected Object decode(Channel channel, ChannelBuffer buffer, int readable, byt } return result; } - + private static Charset getCharset(Channel channel) { if (channel != null) { Object attribute = channel.getAttribute(Constants.CHARSET_KEY); @@ -243,15 +243,15 @@ private static Charset getCharset(Channel channel) { private static String toString(byte[] message, Charset charset) throws UnsupportedEncodingException { byte[] copy = new byte[message.length]; int index = 0; - for (int i = 0; i < message.length; i ++) { - byte b = message[i] ; + for (int i = 0; i < message.length; i++) { + byte b = message[i]; if (b == '\b') { // backspace if (index > 0) { - index --; + index--; } if (i > 2 && message[i - 2] < 0) { // double byte char if (index > 0) { - index --; + index--; } } } else if (b == 27) { // escape @@ -262,11 +262,11 @@ private static String toString(byte[] message, Charset charset) throws Unsupport } else if (i < message.length - 2) { i = i + 2; } - } else if (b == -1 && i < message.length - 2 + } else if (b == -1 && i < message.length - 2 && (message[i + 1] == -3 || message[i + 1] == -5)) { // handshake i = i + 2; } else { - copy[index ++] = message[i]; + copy[index++] = message[i]; } } if (index == 0) { @@ -284,7 +284,7 @@ private static boolean endsWith(byte[] message, byte[] command) throws IOExcepti return false; } int offset = message.length - command.length; - for (int i = command.length - 1; i >= 0 ; i --) { + for (int i = command.length - 1; i >= 0; i--) { if (message[offset + i] != command[i]) { return false; } diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/TelnetHandlerAdapter.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/TelnetHandlerAdapter.java index 74b10bb5a6f..9a77de9c5c7 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/TelnetHandlerAdapter.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/TelnetHandlerAdapter.java @@ -17,8 +17,8 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.transport.ChannelHandlerAdapter; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/ClearTelnetHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/ClearTelnetHandler.java index 13772e44648..00f48b87e69 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/ClearTelnetHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/ClearTelnetHandler.java @@ -17,7 +17,7 @@ import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/ExitTelnetHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/ExitTelnetHandler.java index 7b4d328d353..955acb30e6c 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/ExitTelnetHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/ExitTelnetHandler.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.telnet.support.command; import com.alibaba.dubbo.common.extension.Activate; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/HelpTelnetHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/HelpTelnetHandler.java index d122792c049..b88f5ad9709 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/HelpTelnetHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/HelpTelnetHandler.java @@ -20,7 +20,7 @@ import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; import com.alibaba.dubbo.remoting.telnet.support.TelnetUtils; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/LogTelnetHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/LogTelnetHandler.java index e2e7ab68839..2f587e38702 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/LogTelnetHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/LogTelnetHandler.java @@ -1,41 +1,41 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.telnet.support.command; -import java.io.File; -import java.io.FileInputStream; -import java.nio.ByteBuffer; -import java.nio.channels.FileChannel; -import java.text.SimpleDateFormat; -import java.util.Date; - -import com.alibaba.dubbo.common.extension.Activate; -import com.alibaba.dubbo.common.logger.Level; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.telnet.TelnetHandler; -import com.alibaba.dubbo.remoting.telnet.support.Help; +import java.io.File; +import java.io.FileInputStream; +import java.nio.ByteBuffer; +import java.nio.channels.FileChannel; +import java.text.SimpleDateFormat; +import java.util.Date; + +import com.alibaba.dubbo.common.extension.Activate; +import com.alibaba.dubbo.common.logger.Level; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.common.utils.StringUtils; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.telnet.TelnetHandler; +import com.alibaba.dubbo.remoting.telnet.support.Help; /** * LogTelnetHandler * @author chao.liuc * - */ + */ @Activate @Help(parameter = "level", summary = "Change log level or show log ", detail = "Change log level or show log") public class LogTelnetHandler implements TelnetHandler { @@ -57,9 +57,9 @@ public String telnet(Channel channel, String message) { if (file != null && file.exists()) { try{ - FileInputStream fis = new FileInputStream(file); + FileInputStream fis = new FileInputStream(file); try { - FileChannel filechannel = fis.getChannel(); + FileChannel filechannel = fis.getChannel(); try { size = filechannel.size(); ByteBuffer bb; @@ -78,12 +78,12 @@ public String telnet(Channel channel, String message) { buf.append("\r\nmodified:"+(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss") .format(new Date(file.lastModified())))); - buf.append("\r\nsize:"+size +"\r\n"); - } finally { - filechannel.close(); - } - } finally { - fis.close(); + buf.append("\r\nsize:"+size +"\r\n"); + } finally { + filechannel.close(); + } + } finally { + fis.close(); } }catch (Exception e) { buf.append(e.getMessage()); diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/StatusTelnetHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/StatusTelnetHandler.java index 7014a6cec94..8c02ecaab3e 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/StatusTelnetHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/telnet/support/command/StatusTelnetHandler.java @@ -26,7 +26,7 @@ import com.alibaba.dubbo.common.status.Status; import com.alibaba.dubbo.common.status.StatusChecker; import com.alibaba.dubbo.common.status.support.StatusUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; import com.alibaba.dubbo.remoting.telnet.support.TelnetUtils; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractChannel.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractChannel.java index 0bd04baa47f..5ca4f025e22 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractChannel.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractChannel.java @@ -16,9 +16,7 @@ package com.alibaba.dubbo.remoting.transport; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * AbstractChannel diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractChannelHandlerDelegate.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractChannelHandlerDelegate.java index ae0abfbf7a5..422f9c0b1bb 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractChannelHandlerDelegate.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractChannelHandlerDelegate.java @@ -1,9 +1,7 @@ package com.alibaba.dubbo.remoting.transport; import com.alibaba.dubbo.common.utils.Assert; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * @author kimi @@ -19,7 +17,7 @@ protected AbstractChannelHandlerDelegate(ChannelHandler handler) { public ChannelHandler getHandler() { if (handler instanceof ChannelHandlerDelegate) { - return ((ChannelHandlerDelegate)handler).getHandler(); + return ((ChannelHandlerDelegate) handler).getHandler(); } return handler; } diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractClient.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractClient.java index f4d9ddb0c76..365b480f32a 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractClient.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractClient.java @@ -15,17 +15,6 @@ */ package com.alibaba.dubbo.remoting.transport; -import java.net.InetSocketAddress; -import java.util.concurrent.ExecutorService; -import java.util.concurrent.Executors; -import java.util.concurrent.ScheduledFuture; -import java.util.concurrent.ScheduledThreadPoolExecutor; -import java.util.concurrent.TimeUnit; -import java.util.concurrent.atomic.AtomicBoolean; -import java.util.concurrent.atomic.AtomicInteger; -import java.util.concurrent.locks.Lock; -import java.util.concurrent.locks.ReentrantLock; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; @@ -36,67 +25,72 @@ import com.alibaba.dubbo.common.utils.ExecutorUtil; import com.alibaba.dubbo.common.utils.NamedThreadFactory; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelHandlers; +import java.net.InetSocketAddress; +import java.util.concurrent.*; +import java.util.concurrent.atomic.AtomicBoolean; +import java.util.concurrent.atomic.AtomicInteger; +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + /** * AbstractClient - * + * * @author qian.lei * @author chao.liuc */ public abstract class AbstractClient extends AbstractEndpoint implements Client { - + private static final Logger logger = LoggerFactory.getLogger(AbstractClient.class); - - protected static final String CLIENT_THREAD_POOL_NAME ="DubboClientHandler"; - + + protected static final String CLIENT_THREAD_POOL_NAME = "DubboClientHandler"; + private static final AtomicInteger CLIENT_THREAD_POOL_ID = new AtomicInteger(); - private final Lock connectLock = new ReentrantLock(); - - private static final ScheduledThreadPoolExecutor reconnectExecutorService = new ScheduledThreadPoolExecutor(2, new NamedThreadFactory("DubboClientReconnectTimer", true)); - - private volatile ScheduledFuture reconnectExecutorFuture = null; - + private final Lock connectLock = new ReentrantLock(); + + private static final ScheduledThreadPoolExecutor reconnectExecutorService = new ScheduledThreadPoolExecutor(2, + new NamedThreadFactory("DubboClientReconnectTimer", true)); + + private volatile ScheduledFuture reconnectExecutorFuture = null; + protected volatile ExecutorService executor; - - private final boolean send_reconnect ; - + + private final boolean send_reconnect; + private final AtomicInteger reconnect_count = new AtomicInteger(0); - + //重连的error日志是否已经被调用过. - private final AtomicBoolean reconnect_error_log_flag = new AtomicBoolean(false) ; - + private final AtomicBoolean reconnect_error_log_flag = new AtomicBoolean(false); + //重连warning的间隔.(waring多少次之后,warning一次) //for test - private final int reconnect_warning_period ; - + private final int reconnect_warning_period; + //the last successed connected time private long lastConnectedTime = System.currentTimeMillis(); - - private final long shutdown_timeout ; - - + + private final long shutdown_timeout; + + public AbstractClient(URL url, ChannelHandler handler) throws RemotingException { super(url, handler); - + send_reconnect = url.getParameter(Constants.SEND_RECONNECT_KEY, false); - + shutdown_timeout = url.getParameter(Constants.SHUTDOWN_TIMEOUT_KEY, Constants.DEFAULT_SHUTDOWN_TIMEOUT); - + //默认重连间隔2s,1800表示1小时warning一次. reconnect_warning_period = url.getParameter("reconnect.waring.period", 1800); - + try { doOpen(); } catch (Throwable t) { close(); - throw new RemotingException(url.toInetSocketAddress(), null, - "Failed to start " + getClass().getSimpleName() + " " + NetUtils.getLocalAddress() - + " connect to the server " + getRemoteAddress() + ", cause: " + t.getMessage(), t); + throw new RemotingException(url.toInetSocketAddress(), null, + "Failed to start " + getClass().getSimpleName() + " " + NetUtils.getLocalAddress() + + " connect to the server " + getRemoteAddress() + ", cause: " + t.getMessage(), t); } try { // connect. @@ -110,53 +104,53 @@ public AbstractClient(URL url, ChannelHandler handler) throws RemotingException throw t; } else { logger.warn("Failed to start " + getClass().getSimpleName() + " " + NetUtils.getLocalAddress() - + " connect to the server " + getRemoteAddress() + " (check == false, ignore and retry later!), cause: " + t.getMessage(), t); + + " connect to the server " + getRemoteAddress() + " (check == false, ignore and retry later!), cause: " + t.getMessage(), t); } - } catch (Throwable t){ + } catch (Throwable t) { close(); - throw new RemotingException(url.toInetSocketAddress(), null, - "Failed to start " + getClass().getSimpleName() + " " + NetUtils.getLocalAddress() - + " connect to the server " + getRemoteAddress() + ", cause: " + t.getMessage(), t); + throw new RemotingException(url.toInetSocketAddress(), null, + "Failed to start " + getClass().getSimpleName() + " " + NetUtils.getLocalAddress() + + " connect to the server " + getRemoteAddress() + ", cause: " + t.getMessage(), t); } - + executor = (ExecutorService) ExtensionLoader.getExtensionLoader(DataStore.class) - .getDefaultExtension().get(Constants.CONSUMER_SIDE, Integer.toString(url.getPort())); + .getDefaultExtension().get(Constants.CONSUMER_SIDE, Integer.toString(url.getPort())); ExtensionLoader.getExtensionLoader(DataStore.class) - .getDefaultExtension().remove(Constants.CONSUMER_SIDE, Integer.toString(url.getPort())); + .getDefaultExtension().remove(Constants.CONSUMER_SIDE, Integer.toString(url.getPort())); } - - protected static ChannelHandler wrapChannelHandler(URL url, ChannelHandler handler){ + + protected static ChannelHandler wrapChannelHandler(URL url, ChannelHandler handler) { url = ExecutorUtil.setThreadName(url, CLIENT_THREAD_POOL_NAME); url = url.addParameterIfAbsent(Constants.THREADPOOL_KEY, Constants.DEFAULT_CLIENT_THREADPOOL); return ChannelHandlers.wrap(handler, url); } - + /** * init reconnect thread */ - private synchronized void initConnectStatusCheckCommand(){ + private synchronized void initConnectStatusCheckCommand() { //reconnect=false to close reconnect int reconnect = getReconnectParam(getUrl()); - if(reconnect > 0 && (reconnectExecutorFuture == null || reconnectExecutorFuture.isCancelled())){ - Runnable connectStatusCheckCommand = new Runnable() { + if (reconnect > 0 && (reconnectExecutorFuture == null || reconnectExecutorFuture.isCancelled())) { + Runnable connectStatusCheckCommand = new Runnable() { public void run() { try { - if (! isConnected()) { + if (!isConnected()) { connect(); } else { lastConnectedTime = System.currentTimeMillis(); } - } catch (Throwable t) { - String errorMsg = "client reconnect to "+getUrl().getAddress()+" find error . url: "+ getUrl(); + } catch (Throwable t) { + String errorMsg = "client reconnect to " + getUrl().getAddress() + " find error . url: " + getUrl(); // wait registry sync provider list - if (System.currentTimeMillis() - lastConnectedTime > shutdown_timeout){ - if (!reconnect_error_log_flag.get()){ + if (System.currentTimeMillis() - lastConnectedTime > shutdown_timeout) { + if (!reconnect_error_log_flag.get()) { reconnect_error_log_flag.set(true); logger.error(errorMsg, t); - return ; + return; } } - if ( reconnect_count.getAndIncrement() % reconnect_warning_period == 0){ + if (reconnect_count.getAndIncrement() % reconnect_warning_period == 0) { logger.warn(errorMsg, t); } } @@ -165,34 +159,34 @@ public void run() { reconnectExecutorFuture = reconnectExecutorService.scheduleWithFixedDelay(connectStatusCheckCommand, reconnect, reconnect, TimeUnit.MILLISECONDS); } } - + /** * @param url * @return 0-false */ - private static int getReconnectParam(URL url){ - int reconnect ; + private static int getReconnectParam(URL url) { + int reconnect; String param = url.getParameter(Constants.RECONNECT_KEY); - if (param == null || param.length()==0 || "true".equalsIgnoreCase(param)){ + if (param == null || param.length() == 0 || "true".equalsIgnoreCase(param)) { reconnect = Constants.DEFAULT_RECONNECT_PERIOD; - }else if ("false".equalsIgnoreCase(param)){ + } else if ("false".equalsIgnoreCase(param)) { reconnect = 0; } else { - try{ + try { reconnect = Integer.parseInt(param); - }catch (Exception e) { - throw new IllegalArgumentException("reconnect param must be nonnegative integer or false/true. input is:"+param); + } catch (Exception e) { + throw new IllegalArgumentException("reconnect param must be nonnegative integer or false/true. input is:" + param); } - if(reconnect < 0){ - throw new IllegalArgumentException("reconnect param must be nonnegative integer or false/true. input is:"+param); + if (reconnect < 0) { + throw new IllegalArgumentException("reconnect param must be nonnegative integer or false/true. input is:" + param); } } return reconnect; } - - private synchronized void destroyConnectStatusCheckCommand(){ + + private synchronized void destroyConnectStatusCheckCommand() { try { - if (reconnectExecutorFuture != null && ! reconnectExecutorFuture.isDone()){ + if (reconnectExecutorFuture != null && !reconnectExecutorFuture.isDone()) { reconnectExecutorFuture.cancel(true); reconnectExecutorService.purge(); } @@ -200,11 +194,11 @@ private synchronized void destroyConnectStatusCheckCommand(){ logger.warn(e.getMessage(), e); } } - + protected ExecutorService createExecutor() { return Executors.newCachedThreadPool(new NamedThreadFactory(CLIENT_THREAD_POOL_NAME + CLIENT_THREAD_POOL_ID.incrementAndGet() + "-" + getUrl().getAddress(), true)); } - + public InetSocketAddress getConnectAddress() { return new InetSocketAddress(NetUtils.filterLocalHost(getUrl().getHost()), getUrl().getPort()); } @@ -257,19 +251,19 @@ public boolean hasAttribute(String key) { return false; return channel.hasAttribute(key); } - + public void send(Object message, boolean sent) throws RemotingException { - if (send_reconnect && !isConnected()){ + if (send_reconnect && !isConnected()) { connect(); } Channel channel = getChannel(); //TODO getChannel返回的状态是否包含null需要改进 - if (channel == null || ! channel.isConnected()) { - throw new RemotingException(this, "message can not send, because channel is closed . url:" + getUrl()); + if (channel == null || !channel.isConnected()) { + throw new RemotingException(this, "message can not send, because channel is closed . url:" + getUrl()); } channel.send(message, sent); } - + protected void connect() throws RemotingException { connectLock.lock(); try { @@ -278,16 +272,16 @@ protected void connect() throws RemotingException { } initConnectStatusCheckCommand(); doConnect(); - if (! isConnected()) { + if (!isConnected()) { throw new RemotingException(this, "Failed connect to server " + getRemoteAddress() + " from " + getClass().getSimpleName() + " " - + NetUtils.getLocalHost() + " using dubbo version " + Version.getVersion() - + ", cause: Connect wait timeout: " + getTimeout() + "ms."); + + NetUtils.getLocalHost() + " using dubbo version " + Version.getVersion() + + ", cause: Connect wait timeout: " + getTimeout() + "ms."); } else { - if (logger.isInfoEnabled()){ - logger.info("Successed connect to server " + getRemoteAddress() + " from " + getClass().getSimpleName() + " " - + NetUtils.getLocalHost() + " using dubbo version " + Version.getVersion() - + ", channel is " + this.getChannel()); - } + if (logger.isInfoEnabled()) { + logger.info("Successed connect to server " + getRemoteAddress() + " from " + getClass().getSimpleName() + " " + + NetUtils.getLocalHost() + " using dubbo version " + Version.getVersion() + + ", channel is " + this.getChannel()); + } } reconnect_count.set(0); reconnect_error_log_flag.set(false); @@ -295,8 +289,8 @@ protected void connect() throws RemotingException { throw e; } catch (Throwable e) { throw new RemotingException(this, "Failed connect to server " + getRemoteAddress() + " from " + getClass().getSimpleName() + " " - + NetUtils.getLocalHost() + " using dubbo version " + Version.getVersion() - + ", cause: " + e.getMessage(), e); + + NetUtils.getLocalHost() + " using dubbo version " + Version.getVersion() + + ", cause: " + e.getMessage(), e); } finally { connectLock.unlock(); } @@ -323,18 +317,18 @@ public void disconnect() { connectLock.unlock(); } } - + public void reconnect() throws RemotingException { disconnect(); connect(); } public void close() { - try { - if (executor != null) { - ExecutorUtil.shutdownNow(executor, 100); - } - } catch (Throwable e) { + try { + if (executor != null) { + ExecutorUtil.shutdownNow(executor, 100); + } + } catch (Throwable e) { logger.warn(e.getMessage(), e); } try { @@ -343,7 +337,7 @@ public void close() { logger.warn(e.getMessage(), e); } try { - disconnect(); + disconnect(); } catch (Throwable e) { logger.warn(e.getMessage(), e); } @@ -355,10 +349,10 @@ public void close() { } public void close(int timeout) { - ExecutorUtil.gracefulShutdown(executor ,timeout); + ExecutorUtil.gracefulShutdown(executor, timeout); close(); } - + @Override public String toString() { return getClass().getName() + " [" + getLocalAddress() + " -> " + getRemoteAddress() + "]"; @@ -366,35 +360,35 @@ public String toString() { /** * Open client. - * + * * @throws Throwable */ protected abstract void doOpen() throws Throwable; /** * Close client. - * + * * @throws Throwable */ protected abstract void doClose() throws Throwable; /** * Connect to server. - * + * * @throws Throwable */ protected abstract void doConnect() throws Throwable; - + /** * disConnect to server. - * + * * @throws Throwable */ protected abstract void doDisConnect() throws Throwable; /** * Get the connected channel. - * + * * @return channel */ protected abstract Channel getChannel(); diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractCodec.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractCodec.java index 47f997f6e86..1e2d6a85332 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractCodec.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractCodec.java @@ -24,7 +24,6 @@ import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.serialize.Serialization; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; import com.alibaba.dubbo.remoting.Codec2; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractEndpoint.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractEndpoint.java index 9fc02918eac..8a179d6bf1b 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractEndpoint.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractEndpoint.java @@ -21,26 +21,25 @@ import com.alibaba.dubbo.common.extension.ExtensionLoader; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Codec2; -import com.alibaba.dubbo.remoting.ChannelHandler; import com.alibaba.dubbo.remoting.Codec; +import com.alibaba.dubbo.remoting.Codec2; import com.alibaba.dubbo.remoting.transport.codec.CodecAdapter; /** * AbstractEndpoint - * + * * @author william.liangf */ public abstract class AbstractEndpoint extends AbstractPeer implements Resetable { - + private static final Logger logger = LoggerFactory.getLogger(AbstractEndpoint.class); - private Codec2 codec; + private Codec2 codec; - private int timeout; + private int timeout; + + private int connectTimeout; - private int connectTimeout; - public AbstractEndpoint(URL url, ChannelHandler handler) { super(url, handler); this.codec = getChannelCodec(url); @@ -51,7 +50,7 @@ public AbstractEndpoint(URL url, ChannelHandler handler) { public void reset(URL url) { if (isClosed()) { throw new IllegalStateException("Failed to reset parameters " - + url + ", cause: Channel closed. channel: " + getLocalAddress()); + + url + ", cause: Channel closed. channel: " + getLocalAddress()); } try { if (url.hasParameter(Constants.HEARTBEAT_KEY)) { @@ -81,9 +80,9 @@ public void reset(URL url) { logger.error(t.getMessage(), t); } } - + @Deprecated - public void reset(com.alibaba.dubbo.common.Parameters parameters){ + public void reset(com.alibaba.dubbo.common.Parameters parameters) { reset(getUrl().addParameters(parameters.getParameters())); } @@ -105,7 +104,7 @@ protected static Codec2 getChannelCodec(URL url) { return ExtensionLoader.getExtensionLoader(Codec2.class).getExtension(codecName); } else { return new CodecAdapter(ExtensionLoader.getExtensionLoader(Codec.class) - .getExtension(codecName)); + .getExtension(codecName)); } } diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractPeer.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractPeer.java index 353d54af771..1fa86aaf1e1 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractPeer.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractPeer.java @@ -17,10 +17,7 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Endpoint; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * AbstractPeer diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractServer.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractServer.java index 3788994f2cd..3f29529c965 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractServer.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/AbstractServer.java @@ -15,11 +15,6 @@ */ package com.alibaba.dubbo.remoting.transport; -import java.net.InetSocketAddress; -import java.util.Collection; -import java.util.concurrent.ExecutorService; -import java.util.concurrent.ThreadPoolExecutor; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; @@ -28,39 +23,41 @@ import com.alibaba.dubbo.common.store.DataStore; import com.alibaba.dubbo.common.utils.ExecutorUtil; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.exception.RemotingException; + +import java.net.InetSocketAddress; +import java.util.Collection; +import java.util.concurrent.ExecutorService; +import java.util.concurrent.ThreadPoolExecutor; /** * AbstractServer - * + * * @author qian.lei * @author ding.lid */ public abstract class AbstractServer extends AbstractEndpoint implements Server { - + private static final Logger logger = LoggerFactory.getLogger(AbstractServer.class); - private InetSocketAddress localAddress; + private InetSocketAddress localAddress; + + private InetSocketAddress bindAddress; + + private int accepts; - private InetSocketAddress bindAddress; + private int idleTimeout = 600; //600 seconds - private int accepts; + protected static final String SERVER_THREAD_POOL_NAME = "DubboServerHandler"; - private int idleTimeout = 600; //600 seconds - - protected static final String SERVER_THREAD_POOL_NAME ="DubboServerHandler"; - ExecutorService executor; public AbstractServer(URL url, ChannelHandler handler) throws RemotingException { super(url, handler); localAddress = getUrl().toInetSocketAddress(); - String host = url.getParameter(Constants.ANYHOST_KEY, false) - || NetUtils.isInvalidLocalHost(getUrl().getHost()) - ? NetUtils.ANYHOST : getUrl().getHost(); + String host = url.getParameter(Constants.ANYHOST_KEY, false) + || NetUtils.isInvalidLocalHost(getUrl().getHost()) + ? NetUtils.ANYHOST : getUrl().getHost(); bindAddress = new InetSocketAddress(host, getUrl().getPort()); this.accepts = url.getParameter(Constants.ACCEPTS_KEY, Constants.DEFAULT_ACCEPTS); this.idleTimeout = url.getParameter(Constants.IDLE_TIMEOUT_KEY, Constants.DEFAULT_IDLE_TIMEOUT); @@ -70,16 +67,16 @@ public AbstractServer(URL url, ChannelHandler handler) throws RemotingException logger.info("Start " + getClass().getSimpleName() + " bind " + getBindAddress() + ", export " + getLocalAddress()); } } catch (Throwable t) { - throw new RemotingException(url.toInetSocketAddress(), null, "Failed to bind " + getClass().getSimpleName() - + " on " + getLocalAddress() + ", cause: " + t.getMessage(), t); + throw new RemotingException(url.toInetSocketAddress(), null, "Failed to bind " + getClass().getSimpleName() + + " on " + getLocalAddress() + ", cause: " + t.getMessage(), t); } executor = (ExecutorService) ExtensionLoader.getExtensionLoader(DataStore.class) .getDefaultExtension().get(Constants.EXECUTOR_SERVICE_COMPONENT_KEY, Integer.toString(url.getPort())); } - + protected abstract void doOpen() throws Throwable; - + protected abstract void doClose() throws Throwable; public void reset(URL url) { @@ -107,7 +104,7 @@ public void reset(URL url) { logger.error(t.getMessage(), t); } try { - if (url.hasParameter(Constants.THREADS_KEY) + if (url.hasParameter(Constants.THREADS_KEY) && executor instanceof ThreadPoolExecutor && !executor.isShutdown()) { ThreadPoolExecutor threadPoolExecutor = (ThreadPoolExecutor) executor; int threads = url.getParameter(Constants.THREADS_KEY, 0); @@ -141,12 +138,12 @@ public void send(Object message, boolean sent) throws RemotingException { } } } - + public void close() { if (logger.isInfoEnabled()) { logger.info("Close " + getClass().getSimpleName() + " bind " + getBindAddress() + ", export " + getLocalAddress()); } - ExecutorUtil.shutdownNow(executor ,100); + ExecutorUtil.shutdownNow(executor, 100); try { super.close(); } catch (Throwable e) { @@ -158,16 +155,16 @@ public void close() { logger.warn(e.getMessage(), e); } } - + public void close(int timeout) { - ExecutorUtil.gracefulShutdown(executor ,timeout); + ExecutorUtil.gracefulShutdown(executor, timeout); close(); } public InetSocketAddress getLocalAddress() { return localAddress; } - + public InetSocketAddress getBindAddress() { return bindAddress; } @@ -190,14 +187,14 @@ public void connected(Channel ch) throws RemotingException { } super.connected(ch); } - + @Override public void disconnected(Channel ch) throws RemotingException { Collection channels = getChannels(); - if (channels.size() == 0){ + if (channels.size() == 0) { logger.warn("All clients has discontected from " + ch.getLocalAddress() + ". You can graceful shutdown now."); } super.disconnected(ch); } - + } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelDelegate.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelDelegate.java index 639f95fbd29..8f71bae26ac 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelDelegate.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelDelegate.java @@ -18,9 +18,7 @@ import java.net.InetSocketAddress; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * ChannelDelegate diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerAdapter.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerAdapter.java index f77605e8958..7b1c777d692 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerAdapter.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerAdapter.java @@ -1,23 +1,21 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * ChannelHandlerAdapter. diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerDelegate.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerDelegate.java index b618761b36e..d56508978a1 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerDelegate.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerDelegate.java @@ -13,13 +13,13 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting.transport; - -import com.alibaba.dubbo.remoting.ChannelHandler; - -/** - * @author chao.liuc - */ -public interface ChannelHandlerDelegate extends ChannelHandler { - public ChannelHandler getHandler(); +package com.alibaba.dubbo.remoting.transport; + +/** + * @author chao.liuc + */ +public interface ChannelHandlerDelegate extends ChannelHandler { + + ChannelHandler getHandler(); + } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerDispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerDispatcher.java index 76fdd560dbc..2151fdbfc09 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerDispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandlerDispatcher.java @@ -21,8 +21,6 @@ import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; /** * ChannelListenerDispatcher diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ClientDelegate.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ClientDelegate.java index 6bb445df203..5f4be20242b 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ClientDelegate.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ClientDelegate.java @@ -18,9 +18,7 @@ import java.net.InetSocketAddress; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * ClientDelegate diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/DecodeHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/DecodeHandler.java index 69c99a56c26..b101bd00338 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/DecodeHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/DecodeHandler.java @@ -18,12 +18,10 @@ import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; import com.alibaba.dubbo.remoting.Decodeable; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; /** * @author kimi @@ -42,34 +40,32 @@ public void received(Channel channel, Object message) throws RemotingException { } if (message instanceof Request) { - decode(((Request)message).getData()); + decode(((Request) message).getData()); } if (message instanceof Response) { - decode( ((Response)message).getResult()); + decode(((Response) message).getResult()); } - handler.received(channel, message); } private void decode(Object message) { if (message != null && message instanceof Decodeable) { try { - ((Decodeable)message).decode(); + ((Decodeable) message).decode(); if (log.isDebugEnabled()) { log.debug(new StringBuilder(32).append("Decode decodeable message ") - .append(message.getClass().getName()).toString()); + .append(message.getClass().getName()).toString()); } } catch (Throwable e) { if (log.isWarnEnabled()) { log.warn( - new StringBuilder(32) - .append("Call Decodeable.decode failed: ") - .append(e.getMessage()).toString(), - e); + new StringBuilder(32) + .append("Call Decodeable.decode failed: ") + .append(e.getMessage()).toString(), + e); } - } // ~ end of catch - } // ~ end of if - } // ~ end of method decode - + } + } + } } diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/MultiMessageHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/MultiMessageHandler.java index 032f47c19c4..52d3724f281 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/MultiMessageHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/MultiMessageHandler.java @@ -1,10 +1,7 @@ package com.alibaba.dubbo.remoting.transport; import com.alibaba.dubbo.remoting.exchange.support.MultiMessage; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.support.MultiMessage; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * @author kimi diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ServerDelegate.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ServerDelegate.java index e91572e0b25..236c6a2bc99 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ServerDelegate.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/ServerDelegate.java @@ -19,10 +19,7 @@ import java.util.Collection; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * ServerDelegate diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/codec/CodecAdapter.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/codec/CodecAdapter.java index c3ab52c2996..159b1f8ad99 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/codec/CodecAdapter.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/codec/CodecAdapter.java @@ -21,7 +21,7 @@ import com.alibaba.dubbo.common.io.UnsafeByteArrayInputStream; import com.alibaba.dubbo.common.io.UnsafeByteArrayOutputStream; import com.alibaba.dubbo.common.utils.Assert; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec; import com.alibaba.dubbo.remoting.Codec2; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/codec/TransportCodec.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/codec/TransportCodec.java index 1c57885f009..aa6c28cf6ae 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/codec/TransportCodec.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/codec/TransportCodec.java @@ -23,7 +23,7 @@ import com.alibaba.dubbo.common.serialize.ObjectInput; import com.alibaba.dubbo.common.serialize.ObjectOutput; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; import com.alibaba.dubbo.remoting.buffer.ChannelBufferInputStream; import com.alibaba.dubbo.remoting.buffer.ChannelBufferOutputStream; @@ -49,10 +49,6 @@ public void encode(Channel channel, ChannelBuffer buffer, Object message) throws } public Object decode(Channel channel, ChannelBuffer buffer) throws IOException { -// InputStream input = new ChannelBufferInputStream(buffer); -// return decodeData(channel, getSerialization(channel).deserialize(channel.getUrl(), input)); - - // modified by lishen InputStream input = new ChannelBufferInputStream(buffer); ObjectInput objectInput = getSerialization(channel).deserialize(channel.getUrl(), input); Object object = decodeData(channel, objectInput); diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/ChannelEventRunnable.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/ChannelEventRunnable.java index f0976d34f63..fefa67f2899 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/ChannelEventRunnable.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/ChannelEventRunnable.java @@ -17,32 +17,31 @@ import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; /** * @author chao.liuc - * */ public class ChannelEventRunnable implements Runnable { - private static final Logger logger = LoggerFactory.getLogger(ChannelEventRunnable.class); + private static final Logger logger = LoggerFactory.getLogger(ChannelEventRunnable.class); private final ChannelHandler handler; private final Channel channel; private final ChannelState state; private final Throwable exception; private final Object message; - + public ChannelEventRunnable(Channel channel, ChannelHandler handler, ChannelState state) { this(channel, handler, state, null); } - + public ChannelEventRunnable(Channel channel, ChannelHandler handler, ChannelState state, Object message) { this(channel, handler, state, message, null); } - + public ChannelEventRunnable(Channel channel, ChannelHandler handler, ChannelState state, Throwable t) { - this(channel, handler, state, null , t); + this(channel, handler, state, null, t); } public ChannelEventRunnable(Channel channel, ChannelHandler handler, ChannelState state, Object message, Throwable exception) { @@ -52,45 +51,45 @@ public ChannelEventRunnable(Channel channel, ChannelHandler handler, ChannelStat this.message = message; this.exception = exception; } - + public void run() { switch (state) { case CONNECTED: - try{ + try { handler.connected(channel); - }catch (Exception e) { + } catch (Exception e) { logger.warn("ChannelEventRunnable handle " + state + " operation error, channel is " + channel, e); } break; case DISCONNECTED: - try{ + try { handler.disconnected(channel); - }catch (Exception e) { + } catch (Exception e) { logger.warn("ChannelEventRunnable handle " + state + " operation error, channel is " + channel, e); } break; case SENT: - try{ - handler.sent(channel,message); - }catch (Exception e) { + try { + handler.sent(channel, message); + } catch (Exception e) { logger.warn("ChannelEventRunnable handle " + state + " operation error, channel is " + channel - + ", message is "+ message,e); + + ", message is " + message, e); } break; case RECEIVED: - try{ + try { handler.received(channel, message); - }catch (Exception e) { + } catch (Exception e) { logger.warn("ChannelEventRunnable handle " + state + " operation error, channel is " + channel - + ", message is "+ message,e); + + ", message is " + message, e); } break; case CAUGHT: - try{ + try { handler.caught(channel, exception); - }catch (Exception e) { - logger.warn("ChannelEventRunnable handle " + state + " operation error, channel is "+ channel - + ", message is: " + message + ", exception is " + exception,e); + } catch (Exception e) { + logger.warn("ChannelEventRunnable handle " + state + " operation error, channel is " + channel + + ", message is: " + message + ", exception is " + exception, e); } break; default: @@ -100,31 +99,31 @@ public void run() { /** * ChannelState - * + * * @author william.liangf */ - public enum ChannelState{ - + public enum ChannelState { + /** * CONNECTED */ CONNECTED, - + /** * DISCONNECTED */ DISCONNECTED, - + /** * SENT */ SENT, - + /** * RECEIVED */ RECEIVED, - + /** * CAUGHT */ diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/ChannelHandlers.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/ChannelHandlers.java index 5590d7b543b..b08efc7db6e 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/ChannelHandlers.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/ChannelHandlers.java @@ -18,7 +18,7 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.Dispatcher; import com.alibaba.dubbo.remoting.exchange.support.header.HeartbeatHandler; import com.alibaba.dubbo.remoting.transport.MultiMessageHandler; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/WrappedChannelHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/WrappedChannelHandler.java index 4ba418f9c50..076b3ec2d2e 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/WrappedChannelHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/WrappedChannelHandler.java @@ -26,9 +26,9 @@ import com.alibaba.dubbo.common.store.DataStore; import com.alibaba.dubbo.common.threadpool.ThreadPool; import com.alibaba.dubbo.common.utils.NamedThreadFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.ChannelHandlerDelegate; public class WrappedChannelHandler implements ChannelHandlerDelegate { @@ -58,8 +58,8 @@ public WrappedChannelHandler(ChannelHandler handler, URL url) { public void close() { try { - if (executor instanceof ExecutorService) { - ((ExecutorService)executor).shutdown(); + if (executor != null) { + executor.shutdown(); } } catch (Throwable t) { logger.warn("fail to destroy thread pool of server: " + t.getMessage(), t); diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/all/AllChannelHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/all/AllChannelHandler.java index 1268cdb1418..f036a0f5872 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/all/AllChannelHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/all/AllChannelHandler.java @@ -18,10 +18,10 @@ import java.util.concurrent.ExecutorService; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.ExecutionException; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.ExecutionException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable; import com.alibaba.dubbo.remoting.transport.dispatcher.WrappedChannelHandler; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable.ChannelState; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/all/AllDispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/all/AllDispatcher.java index 30d5ec6d675..79bd97a3cc3 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/all/AllDispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/all/AllDispatcher.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.transport.dispatcher.all; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.Dispatcher; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/connection/ConnectionOrderedChannelHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/connection/ConnectionOrderedChannelHandler.java index 4dff6d5a3d1..17069a424ba 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/connection/ConnectionOrderedChannelHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/connection/ConnectionOrderedChannelHandler.java @@ -24,10 +24,10 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.threadpool.support.AbortPolicyWithReport; import com.alibaba.dubbo.common.utils.NamedThreadFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.ExecutionException; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.ExecutionException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable; import com.alibaba.dubbo.remoting.transport.dispatcher.WrappedChannelHandler; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable.ChannelState; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/connection/ConnectionOrderedDispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/connection/ConnectionOrderedDispatcher.java index ee9fe27e4a1..bf1c4549b2b 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/connection/ConnectionOrderedDispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/connection/ConnectionOrderedDispatcher.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.transport.dispatcher.connection; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.Dispatcher; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/direct/DirectDispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/direct/DirectDispatcher.java index 5eab7be3a82..e9fc8d9c803 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/direct/DirectDispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/direct/DirectDispatcher.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.transport.dispatcher.direct; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.Dispatcher; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/execution/ExecutionChannelHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/execution/ExecutionChannelHandler.java index ffe113a87ac..7214e98b8bf 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/execution/ExecutionChannelHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/execution/ExecutionChannelHandler.java @@ -16,9 +16,9 @@ package com.alibaba.dubbo.remoting.transport.dispatcher.execution; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable; import com.alibaba.dubbo.remoting.transport.dispatcher.WrappedChannelHandler; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable.ChannelState; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/execution/ExecutionDispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/execution/ExecutionDispatcher.java index d72f9d6983a..8477a3f7534 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/execution/ExecutionDispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/execution/ExecutionDispatcher.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.transport.dispatcher.execution; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.Dispatcher; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/message/MessageOnlyChannelHandler.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/message/MessageOnlyChannelHandler.java index 19a112970f2..b801b404775 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/message/MessageOnlyChannelHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/message/MessageOnlyChannelHandler.java @@ -18,10 +18,10 @@ import java.util.concurrent.ExecutorService; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.ExecutionException; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.ExecutionException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable; import com.alibaba.dubbo.remoting.transport.dispatcher.WrappedChannelHandler; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable.ChannelState; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/message/MessageOnlyDispatcher.java b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/message/MessageOnlyDispatcher.java index 4326aaec270..6be3d0dfb3a 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/message/MessageOnlyDispatcher.java +++ b/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/transport/dispatcher/message/MessageOnlyDispatcher.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.transport.dispatcher.message; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.Dispatcher; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/ChanelHandlerTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/ChanelHandlerTest.java index 1917fd6cda7..6f3bb9ad3a7 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/ChanelHandlerTest.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/ChanelHandlerTest.java @@ -1,20 +1,22 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import junit.framework.TestCase; import org.junit.Test; diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/Main.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/Main.java deleted file mode 100644 index f078531d727..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/Main.java +++ /dev/null @@ -1,142 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting; - -import java.io.Serializable; -import java.util.Random; -import java.util.concurrent.Executor; -import java.util.concurrent.Executors; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; -import com.alibaba.dubbo.remoting.exchange.Exchangers; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; -import com.alibaba.dubbo.remoting.exchange.support.Replier; -import com.alibaba.dubbo.remoting.exchange.support.ReplierDispatcher; - -/** - * Main - */ - -public class Main -{ - public static void main(String[] args) throws Exception - { - startServer(9010); - mutliThreadTest(10,9010); - dataPackageTest(9010); - } - - private static void startServer(int port) throws Exception - { - ReplierDispatcher dispatcher = new ReplierDispatcher(); - dispatcher.addReplier(RpcMessage.class, new RpcMessageHandler()); - dispatcher.addReplier(Object.class, new Replier() { - public Object reply(ExchangeChannel channel, Object msg) - { - for(int i=0;i<10000;i++) - System.currentTimeMillis(); - System.out.println("handle:"+msg+";thread:"+Thread.currentThread().getName()); - return new StringMessage("hello world"); - } - }); - Exchangers.bind(URL.valueOf("dubbo://localhost:" + port), dispatcher); - } - - static void dataPackageTest(int port) throws Exception - { - ExchangeChannel client = Exchangers.connect(URL.valueOf("dubbo://localhost:" + port)); - Random random = new Random(); - for(int i=5;i<100;i++) - { - StringBuilder sb = new StringBuilder(); - for(int j=0;j[]{int.class, int.class},new Object[]{55,25})).get(); - System.out.println("55+25="+result.getResult()); - - for(int i=0;i<100;i++) - client.request(new RpcMessage(DemoService.class.getName(),"sayHello", new Class[]{String.class},new Object[]{"qianlei"+i})); - - for(int i=0;i<100;i++) - client.request(new Main.Data()); - - System.out.println("=====test invoke====="); - for(int i=0;i<100;i++){ - ResponseFuture future = client.request(new Main.Data()); - System.out.println("invoke and get"); - System.out.println("invoke result:" + future.get()); - } - System.out.println("=====the end====="); - } - - static class Data implements Serializable - { - private static final long serialVersionUID = -4666580993978548778L; - - private String mData = ""; - - public Data(){} - - public String getData() - { - return mData; - } - - public void setData(String data) - { - mData = data; - } - } - - static class StringMessage implements Serializable - { - private static final long serialVersionUID = 7193122183120113947L; - - private String mText; - - StringMessage(String msg) - { - mText = msg; - } - - public String toString() - { - return mText; - } - } -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientFixedTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientFixedTest.java deleted file mode 100644 index 6b93ca686d0..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientFixedTest.java +++ /dev/null @@ -1,136 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting; - -import java.util.ArrayList; -import java.util.Random; - -import junit.framework.TestCase; - -import org.junit.Test; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.exchange.ExchangeClient; -import com.alibaba.dubbo.remoting.exchange.Exchangers; - -public class PerformanceClientFixedTest extends TestCase { - - private static final Logger logger = LoggerFactory.getLogger(PerformanceClientTest.class); - - @Test - public void testClient() throws Exception { - // 读取参数 - if (PerformanceUtils.getProperty("server", null) == null) { - logger.warn("Please set -Dserver=127.0.0.1:9911"); - return; - } - final String server = System.getProperty("server", "127.0.0.1:9911"); - final String transporter = PerformanceUtils.getProperty(Constants.TRANSPORTER_KEY, Constants.DEFAULT_TRANSPORTER); - final String serialization = PerformanceUtils.getProperty(Constants.SERIALIZATION_KEY, Constants.DEFAULT_REMOTING_SERIALIZATION); - final int timeout = PerformanceUtils.getIntProperty(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); - //final int length = PerformanceUtils.getIntProperty("length", 1024); - final int connectionCount = PerformanceUtils.getIntProperty(Constants.CONNECTIONS_KEY, 1); - //final int concurrent = PerformanceUtils.getIntProperty("concurrent", 100); - //int r = PerformanceUtils.getIntProperty("runs", 10000); - //final int runs = r > 0 ? r : Integer.MAX_VALUE; - //final String onerror = PerformanceUtils.getProperty("onerror", "continue"); - final String url = "exchange://" + server + "?transporter=" + transporter + "&serialization=" + serialization + "&timeout=" + timeout; - - //int idx = server.indexOf(':'); - Random rd = new Random(connectionCount); - ArrayList arrays = new ArrayList(); - String oneKBlock = null; - String messageBlock = null; - int s = 0; - int f = 0; - System.out.println("initialize arrays " + url); - while (s < connectionCount) { - ExchangeClient client = null; - try { - System.out.println("open connection " + s + " " + url + arrays.size()); - - client = Exchangers.connect(url); - - System.out.println("run after open"); - - if (client.isConnected()) { - arrays.add(client); - s++; - System.out.println("open client success " + s); - } else { - System.out.println("open client failed, try again."); - } - } catch (Throwable t) { - t.printStackTrace(); - } finally { - if (client != null && client.isConnected() == false) { - f++; - System.out.println("open client failed, try again " + f); - client.close(); - } - } - } - - StringBuilder sb1 = new StringBuilder(); - Random rd2 = new Random(); - char[] numbersAndLetters = ("0123456789abcdefghijklmnopqrstuvwxyz" + "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ").toCharArray(); - int size1 = numbersAndLetters.length; - for (int j = 0; j < 1024; j++) { - sb1.append(numbersAndLetters[rd2.nextInt(size1)]); - } - oneKBlock = sb1.toString(); - - for (int j = 0; j < Integer.MAX_VALUE; j++) { - try { - String size = "10"; - - int request_size = 10; - try { - request_size = Integer.parseInt(size); - } catch (Throwable t) { - request_size = 10; - } - - if (messageBlock == null) { - StringBuilder sb = new StringBuilder(); - for (int i = 0; i < request_size; i++) { - sb.append(oneKBlock); - } - messageBlock = sb.toString(); - - System.out.println("set messageBlock to " + messageBlock); - } - int index = rd.nextInt(connectionCount); - ExchangeClient client = arrays.get(index); - // ExchangeClient client = arrays.get(0); - String output = (String) client.request(messageBlock).get(); - - if (output.lastIndexOf(messageBlock) < 0) { - System.out.println("send messageBlock;get " + output); - throw new Throwable("return results invalid"); - } else { - if (j % 100 == 0) - System.out.println("OK: " + j); - } - } catch (Throwable t) { - t.printStackTrace(); - } - } - } - -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientMain.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientMain.java deleted file mode 100644 index 18196015ddf..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientMain.java +++ /dev/null @@ -1,28 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting; - - -/** - * PerformanceClientMain - */ -public class PerformanceClientMain { - - public static void main(String[] args) throws Throwable { - new PerformanceClientTest().testClient(); - } - -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientTest.java deleted file mode 100644 index 658de26aaca..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceClientTest.java +++ /dev/null @@ -1,228 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting; - -import java.text.DecimalFormat; -import java.text.SimpleDateFormat; -import java.util.Date; -import java.util.List; -import java.util.concurrent.CountDownLatch; -import java.util.concurrent.atomic.AtomicInteger; -import java.util.concurrent.atomic.AtomicLong; - -import junit.framework.TestCase; - -import org.junit.Test; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.exchange.ExchangeClient; -import com.alibaba.dubbo.remoting.exchange.Exchangers; -import com.alibaba.dubbo.remoting.exchange.support.ExchangeHandlerAdapter; - -/** - * PerformanceClientTest - * - * mvn clean test -Dtest=*PerformanceClientTest -Dserver=10.20.153.187:9911 - * - * @author william.liangf - */ -public class PerformanceClientTest extends TestCase { - - private static final Logger logger = LoggerFactory.getLogger(PerformanceClientTest.class); - - @Test - @SuppressWarnings("unchecked") - public void testClient() throws Throwable { - // 读取参数 - if (PerformanceUtils.getProperty("server", null) == null) { - logger.warn("Please set -Dserver=127.0.0.1:9911"); - return; - } - final String server = System.getProperty("server", "127.0.0.1:9911"); - final String transporter = PerformanceUtils.getProperty(Constants.TRANSPORTER_KEY, Constants.DEFAULT_TRANSPORTER); - final String serialization = PerformanceUtils.getProperty(Constants.SERIALIZATION_KEY, Constants.DEFAULT_REMOTING_SERIALIZATION); - final int timeout = PerformanceUtils.getIntProperty(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); - final int length = PerformanceUtils.getIntProperty("length", 1024); - final int connections = PerformanceUtils.getIntProperty(Constants.CONNECTIONS_KEY, 1); - final int concurrent = PerformanceUtils.getIntProperty("concurrent", 100); - int r = PerformanceUtils.getIntProperty("runs", 10000); - final int runs = r > 0 ? r : Integer.MAX_VALUE; - final String onerror = PerformanceUtils.getProperty("onerror", "continue"); - - final String url = "exchange://" + server + "?transporter=" + transporter + "&serialization=" + serialization + "&timeout=" + timeout; - // 创建客户端 - final ExchangeClient[] exchangeClients = new ExchangeClient[connections]; - for (int i = 0; i < connections; i ++) { - //exchangeClients[i] = Exchangers.connect(url,handler); - exchangeClients[i] = Exchangers.connect(url); - } - - List serverEnvironment = (List) exchangeClients[0].request("environment").get(); - List serverScene = (List) exchangeClients[0].request("scene").get(); - - // 制造数据 - StringBuilder buf = new StringBuilder(length); - for (int i = 0; i < length; i ++) { - buf.append("A"); - } - final String data = buf.toString(); - - // 计数器 - final AtomicLong count = new AtomicLong(); - final AtomicLong error = new AtomicLong(); - final AtomicLong time = new AtomicLong(); - final AtomicLong all = new AtomicLong(); - - // 并发调用 - final CountDownLatch latch = new CountDownLatch(concurrent); - for (int i = 0; i < concurrent; i ++) { - new Thread(new Runnable() { - public void run() { - try { - AtomicInteger index = new AtomicInteger(); - long init = System.currentTimeMillis(); - for (int i = 0; i < runs; i++) { - try { - count.incrementAndGet(); - ExchangeClient client = exchangeClients[index.getAndIncrement() % connections]; - long start = System.currentTimeMillis(); - String result = (String) client.request(data).get(); - long end = System.currentTimeMillis(); - if (! data.equals(result)) { - throw new IllegalStateException("Invalid result " + result); - } - time.addAndGet(end - start); - } catch (Exception e) { - error.incrementAndGet(); - e.printStackTrace(); - if ("exit".equals(onerror)) { - System.exit(-1); - } else if ("break".equals(onerror)) { - break; - } else if ("sleep".equals(onerror)) { - try { - Thread.sleep(30000); - } catch (InterruptedException e1) { - } - } - } - } - all.addAndGet(System.currentTimeMillis() - init); - } finally { - latch.countDown(); - } - } - }).start(); - } - - // 输出,tps不精确,但大概反映情况 - new Thread(new Runnable() { - public void run() { - try{ - SimpleDateFormat dateFormat = new SimpleDateFormat ("HH:mm:ss"); - long lastCount = count.get(); - long sleepTime = 2000; - long elapsd = sleepTime/1000; - boolean bfirst = true; - while (latch.getCount() > 0) { - long c = count.get()-lastCount ; - if(! bfirst)//第一次不准 - System.out.println("["+dateFormat.format(new Date()) +"] count: " + count.get() + ", error: " + error.get() + ",tps:"+(c/elapsd)); - - bfirst = false; - lastCount = count.get(); - Thread.sleep(sleepTime); - } - } catch(Exception e) { - e.printStackTrace(); - } - } - }).start(); - - latch.await(); - - for(ExchangeClient client:exchangeClients){ - if(client.isConnected()){ - client.close(); - } - } - - long total = count.get(); - long failed = error.get(); - long succeeded = total - failed; - long elapsed = time.get(); - long allElapsed = all.get(); - long clientElapsed = allElapsed - elapsed; - long art = 0; - long qps = 0; - long throughput = 0; - if (elapsed > 0) { - art = elapsed / succeeded; - qps = concurrent * succeeded * 1000 / elapsed; - throughput = concurrent * succeeded * length * 2 * 1000 / elapsed; - } - - PerformanceUtils.printBorder(); - PerformanceUtils.printHeader("Dubbo Remoting Performance Test Report"); - PerformanceUtils.printBorder(); - PerformanceUtils.printHeader("Test Environment"); - PerformanceUtils.printSeparator(); - for (String item: serverEnvironment) { - PerformanceUtils.printBody("Server " + item); - } - PerformanceUtils.printSeparator(); - List clientEnvironment = PerformanceUtils.getEnvironment(); - for (String item: clientEnvironment) { - PerformanceUtils.printBody("Client " + item); - } - PerformanceUtils.printSeparator(); - PerformanceUtils.printHeader("Test Scene"); - PerformanceUtils.printSeparator(); - for (String item: serverScene) { - PerformanceUtils.printBody("Server " + item); - } - PerformanceUtils.printBody("Client Transporter: " + transporter); - PerformanceUtils.printBody("Serialization: " + serialization); - PerformanceUtils.printBody("Response Timeout: " + timeout + " ms"); - PerformanceUtils.printBody("Data Length: " + length + " bytes"); - PerformanceUtils.printBody("Client Shared Connections: " + connections); - PerformanceUtils.printBody("Client Concurrent Threads: " + concurrent); - PerformanceUtils.printBody("Run Times Per Thread: " + runs); - PerformanceUtils.printSeparator(); - PerformanceUtils.printHeader("Test Result"); - PerformanceUtils.printSeparator(); - PerformanceUtils.printBody("Succeeded Requests: " + DecimalFormat.getIntegerInstance().format(succeeded)); - PerformanceUtils.printBody("Failed Requests: " + failed); - PerformanceUtils.printBody("Client Elapsed Time: " + clientElapsed + " ms"); - PerformanceUtils.printBody("Average Response Time: " + art + " ms"); - PerformanceUtils.printBody("Requests Per Second: " + qps + "/s"); - PerformanceUtils.printBody("Throughput Per Second: " + DecimalFormat.getIntegerInstance().format(throughput) + " bytes/s"); - PerformanceUtils.printBorder(); - } - - static class PeformanceTestHandler extends ExchangeHandlerAdapter{ - - public void connected(Channel channel) throws RemotingException { - System.out.println("connected event,chanel;"+channel); - } - - public void disconnected(Channel channel) throws RemotingException { - System.out.println("disconnected event,chanel;"+channel); - } - } -} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceServerTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceServerTest.java index b829cd1ce64..36fe74c223d 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceServerTest.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/PerformanceServerTest.java @@ -18,6 +18,8 @@ import java.util.ArrayList; import java.util.List; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import junit.framework.TestCase; import org.junit.Test; diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/RpcMessage.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/RpcMessage.java index 8ab2c36a8f0..0292b05b269 100755 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/RpcMessage.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/RpcMessage.java @@ -19,47 +19,42 @@ /** * RpcMessage. - * + * * @author qian.lei */ -public class RpcMessage implements Serializable -{ - private static final long serialVersionUID = -5148079121106659095L; +public class RpcMessage implements Serializable { + private static final long serialVersionUID = -5148079121106659095L; - private String mClassName; + private String mClassName; - private String mMethodDesc; + private String mMethodDesc; - private Class[] mParameterTypes; + private Class[] mParameterTypes; - private Object[] mArguments; + private Object[] mArguments; - public RpcMessage(String cn, String desc, Class[] parameterTypes,Object[] args) - { - mClassName = cn; - mMethodDesc = desc; - mParameterTypes = parameterTypes; - mArguments = args; - } + public RpcMessage(String cn, String desc, Class[] parameterTypes, Object[] args) { + mClassName = cn; + mMethodDesc = desc; + mParameterTypes = parameterTypes; + mArguments = args; + } - public String getClassName() - { - return mClassName; - } + public String getClassName() { + return mClassName; + } - public String getMethodDesc() - { - return mMethodDesc; - } + public String getMethodDesc() { + return mMethodDesc; + } - public Class[] getParameterTypes() { - return mParameterTypes; - } + public Class[] getParameterTypes() { + return mParameterTypes; + } - public Object[] getArguments() - { - return mArguments; - } + public Object[] getArguments() { + return mArguments; + } } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/RpcMessageHandler.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/RpcMessageHandler.java index 0a12593856a..788d6ec79c7 100755 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/RpcMessageHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/RpcMessageHandler.java @@ -19,6 +19,7 @@ import com.alibaba.dubbo.common.bytecode.NoSuchMethodException; import com.alibaba.dubbo.common.bytecode.Wrapper; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.support.Replier; diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/TelnetServer.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/TelnetServer.java index 637c9cec374..917de6f567f 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/TelnetServer.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/TelnetServer.java @@ -15,6 +15,8 @@ */ package com.alibaba.dubbo.remoting; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.ChannelHandlerAdapter; /** diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/AbstractMockChannel.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/AbstractMockChannel.java index 325a50c9555..46837a561d1 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/AbstractMockChannel.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/AbstractMockChannel.java @@ -1,18 +1,18 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.codec; import java.net.InetSocketAddress; @@ -21,9 +21,9 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * @author chao.liuc diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/ExchangeCodecTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/ExchangeCodecTest.java index 14500fed791..93347bb305f 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/ExchangeCodecTest.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/ExchangeCodecTest.java @@ -16,70 +16,68 @@ package com.alibaba.dubbo.remoting.codec; -import java.io.ByteArrayOutputStream; -import java.io.IOException; -import java.util.Date; -import java.util.HashMap; - -import org.junit.Before; -import org.junit.Test; - import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.extension.ExtensionLoader; import com.alibaba.dubbo.common.io.Bytes; import com.alibaba.dubbo.common.io.UnsafeByteArrayOutputStream; import com.alibaba.dubbo.common.serialize.ObjectOutput; import com.alibaba.dubbo.common.serialize.Serialization; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; import com.alibaba.dubbo.remoting.buffer.ChannelBuffers; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; import com.alibaba.dubbo.remoting.exchange.codec.ExchangeCodec; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; import com.alibaba.dubbo.remoting.telnet.codec.TelnetCodec; - import junit.framework.Assert; +import org.junit.Before; +import org.junit.Test; + +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.util.Date; +import java.util.HashMap; + import static org.junit.Assert.fail; /** * @author chao.liuc - * byte 16 - * 0-1 magic code - * 2 flag - * 8 - 1-request/0-response - * 7 - two way - * 6 - heartbeat - * 1-5 serialization id - * 3 status - * 20 ok - * 90 error? - * 4-11 id (long) - * 12 -15 datalength - * + * byte 16 + * 0-1 magic code + * 2 flag + * 8 - 1-request/0-response + * 7 - two way + * 6 - heartbeat + * 1-5 serialization id + * 3 status + * 20 ok + * 90 error? + * 4-11 id (long) + * 12 -15 datalength */ -public class ExchangeCodecTest extends TelnetCodecTest{ +public class ExchangeCodecTest extends TelnetCodecTest { // magic header. - private static final short MAGIC = (short) 0xdabb; - private static final byte MAGIC_HIGH = (byte) Bytes.short2bytes(MAGIC)[0]; - private static final byte MAGIC_LOW = (byte) Bytes.short2bytes(MAGIC)[1]; + private static final short MAGIC = (short) 0xdabb; + private static final byte MAGIC_HIGH = (byte) Bytes.short2bytes(MAGIC)[0]; + private static final byte MAGIC_LOW = (byte) Bytes.short2bytes(MAGIC)[1]; Serialization serialization = getSerialization(Constants.DEFAULT_REMOTING_SERIALIZATION); - - - private Object decode(byte[] request) throws IOException{ + + private Object decode(byte[] request) throws IOException { ChannelBuffer buffer = ChannelBuffers.wrappedBuffer(request); AbstractMockChannel channel = getServerSideChannel(url); //decode Object obj = codec.decode(channel, buffer); return obj; } - - private byte[] getRequestBytes(Object obj, byte[] header) throws IOException{ + + private byte[] getRequestBytes(Object obj, byte[] header) throws IOException { // encode request data. UnsafeByteArrayOutputStream bos = new UnsafeByteArrayOutputStream(1024); ObjectOutput out = serialization.serialize(url, bos); out.writeObject(obj); - + out.flushBuffer(); bos.flush(); bos.close(); @@ -89,60 +87,62 @@ private byte[] getRequestBytes(Object obj, byte[] header) throws IOException{ byte[] request = join(header, data); return request; } - - private byte[] assemblyDataProtocol(byte[] header){ + + private byte[] assemblyDataProtocol(byte[] header) { Person request = new Person(); byte[] newbuf = join(header, objectToByte(request)); return newbuf; } - + private static Serialization getSerialization(String name) { Serialization serialization = ExtensionLoader.getExtensionLoader(Serialization.class).getExtension(name); return serialization; } //=================================================================================== - + @Before public void setUp() throws Exception { codec = new ExchangeCodec(); } + @Test - public void test_Decode_Error_MagicNum() throws IOException{ - HashMap inputBytes = new HashMap(); - inputBytes.put( new byte[] { 0 }, TelnetCodec.DecodeResult.NEED_MORE_INPUT ); - inputBytes.put( new byte[] { MAGIC_HIGH, 0 }, TelnetCodec.DecodeResult.NEED_MORE_INPUT ); - inputBytes.put( new byte[] { 0 , MAGIC_LOW }, TelnetCodec.DecodeResult.NEED_MORE_INPUT ); - - for (byte[] input : inputBytes.keySet()){ - testDecode_assertEquals(assemblyDataProtocol(input) ,inputBytes.get(input)); + public void test_Decode_Error_MagicNum() throws IOException { + HashMap inputBytes = new HashMap(); + inputBytes.put(new byte[]{0}, TelnetCodec.DecodeResult.NEED_MORE_INPUT); + inputBytes.put(new byte[]{MAGIC_HIGH, 0}, TelnetCodec.DecodeResult.NEED_MORE_INPUT); + inputBytes.put(new byte[]{0, MAGIC_LOW}, TelnetCodec.DecodeResult.NEED_MORE_INPUT); + + for (byte[] input : inputBytes.keySet()) { + testDecode_assertEquals(assemblyDataProtocol(input), inputBytes.get(input)); } } - + @Test - public void test_Decode_Error_Length() throws IOException{ - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, 0x20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + public void test_Decode_Error_Length() throws IOException { + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, 0x20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; Person person = new Person(); byte[] request = getRequestBytes(person, header); - + Channel channel = getServerSideChannel(url); - byte[] baddata = new byte[]{1,2}; + byte[] baddata = new byte[]{1, 2}; ChannelBuffer buffer = ChannelBuffers.wrappedBuffer(join(request, baddata)); - Response obj = (Response)codec.decode(channel, buffer); + Response obj = (Response) codec.decode(channel, buffer); Assert.assertEquals(person, obj.getResult()); //only decode necessary bytes Assert.assertEquals(request.length, buffer.readerIndex()); } + @Test - public void test_Decode_Error_Response_Object() throws IOException{ + public void test_Decode_Error_Response_Object() throws IOException { //00000010-response/oneway/hearbeat=true |20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, 0x20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, 0x20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; Person person = new Person(); byte[] request = getRequestBytes(person, header); //bad object - byte[] badbytes = new byte[]{-1,-2,-3,-4,-3,-4,-3,-4,-3,-4,-3,-4}; + byte[] badbytes = new byte[]{-1, -2, -3, -4, -3, -4, -3, -4, -3, -4, -3, -4}; System.arraycopy(badbytes, 0, request, 21, badbytes.length); - - Response obj = (Response)decode(request); + + Response obj = (Response) decode(request); Assert.assertEquals(90, obj.getStatus()); } @@ -157,22 +157,24 @@ public void test_Decode_Check_Payload() throws IOException { Assert.assertTrue(expected.getMessage().startsWith("Data length too large: " + Bytes.bytes2int(new byte[]{1, 1, 1, 1}))); } } + @Test - public void test_Decode_Header_Need_Readmore() throws IOException{ - byte[] header = new byte[] { MAGIC_HIGH , MAGIC_LOW , 0 ,0 ,0 ,0 ,0 , 0 ,0 ,0 ,0 }; + public void test_Decode_Header_Need_Readmore() throws IOException { + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, 0, 0, 0, 0, 0, 0, 0, 0, 0}; testDecode_assertEquals(header, TelnetCodec.DecodeResult.NEED_MORE_INPUT); } - + @Test - public void test_Decode_Body_Need_Readmore() throws IOException{ - byte[] header = new byte[] { MAGIC_HIGH , MAGIC_LOW , 0 ,0 ,0 ,0 ,0 , 0 ,0 ,0 ,0, 0, 0, 0 , 1 ,1, 'a', 'a' }; + public void test_Decode_Body_Need_Readmore() throws IOException { + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 'a', 'a'}; testDecode_assertEquals(header, TelnetCodec.DecodeResult.NEED_MORE_INPUT); } + @Test - public void test_Decode_MigicCodec_Contain_ExchangeHeader() throws IOException{ + public void test_Decode_MigicCodec_Contain_ExchangeHeader() throws IOException { // - byte[] header = new byte[] { 0, 0, MAGIC_HIGH , MAGIC_LOW , 0 ,0 ,0 ,0 ,0 , 0 ,0 ,0 ,0 }; - + byte[] header = new byte[]{0, 0, MAGIC_HIGH, MAGIC_LOW, 0, 0, 0, 0, 0, 0, 0, 0, 0}; + Channel channel = getServerSideChannel(url); ChannelBuffer buffer = ChannelBuffers.wrappedBuffer(header); Object obj = codec.decode(channel, buffer); @@ -180,203 +182,200 @@ public void test_Decode_MigicCodec_Contain_ExchangeHeader() throws IOException{ //如果telnet数据与request数据在同一个数据包中,不能因为telnet没有结尾字符而影响其他数据的接收. Assert.assertEquals(2, buffer.readerIndex()); } - + @Test - public void test_Decode_Return_Response_Person() throws IOException{ + public void test_Decode_Return_Response_Person() throws IOException { //00000010-response/oneway/hearbeat=false/hessian |20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, 2, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, 2, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; Person person = new Person(); byte[] request = getRequestBytes(person, header); - - Response obj = (Response)decode(request); + + Response obj = (Response) decode(request); Assert.assertEquals(20, obj.getStatus()); Assert.assertEquals(person, obj.getResult()); System.out.println(obj); } - + @Test //status输入有问题,序列化时读取信息出错. - public void test_Decode_Return_Response_Error() throws IOException{ - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, 2, 90, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + public void test_Decode_Return_Response_Error() throws IOException { + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, 2, 90, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; String errorString = "encode request data error "; byte[] request = getRequestBytes(errorString, header); - Response obj = (Response)decode(request); + Response obj = (Response) decode(request); Assert.assertEquals(90, obj.getStatus()); Assert.assertEquals(errorString, obj.getErrorMessage()); } + @Test - public void test_Decode_Return_Request_Event_Object() throws IOException{ + public void test_Decode_Return_Request_Event_Object() throws IOException { //|10011111|20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, (byte) 0xff, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, (byte) 0xff, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; Person person = new Person(); byte[] request = getRequestBytes(person, header); - - Request obj = (Request)decode(request); + + Request obj = (Request) decode(request); Assert.assertEquals(person, obj.getData()); Assert.assertEquals(true, obj.isTwoWay()); Assert.assertEquals(true, obj.isEvent()); Assert.assertEquals("2.0.0", obj.getVersion()); System.out.println(obj); } - + @Test - public void test_Decode_Return_Request_Event_String() throws IOException{ + public void test_Decode_Return_Request_Event_String() throws IOException { //|10011111|20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, (byte) 0xff, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, (byte) 0xff, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; String event = Request.READONLY_EVENT; byte[] request = getRequestBytes(event, header); - - Request obj = (Request)decode(request); + + Request obj = (Request) decode(request); Assert.assertEquals(event, obj.getData()); Assert.assertEquals(true, obj.isTwoWay()); Assert.assertEquals(true, obj.isEvent()); Assert.assertEquals("2.0.0", obj.getVersion()); System.out.println(obj); } - + @Test - public void test_Decode_Return_Request_Heartbeat_Object() throws IOException{ + public void test_Decode_Return_Request_Heartbeat_Object() throws IOException { //|10011111|20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, (byte) 0xff, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, (byte) 0xff, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; byte[] request = getRequestBytes(null, header); - Request obj = (Request)decode(request); + Request obj = (Request) decode(request); Assert.assertEquals(null, obj.getData()); Assert.assertEquals(true, obj.isTwoWay()); Assert.assertEquals(true, obj.isHeartbeat()); Assert.assertEquals("2.0.0", obj.getVersion()); System.out.println(obj); } - + @Test - public void test_Decode_Return_Request_Object() throws IOException{ + public void test_Decode_Return_Request_Object() throws IOException { //|10011111|20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, (byte) 0xdf, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, (byte) 0xdf, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; Person person = new Person(); byte[] request = getRequestBytes(person, header); - - Request obj = (Request)decode(request); + + Request obj = (Request) decode(request); Assert.assertEquals(person, obj.getData()); Assert.assertEquals(true, obj.isTwoWay()); Assert.assertEquals(false, obj.isHeartbeat()); Assert.assertEquals("2.0.0", obj.getVersion()); System.out.println(obj); } - - @Test - public void test_Decode_Error_Request_Object() throws IOException{ - //00000010-response/oneway/hearbeat=true |20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, (byte)0xdf, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + + @Test + public void test_Decode_Error_Request_Object() throws IOException { + //00000010-response/oneway/hearbeat=true |20-stats=ok|id=0|length=0 + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, (byte) 0xdf, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; Person person = new Person(); byte[] request = getRequestBytes(person, header); //bad object - byte[] badbytes = new byte[]{-1,-2,-3,-4,-3,-4,-3,-4,-3,-4,-3,-4}; + byte[] badbytes = new byte[]{-1, -2, -3, -4, -3, -4, -3, -4, -3, -4, -3, -4}; System.arraycopy(badbytes, 0, request, 21, badbytes.length); - - Request obj = (Request)decode(request); + + Request obj = (Request) decode(request); Assert.assertEquals(true, obj.isBroken()); Assert.assertEquals(true, obj.getData() instanceof Throwable); } - + @Test - public void test_Header_Response_NoSerializationFlag() throws IOException{ - //00000010-response/oneway/hearbeat=false/noset |20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, 0, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + public void test_Header_Response_NoSerializationFlag() throws IOException { + //00000010-response/oneway/hearbeat=false/noset |20-stats=ok|id=0|length=0 + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, 0, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; Person person = new Person(); byte[] request = getRequestBytes(person, header); - - Response obj = (Response)decode(request); + + Response obj = (Response) decode(request); Assert.assertEquals(20, obj.getStatus()); Assert.assertEquals(person, obj.getResult()); System.out.println(obj); } - + @Test - public void test_Header_Response_Heartbeat() throws IOException{ - //00000010-response/oneway/hearbeat=true |20-stats=ok|id=0|length=0 - byte[] header = new byte[] { MAGIC_HIGH, MAGIC_LOW, 0x20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + public void test_Header_Response_Heartbeat() throws IOException { + //00000010-response/oneway/hearbeat=true |20-stats=ok|id=0|length=0 + byte[] header = new byte[]{MAGIC_HIGH, MAGIC_LOW, 0x20, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; Person person = new Person(); byte[] request = getRequestBytes(person, header); - - Response obj = (Response)decode(request); + + Response obj = (Response) decode(request); Assert.assertEquals(20, obj.getStatus()); Assert.assertEquals(person, obj.getResult()); System.out.println(obj); } - - @Test - public void test_Encode_Request() throws IOException{ + + @Test + public void test_Encode_Request() throws IOException { ChannelBuffer encodeBuffer = ChannelBuffers.dynamicBuffer(2014); Channel channel = getCliendSideChannel(url); - Request request = new Request(); + Person person = new Person(); - request.setData(person); - + Request.Builder builder = new Request.Builder(); + builder.newId().version(Version.getVersion()).data(person); + final Request request = builder.build(); codec.encode(channel, encodeBuffer, request); //encode resault check need decode byte[] data = new byte[encodeBuffer.writerIndex()]; encodeBuffer.readBytes(data); ChannelBuffer decodeBuffer = ChannelBuffers.wrappedBuffer(data); - Request obj = (Request)codec.decode(channel, decodeBuffer); + Request obj = (Request) codec.decode(channel, decodeBuffer); Assert.assertEquals(request.isBroken(), obj.isBroken()); Assert.assertEquals(request.isHeartbeat(), obj.isHeartbeat()); Assert.assertEquals(request.isTwoWay(), obj.isTwoWay()); Assert.assertEquals(person, obj.getData()); } - - @Test - public void test_Encode_Response() throws IOException{ + + @Test + public void test_Encode_Response() throws IOException { ChannelBuffer encodeBuffer = ChannelBuffers.dynamicBuffer(1024); Channel channel = getCliendSideChannel(url); - Response response = new Response(); - response.setHeartbeat(true); - response.setId(1001l); - response.setStatus((byte)20 ); - response.setVersion("11"); Person person = new Person(); - response.setResult(person); - + Response response = new Response.Builder(1001l). + isEvent(true). + status((byte) 20). + version("11"). + result(person).build(); codec.encode(channel, encodeBuffer, response); byte[] data = new byte[encodeBuffer.writerIndex()]; encodeBuffer.readBytes(data); //encode resault check need decode ChannelBuffer decodeBuffer = ChannelBuffers.wrappedBuffer(data); - Response obj = (Response)codec.decode(channel, decodeBuffer); - + Response obj = (Response) codec.decode(channel, decodeBuffer); + Assert.assertEquals(response.getId(), obj.getId()); Assert.assertEquals(response.getStatus(), obj.getStatus()); Assert.assertEquals(response.isHeartbeat(), obj.isHeartbeat()); Assert.assertEquals(person, obj.getResult()); // encode response verson ?? // Assert.assertEquals(response.getVersion(), obj.getVersion()); - + } - - @Test - public void test_Encode_Error_Response() throws IOException{ + + @Test + public void test_Encode_Error_Response() throws IOException { ChannelBuffer encodeBuffer = ChannelBuffers.dynamicBuffer(1024); Channel channel = getCliendSideChannel(url); - Response response = new Response(); - response.setHeartbeat(true); - response.setId(1001l); - response.setStatus((byte)10 ); - response.setVersion("11"); - String badString = "bad" ; - response.setErrorMessage(badString); Person person = new Person(); - response.setResult(person); - + Response response = new Response.Builder(1001l). + isEvent(true). + status((byte) 10). + version("11"). + result(person). + errorMsg("bad").build(); codec.encode(channel, encodeBuffer, response); byte[] data = new byte[encodeBuffer.writerIndex()]; encodeBuffer.readBytes(data); //encode resault check need decode ChannelBuffer decodeBuffer = ChannelBuffers.wrappedBuffer(data); - Response obj = (Response)codec.decode(channel, decodeBuffer); + Response obj = (Response) codec.decode(channel, decodeBuffer); Assert.assertEquals(response.getId(), obj.getId()); Assert.assertEquals(response.getStatus(), obj.getStatus()); Assert.assertEquals(response.isHeartbeat(), obj.isHeartbeat()); - Assert.assertEquals(badString, obj.getErrorMessage()); + Assert.assertEquals("bad", obj.getErrorMessage()); Assert.assertEquals(null, obj.getResult()); // Assert.assertEquals(response.getVersion(), obj.getVersion()); } @@ -385,10 +384,10 @@ public void test_Encode_Error_Response() throws IOException{ @Test public void testMessageLengthGreaterThanMessageActualLength() throws Exception { Channel channel = getCliendSideChannel(url); - Request request = new Request(1L); - request.setVersion("2.0.0"); Date date = new Date(); - request.setData(date); + Request.Builder builder = new Request.Builder(); + builder.newId().version(Version.getVersion()).data(date); + final Request request = builder.build(); ChannelBuffer encodeBuffer = ChannelBuffers.dynamicBuffer(1024); codec.encode(channel, encodeBuffer, request); byte[] bytes = new byte[encodeBuffer.writerIndex()]; @@ -403,23 +402,24 @@ public void testMessageLengthGreaterThanMessageActualLength() throws Exception { int padding = 512; out.write(Bytes.int2bytes(len + padding)); out.write(bytes, 16, bytes.length - 16); - for(int i = 0; i < padding; i++) { + for (int i = 0; i < padding; i++) { out.write(1); } out.write(bytes); /* request|1111...|request */ ChannelBuffer decodeBuffer = ChannelBuffers.wrappedBuffer(out.toByteArray()); - Request decodedRequest = (Request)codec.decode(channel, decodeBuffer); + Request decodedRequest = (Request) codec.decode(channel, decodeBuffer); Assert.assertTrue(date.equals(decodedRequest.getData())); Assert.assertEquals(bytes.length + padding, decodeBuffer.readerIndex()); - decodedRequest = (Request)codec.decode(channel, decodeBuffer); + decodedRequest = (Request) codec.decode(channel, decodeBuffer); Assert.assertTrue(date.equals(decodedRequest.getData())); } @Test public void testMessageLengthExceedPayloadLimitWhenEncode() throws Exception { - Request request = new Request(1L); - request.setData("hello"); + Request.Builder builder = new Request.Builder(); + builder.newId().version(Version.getVersion()).data("hello"); + final Request request = builder.build(); ChannelBuffer encodeBuffer = ChannelBuffers.dynamicBuffer(512); AbstractMockChannel channel = getCliendSideChannel(url.addParameter(Constants.PAYLOAD_KEY, 4)); try { @@ -429,8 +429,7 @@ public void testMessageLengthExceedPayloadLimitWhenEncode() throws Exception { Assert.assertTrue(e.getMessage().startsWith("Data length too large: " + 6)); } - Response response = new Response(1L); - response.setResult("hello"); + Response response = new Response.Builder(1L).result("hello").build(); encodeBuffer = ChannelBuffers.dynamicBuffer(512); channel = getServerSideChannel(url.addParameter(Constants.PAYLOAD_KEY, 4)); codec.encode(channel, encodeBuffer, response); diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/TelnetCodecTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/TelnetCodecTest.java index e3de9d3de87..b2e23a38591 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/TelnetCodecTest.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/codec/TelnetCodecTest.java @@ -28,7 +28,7 @@ import org.junit.Test; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec2; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; import com.alibaba.dubbo.remoting.buffer.ChannelBuffers; diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartBeatTaskTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartBeatTaskTest.java index 2c963a1ac0d..744edff5312 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartBeatTaskTest.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartBeatTaskTest.java @@ -18,8 +18,8 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.exchange.Request; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.message.Request; import org.junit.Assert; import org.junit.Before; import org.junit.Test; diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/MockChannel.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/MockChannel.java index 4f00c6b588b..ac335627dd0 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/MockChannel.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/MockChannel.java @@ -17,9 +17,9 @@ package com.alibaba.dubbo.remoting.exchange.support.header; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import java.net.InetSocketAddress; import java.util.ArrayList; diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/ConnectChannelHandlerTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/ConnectChannelHandlerTest.java index 3155ecb50d9..3cc9e6e7b19 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/ConnectChannelHandlerTest.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/ConnectChannelHandlerTest.java @@ -15,121 +15,125 @@ */ package com.alibaba.dubbo.remoting.handler; -import java.util.concurrent.ThreadPoolExecutor; -import java.util.concurrent.atomic.AtomicInteger; - +import com.alibaba.dubbo.common.Version; +import com.alibaba.dubbo.remoting.exception.ExecutionException; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.dispatcher.connection.ConnectionOrderedChannelHandler; import junit.framework.Assert; - import org.junit.Before; import org.junit.Ignore; import org.junit.Test; -import com.alibaba.dubbo.remoting.ExecutionException; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.remoting.transport.dispatcher.connection.ConnectionOrderedChannelHandler; - +import java.util.concurrent.ThreadPoolExecutor; +import java.util.concurrent.atomic.AtomicInteger; -public class ConnectChannelHandlerTest extends WrappedChannelHandlerTest{ +public class ConnectChannelHandlerTest extends WrappedChannelHandlerTest { @Before public void setUp() throws Exception { handler = new ConnectionOrderedChannelHandler(new BizChannelHander(true), url); } - + @Test - public void test_Connect_Blocked() throws RemotingException{ + public void test_Connect_Blocked() throws RemotingException { handler = new ConnectionOrderedChannelHandler(new BizChannelHander(false), url); - ThreadPoolExecutor executor = (ThreadPoolExecutor)getField(handler, "connectionExecutor", 1); + ThreadPoolExecutor executor = (ThreadPoolExecutor) getField(handler, "connectionExecutor", 1); Assert.assertEquals(1, executor.getMaximumPoolSize()); - + int runs = 20; int taskCount = runs * 2; - for(int i=0; i map = new HashMap(); public MockedChannel() { diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/MockedChannelHandler.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/MockedChannelHandler.java index 08744da1fc8..b3ad5fa383f 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/MockedChannelHandler.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/MockedChannelHandler.java @@ -1,27 +1,27 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.handler; import java.util.Collections; import java.util.Set; import com.alibaba.dubbo.common.utils.ConcurrentHashSet; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * @author chao.liuc diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/WrappedChannelHandlerTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/WrappedChannelHandlerTest.java index b086bf35377..54538be4b05 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/WrappedChannelHandlerTest.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/handler/WrappedChannelHandlerTest.java @@ -1,18 +1,18 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.handler; @@ -26,9 +26,9 @@ import org.junit.Test; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.transport.dispatcher.WrappedChannelHandler; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.dispatcher.WrappedChannelHandler; public class WrappedChannelHandlerTest { WrappedChannelHandler handler ; diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/AbstractCodecTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/AbstractCodecTest.java index e11070e0c6a..c00c053c89a 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/AbstractCodecTest.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/AbstractCodecTest.java @@ -18,7 +18,6 @@ import java.io.IOException; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; import junit.framework.TestCase; import static org.easymock.EasyMock.createMock; diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/CodecAdapterTest.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/CodecAdapterTest.java deleted file mode 100644 index 7852dde02e0..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/CodecAdapterTest.java +++ /dev/null @@ -1,29 +0,0 @@ -package com.alibaba.dubbo.remoting.transport.codec; - -import java.io.IOException; - -import org.junit.Before; -import org.junit.Test; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.io.UnsafeByteArrayInputStream; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.Codec; -import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; -import com.alibaba.dubbo.remoting.buffer.ChannelBuffers; -import com.alibaba.dubbo.remoting.codec.ExchangeCodecTest; -import com.alibaba.dubbo.remoting.telnet.codec.TelnetCodec; - -import junit.framework.Assert; - -/** - * @author kimi - */ -public class CodecAdapterTest extends ExchangeCodecTest { - - @Before - public void setUp() throws Exception { - codec = new CodecAdapter(new DeprecatedExchangeCodec()); - } - -} diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/DeprecatedExchangeCodec.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/DeprecatedExchangeCodec.java deleted file mode 100644 index 3c9b8b175a5..00000000000 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/DeprecatedExchangeCodec.java +++ /dev/null @@ -1,404 +0,0 @@ -package com.alibaba.dubbo.remoting.transport.codec; - -import java.io.IOException; -import java.io.InputStream; -import java.io.OutputStream; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.io.Bytes; -import com.alibaba.dubbo.common.io.StreamUtils; -import com.alibaba.dubbo.common.io.UnsafeByteArrayInputStream; -import com.alibaba.dubbo.common.io.UnsafeByteArrayOutputStream; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.serialize.ObjectInput; -import com.alibaba.dubbo.common.serialize.ObjectOutput; -import com.alibaba.dubbo.common.serialize.Serialization; -import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.Codec; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.remoting.exchange.support.DefaultFuture; -import com.alibaba.dubbo.remoting.transport.CodecSupport; - -/** - * @author kimi - */ -final class DeprecatedExchangeCodec extends DeprecatedTelnetCodec implements Codec { - - private static final Logger logger = LoggerFactory.getLogger(DeprecatedExchangeCodec.class); - - // header length. - protected static final int HEADER_LENGTH = 16; - - // magic header. - protected static final short MAGIC = (short) 0xdabb; - - protected static final byte MAGIC_HIGH = Bytes.short2bytes(MAGIC)[0]; - - protected static final byte MAGIC_LOW = Bytes.short2bytes(MAGIC)[1]; - - // message flag. - protected static final byte FLAG_REQUEST = (byte) 0x80; - - protected static final byte FLAG_TWOWAY = (byte) 0x40; - - protected static final byte FLAG_EVENT = (byte) 0x20; - - protected static final int SERIALIZATION_MASK = 0x1f; - - public Short getMagicCode() { - return MAGIC; - } - - public void encode(Channel channel, OutputStream os, Object msg) throws IOException { - if (msg instanceof Request) { - encodeRequest(channel, os, (Request) msg); - } else if (msg instanceof Response) { - encodeResponse(channel, os, (Response) msg); - } else { - super.encode(channel, os, msg); - } - } - - public Object decode(Channel channel, InputStream is) throws IOException { - int readable = is.available(); - byte[] header = new byte[Math.min(readable, HEADER_LENGTH)]; - is.read(header); - return decode(channel, is, readable, header); - } - - protected Object decode(Channel channel, InputStream is, int readable, byte[] header) throws IOException { - // check magic number. - if (readable > 0 && header[0] != MAGIC_HIGH - || readable > 1 && header[1] != MAGIC_LOW) { - int length = header.length; - if (header.length < readable) { - header = Bytes.copyOf(header, readable); - is.read(header, length, readable - length); - } - for (int i = 1; i < header.length - 1; i++) { - if (header[i] == MAGIC_HIGH && header[i + 1] == MAGIC_LOW) { - UnsafeByteArrayInputStream bis = ((UnsafeByteArrayInputStream) is); - bis.position(bis.position() - header.length + i); - header = Bytes.copyOf(header, i); - break; - } - } - return super.decode(channel, is, readable, header); - } - // check length. - if (readable < HEADER_LENGTH) { - return NEED_MORE_INPUT; - } - - // get data length. - int len = Bytes.bytes2int(header, 12); - checkPayload(channel, len); - - int tt = len + HEADER_LENGTH; - if (readable < tt) { - return NEED_MORE_INPUT; - } - - // limit input stream. - if (readable != tt) - is = StreamUtils.limitedInputStream(is, len); - - try { - return decodeBody(channel, is, header); - } finally { - if (is.available() > 0) { - try { - if (logger.isWarnEnabled()) { - logger.warn("Skip input stream " + is.available()); - } - StreamUtils.skipUnusedStream(is); - } catch (IOException e) { - logger.warn(e.getMessage(), e); - } - } - } - } - - protected Object decodeBody(Channel channel, InputStream is, byte[] header) throws IOException { - byte flag = header[2], proto = (byte) (flag & SERIALIZATION_MASK); - Serialization s = CodecSupport.getSerialization(channel.getUrl(), proto); - ObjectInput in = s.deserialize(channel.getUrl(), is); - // get request id. - long id = Bytes.bytes2long(header, 4); - if ((flag & FLAG_REQUEST) == 0) { - // decode response. - Response res = new Response(id); - if ((flag & FLAG_EVENT) != 0) { - res.setEvent(Response.HEARTBEAT_EVENT); - } - // get status. - byte status = header[3]; - res.setStatus(status); - if (status == Response.OK) { - try { - Object data; - if (res.isHeartbeat()) { - data = decodeHeartbeatData(channel, in); - } else if (res.isEvent()) { - data = decodeEventData(channel, in); - } else { - data = decodeResponseData(channel, in, getRequestData(id)); - } - res.setResult(data); - } catch (Throwable t) { - res.setStatus(Response.CLIENT_ERROR); - res.setErrorMessage(StringUtils.toString(t)); - } - } else { - res.setErrorMessage(in.readUTF()); - } - return res; - } else { - // decode request. - Request req = new Request(id); - req.setVersion("2.0.0"); - req.setTwoWay((flag & FLAG_TWOWAY) != 0); - if ((flag & FLAG_EVENT) != 0) { - req.setEvent(Request.HEARTBEAT_EVENT); - } - try { - Object data; - if (req.isHeartbeat()) { - data = decodeHeartbeatData(channel, in); - } else if (req.isEvent()) { - data = decodeEventData(channel, in); - } else { - data = decodeRequestData(channel, in); - } - req.setData(data); - } catch (Throwable t) { - // bad request - req.setBroken(true); - req.setData(t); - } - return req; - } - } - - protected Object getRequestData(long id) { - DefaultFuture future = DefaultFuture.getFuture(id); - if (future == null) - return null; - Request req = future.getRequest(); - if (req == null) - return null; - return req.getData(); - } - - protected void encodeRequest(Channel channel, OutputStream os, Request req) throws IOException { - Serialization serialization = CodecSupport.getSerialization(channel.getUrl()); - // header. - byte[] header = new byte[HEADER_LENGTH]; - // set magic number. - Bytes.short2bytes(MAGIC, header); - - // set request and serialization flag. - header[2] = (byte) (FLAG_REQUEST | serialization.getContentTypeId()); - - if (req.isTwoWay()) header[2] |= FLAG_TWOWAY; - if (req.isEvent()) header[2] |= FLAG_EVENT; - - // set request id. - Bytes.long2bytes(req.getId(), header, 4); - - // encode request data. - UnsafeByteArrayOutputStream bos = new UnsafeByteArrayOutputStream(1024); - ObjectOutput out = serialization.serialize(channel.getUrl(), bos); - if (req.isEvent()) { - encodeEventData(channel, out, req.getData()); - } else { - encodeRequestData(channel, out, req.getData()); - } - out.flushBuffer(); - bos.flush(); - bos.close(); - byte[] data = bos.toByteArray(); - checkPayload(channel, data.length); - Bytes.int2bytes(data.length, header, 12); - - // write - os.write(header); // write header. - os.write(data); // write data. - } - - protected void encodeResponse(Channel channel, OutputStream os, Response res) throws IOException { - try { - Serialization serialization = CodecSupport.getSerialization(channel.getUrl()); - // header. - byte[] header = new byte[HEADER_LENGTH]; - // set magic number. - Bytes.short2bytes(MAGIC, header); - // set request and serialization flag. - header[2] = serialization.getContentTypeId(); - if (res.isHeartbeat()) header[2] |= FLAG_EVENT; - // set response status. - byte status = res.getStatus(); - header[3] = status; - // set request id. - Bytes.long2bytes(res.getId(), header, 4); - - UnsafeByteArrayOutputStream bos = new UnsafeByteArrayOutputStream(1024); - ObjectOutput out = serialization.serialize(channel.getUrl(), bos); - // encode response data or error message. - if (status == Response.OK) { - if (res.isHeartbeat()) { - encodeHeartbeatData(channel, out, res.getResult()); - } else { - encodeResponseData(channel, out, res.getResult()); - } - } else out.writeUTF(res.getErrorMessage()); - out.flushBuffer(); - bos.flush(); - bos.close(); - - byte[] data = bos.toByteArray(); - checkPayload(channel, data.length); - Bytes.int2bytes(data.length, header, 12); - // write - os.write(header); // write header. - os.write(data); // write data. - } catch (Throwable t) { - // 发送失败信息给Consumer,否则Consumer只能等超时了 - if (!res.isEvent() && res.getStatus() != Response.BAD_RESPONSE) { - try { - // FIXME 在Codec中打印出错日志?在IoHanndler的caught中统一处理? - logger.warn("Fail to encode response: " + res + ", send bad_response info instead, cause: " + t.getMessage(), t); - - Response r = new Response(res.getId(), res.getVersion()); - r.setStatus(Response.BAD_RESPONSE); - r.setErrorMessage("Failed to send response: " + res + ", cause: " + StringUtils.toString(t)); - channel.send(r); - - return; - } catch (RemotingException e) { - logger.warn("Failed to send bad_response info back: " + res + ", cause: " + e.getMessage(), e); - } - } - - // 重新抛出收到的异常 - if (t instanceof IOException) { - throw (IOException) t; - } else if (t instanceof RuntimeException) { - throw (RuntimeException) t; - } else if (t instanceof Error) { - throw (Error) t; - } else { - throw new RuntimeException(t.getMessage(), t); - } - } - } - - protected Object decodeData(ObjectInput in) throws IOException { - return decodeRequestData(in); - } - - @Deprecated - protected Object decodeHeartbeatData(ObjectInput in) throws IOException { - try { - return in.readObject(); - } catch (ClassNotFoundException e) { - throw new IOException(StringUtils.toString("Read object failed.", e)); - } - } - - protected Object decodeRequestData(ObjectInput in) throws IOException { - try { - return in.readObject(); - } catch (ClassNotFoundException e) { - throw new IOException(StringUtils.toString("Read object failed.", e)); - } - } - - protected Object decodeResponseData(ObjectInput in) throws IOException { - try { - return in.readObject(); - } catch (ClassNotFoundException e) { - throw new IOException(StringUtils.toString("Read object failed.", e)); - } - } - - protected void encodeData(ObjectOutput out, Object data) throws IOException { - encodeRequestData(out, data); - } - - private void encodeEventData(ObjectOutput out, Object data) throws IOException { - out.writeObject(data); - } - - @Deprecated - protected void encodeHeartbeatData(ObjectOutput out, Object data) throws IOException { - encodeEventData(out, data); - } - - protected void encodeRequestData(ObjectOutput out, Object data) throws IOException { - out.writeObject(data); - } - - protected void encodeResponseData(ObjectOutput out, Object data) throws IOException { - out.writeObject(data); - } - - protected Object decodeData(Channel channel, ObjectInput in) throws IOException { - return decodeRequestData(channel, in); - } - - protected Object decodeEventData(Channel channel, ObjectInput in) throws IOException { - try { - return in.readObject(); - } catch (ClassNotFoundException e) { - throw new IOException(StringUtils.toString("Read object failed.", e)); - } - } - - @Deprecated - protected Object decodeHeartbeatData(Channel channel, ObjectInput in) throws IOException { - try { - return in.readObject(); - } catch (ClassNotFoundException e) { - throw new IOException(StringUtils.toString("Read object failed.", e)); - } - } - - protected Object decodeRequestData(Channel channel, ObjectInput in) throws IOException { - return decodeRequestData(in); - } - - protected Object decodeResponseData(Channel channel, ObjectInput in) throws IOException { - return decodeResponseData(in); - } - - protected Object decodeResponseData(Channel channel, ObjectInput in, Object requestData) throws IOException { - return decodeResponseData(channel, in); - } - - protected void encodeData(Channel channel, ObjectOutput out, Object data) throws IOException { - encodeRequestData(channel, out, data); - } - - private void encodeEventData(Channel channel, ObjectOutput out, Object data) throws IOException { - encodeEventData(out, data); - } - - @Deprecated - protected void encodeHeartbeatData(Channel channel, ObjectOutput out, Object data) throws IOException { - encodeHeartbeatData(out, data); - } - - protected void encodeRequestData(Channel channel, ObjectOutput out, Object data) throws IOException { - encodeRequestData(out, data); - } - - protected void encodeResponseData(Channel channel, ObjectOutput out, Object data) throws IOException { - encodeResponseData(out, data); - } - -} diff --git a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/DeprecatedTelnetCodec.java b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/DeprecatedTelnetCodec.java index 74314cd3e18..0078778c83a 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/DeprecatedTelnetCodec.java +++ b/dubbo-remoting/dubbo-remoting-api/src/test/java/com/alibaba/dubbo/remoting/transport/codec/DeprecatedTelnetCodec.java @@ -17,10 +17,9 @@ import com.alibaba.dubbo.common.serialize.ObjectOutput; import com.alibaba.dubbo.common.utils.NetUtils; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.buffer.ChannelBufferOutputStream; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.CodecSupport; /** diff --git a/dubbo-remoting/dubbo-remoting-common/pom.xml b/dubbo-remoting/dubbo-remoting-common/pom.xml new file mode 100644 index 00000000000..52cd1e8a1d6 --- /dev/null +++ b/dubbo-remoting/dubbo-remoting-common/pom.xml @@ -0,0 +1,22 @@ + + + + dubbo-remoting + com.alibaba + 3.0.1 + + 4.0.0 + + dubbo-remoting-common + + + + com.alibaba + dubbo-common + 3.0.1 + + + + \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/ExecutionException.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/ExecutionException.java similarity index 95% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/ExecutionException.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/ExecutionException.java index 86963866a9f..379ae928ad4 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/ExecutionException.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/ExecutionException.java @@ -1,68 +1,70 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting; - -import java.net.InetSocketAddress; - -/** - * ReceiveException - * - * @author william.liangf - * @export - */ -public class ExecutionException extends RemotingException { - - private static final long serialVersionUID = -2531085236111056860L; - - private final Object request; - - public ExecutionException(Object request, Channel channel, String message, Throwable cause){ - super(channel, message, cause); - this.request = request; - } - - public ExecutionException(Object request, Channel channel, String msg){ - super(channel, msg); - this.request = request; - } - - public ExecutionException(Object request, Channel channel, Throwable cause){ - super(channel, cause); - this.request = request; - } - - public ExecutionException(Object request, InetSocketAddress localAddress, InetSocketAddress remoteAddress, String message, - Throwable cause){ - super(localAddress, remoteAddress, message, cause); - this.request = request; - } - - public ExecutionException(Object request, InetSocketAddress localAddress, InetSocketAddress remoteAddress, String message){ - super(localAddress, remoteAddress, message); - this.request = request; - } - - public ExecutionException(Object request, InetSocketAddress localAddress, InetSocketAddress remoteAddress, Throwable cause){ - super(localAddress, remoteAddress, cause); - this.request = request; - } - - - public Object getRequest() { - return request; - } - +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.alibaba.dubbo.remoting.exception; + +import com.alibaba.dubbo.remoting.transport.Channel; + +import java.net.InetSocketAddress; + +/** + * ReceiveException + * + * @author william.liangf + * @export + */ +public class ExecutionException extends RemotingException { + + private static final long serialVersionUID = -2531085236111056860L; + + private final Object request; + + public ExecutionException(Object request, Channel channel, String message, Throwable cause){ + super(channel, message, cause); + this.request = request; + } + + public ExecutionException(Object request, Channel channel, String msg){ + super(channel, msg); + this.request = request; + } + + public ExecutionException(Object request, Channel channel, Throwable cause){ + super(channel, cause); + this.request = request; + } + + public ExecutionException(Object request, InetSocketAddress localAddress, InetSocketAddress remoteAddress, String message, + Throwable cause){ + super(localAddress, remoteAddress, message, cause); + this.request = request; + } + + public ExecutionException(Object request, InetSocketAddress localAddress, InetSocketAddress remoteAddress, String message){ + super(localAddress, remoteAddress, message); + this.request = request; + } + + public ExecutionException(Object request, InetSocketAddress localAddress, InetSocketAddress remoteAddress, Throwable cause){ + super(localAddress, remoteAddress, cause); + this.request = request; + } + + + public Object getRequest() { + return request; + } + } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/RemotingException.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/RemotingException.java similarity index 69% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/RemotingException.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/RemotingException.java index ebdb50f5d87..de0adbfe737 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/RemotingException.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/RemotingException.java @@ -13,20 +13,15 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting; +package com.alibaba.dubbo.remoting.exception; + +import com.alibaba.dubbo.remoting.transport.Channel; import java.net.InetSocketAddress; /** * RemotingException. (API, Prototype, ThreadSafe) - * - * @see com.alibaba.dubbo.remoting.exchange.ResponseFuture#get() - * @see com.alibaba.dubbo.remoting.exchange.ResponseFuture#get(int) - * @see com.alibaba.dubbo.remoting.Channel#send(Object, boolean) - * @see com.alibaba.dubbo.remoting.exchange.ExchangeChannel#request(Object) - * @see com.alibaba.dubbo.remoting.exchange.ExchangeChannel#request(Object, int) - * @see com.alibaba.dubbo.remoting.Transporter#bind(com.alibaba.dubbo.common.URL, ChannelHandler) - * @see com.alibaba.dubbo.remoting.Transporter#connect(com.alibaba.dubbo.common.URL, ChannelHandler) + * * @author qian.lei * @export */ @@ -38,37 +33,37 @@ public class RemotingException extends Exception { private InetSocketAddress remoteAddress; - public RemotingException(Channel channel, String msg){ + public RemotingException(Channel channel, String msg) { this(channel == null ? null : channel.getLocalAddress(), channel == null ? null : channel.getRemoteAddress(), - msg); + msg); } - public RemotingException(InetSocketAddress localAddress, InetSocketAddress remoteAddress, String message){ + public RemotingException(InetSocketAddress localAddress, InetSocketAddress remoteAddress, String message) { super(message); this.localAddress = localAddress; this.remoteAddress = remoteAddress; } - public RemotingException(Channel channel, Throwable cause){ + public RemotingException(Channel channel, Throwable cause) { this(channel == null ? null : channel.getLocalAddress(), channel == null ? null : channel.getRemoteAddress(), - cause); + cause); } - public RemotingException(InetSocketAddress localAddress, InetSocketAddress remoteAddress, Throwable cause){ + public RemotingException(InetSocketAddress localAddress, InetSocketAddress remoteAddress, Throwable cause) { super(cause); this.localAddress = localAddress; this.remoteAddress = remoteAddress; } - public RemotingException(Channel channel, String message, Throwable cause){ + public RemotingException(Channel channel, String message, Throwable cause) { this(channel == null ? null : channel.getLocalAddress(), channel == null ? null : channel.getRemoteAddress(), - message, cause); + message, cause); } public RemotingException(InetSocketAddress localAddress, InetSocketAddress remoteAddress, String message, - Throwable cause){ + Throwable cause) { super(message, cause); this.localAddress = localAddress; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/TimeoutException.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/TimeoutException.java similarity index 64% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/TimeoutException.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/TimeoutException.java index f2ae4ed037d..054d7ecde33 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/TimeoutException.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/exception/TimeoutException.java @@ -13,49 +13,31 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting; +package com.alibaba.dubbo.remoting.exception; + +import com.alibaba.dubbo.remoting.transport.Channel; import java.net.InetSocketAddress; /** * TimeoutException. (API, Prototype, ThreadSafe) - * - * @see com.alibaba.dubbo.remoting.exchange.ResponseFuture#get() - * @see com.alibaba.dubbo.remoting.exchange.ResponseFuture#get(int) + * * @author qian.lei * @export + * @see com.alibaba.dubbo.remoting.exchange.ResponseFuture#get() + * @see com.alibaba.dubbo.remoting.exchange.ResponseFuture#get(int) */ public class TimeoutException extends RemotingException { private static final long serialVersionUID = 3122966731958222692L; - - public static final int CLIENT_SIDE = 0; - - public static final int SERVER_SIDE = 1; - - private final int phase; - public TimeoutException(boolean serverSide, Channel channel, String message){ + public TimeoutException(Channel channel, String message) { super(channel, message); - this.phase = serverSide ? SERVER_SIDE : CLIENT_SIDE; } - public TimeoutException(boolean serverSide, InetSocketAddress localAddress, + public TimeoutException(InetSocketAddress localAddress, InetSocketAddress remoteAddress, String message) { super(localAddress, remoteAddress, message); - this.phase = serverSide ? SERVER_SIDE : CLIENT_SIDE; - } - - public int getPhase() { - return phase; - } - - public boolean isServerSide() { - return phase == 1; - } - - public boolean isClientSide() { - return phase == 0; } } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Interceptor.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Interceptor.java new file mode 100644 index 00000000000..eec09cdf2a7 --- /dev/null +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Interceptor.java @@ -0,0 +1,24 @@ +package com.alibaba.dubbo.remoting.message; + + +import com.alibaba.dubbo.remoting.exception.RemotingException; + +/** + * @author Xs + */ +public interface Interceptor { + + Response intercept(Chain chain) throws RemotingException; + + interface Chain { + + Request request(); + + int timeout(); + + Response proceed(Request request, int timeout) throws RemotingException; + + Response proceed(Request request) throws RemotingException; + + } +} diff --git a/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Message.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Message.java new file mode 100644 index 00000000000..e0e6a9683e7 --- /dev/null +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Message.java @@ -0,0 +1,7 @@ +package com.alibaba.dubbo.remoting.message; + +/** + * @author Xs. + */ +public class Message { +} diff --git a/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Request.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Request.java new file mode 100644 index 00000000000..2603fd2f136 --- /dev/null +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Request.java @@ -0,0 +1,178 @@ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.alibaba.dubbo.remoting.message; + +import com.alibaba.dubbo.common.Version; +import com.alibaba.dubbo.common.utils.StringUtils; + +import java.util.concurrent.atomic.AtomicLong; + +/** + * Request. + * + * @author qian.lei + * @author william.liangf + */ +public class Request extends Message { + + public static final String HEARTBEAT_EVENT = null; + + public static final String READONLY_EVENT = "R"; + + private static final AtomicLong INVOKE_ID = new AtomicLong(0); + + private final long mId; + + private final String mVersion; + + private final boolean mTwoWay; + + private final boolean mEvent; + + private final boolean mBroken; + + private final Object mData; + + public Request(Builder builder) { + this.mId = builder.mId; + this.mVersion = builder.mVersion; + this.mTwoWay = builder.mTwoWay; + this.mEvent = builder.mEvent; + this.mBroken = builder.mBroken; + this.mData = builder.mData; + } + + public Builder newBuilder() { + return new Builder(this); + } + + public static class Builder { + private long mId; + private String mVersion = Version.getVersion(); + private boolean mTwoWay = true; + private boolean mEvent = false; + private boolean mBroken = false; + private Object mData; + + public Builder() { + } + + public Builder(long mId) { + this.mId = mId; + } + + public Builder(Request request) { + this.mId = request.mId; + this.mVersion = request.mVersion; + this.mTwoWay = request.mTwoWay; + this.mEvent = request.mEvent; + this.mBroken = request.mBroken; + this.mData = request.mData; + + } + + public Builder id(long mId) { + this.mId = mId; + return this; + } + + public Builder newId() { + this.mId = Request.newId(); + return this; + } + + public Builder version(String mVersion) { + this.mVersion = mVersion; + return this; + } + + public Builder twoWay(boolean mTwoWay) { + this.mTwoWay = mTwoWay; + return this; + } + + public Builder isEvent(boolean mEvent) { + this.mEvent = mEvent; + return this; + } + + public Builder broken(boolean mBroken) { + this.mBroken = mBroken; + return this; + } + + public Builder data(Object mData) { + this.mData = mData; + return this; + } + + public Request build() { + return new Request(this); + } + } + + public long getId() { + return mId; + } + + public String getVersion() { + return mVersion; + } + + public boolean isTwoWay() { + return mTwoWay; + } + + public boolean isEvent() { + return mEvent; + } + + public boolean isBroken() { + return mBroken; + } + + + public Object getData() { + return mData; + } + + public boolean isHeartbeat() { + return mEvent && HEARTBEAT_EVENT == mData; + } + + private static long newId() { + // getAndIncrement()增长到MAX_VALUE时,再增长会变为MIN_VALUE,负数也可以做为ID + return INVOKE_ID.getAndIncrement(); + } + + @Override + public String toString() { + return "Request [id=" + mId + ", version=" + mVersion + ", twoway=" + mTwoWay + ", event=" + mEvent + + ", broken=" + mBroken + ", data=" + (mData == this ? "this" : safeToString(mData)) + "]"; + } + + private static String safeToString(Object data) { + if (data == null) return null; + String dataStr; + try { + dataStr = data.toString(); + } catch (Throwable e) { + dataStr = ""; + } + return dataStr; + } +} diff --git a/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Response.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Response.java new file mode 100644 index 00000000000..45cd88b5d28 --- /dev/null +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/message/Response.java @@ -0,0 +1,178 @@ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.alibaba.dubbo.remoting.message; + +/** + * Response + * + * @author qian.lei + * @author william.liangf + */ +public class Response extends Message { + + public static final String HEARTBEAT_EVENT = null; + public static final String READONLY_EVENT = "R"; + /** + * ok. + */ + public static final byte OK = 20; + /** + * client side timeout. + */ + public static final byte CLIENT_TIMEOUT = 30; + /** + * server side timeout. + */ + public static final byte SERVER_TIMEOUT = 31; + /** + * request format error. + */ + public static final byte BAD_REQUEST = 40; + /** + * response format error. + */ + public static final byte BAD_RESPONSE = 50; + /** + * service not found. + */ + public static final byte SERVICE_NOT_FOUND = 60; + /** + * service error. + */ + public static final byte SERVICE_ERROR = 70; + /** + * internal server error. + */ + public static final byte SERVER_ERROR = 80; + /** + * internal server error. + */ + public static final byte CLIENT_ERROR = 90; + + private final long mId; + private final String mVersion; + private final byte mStatus; + private final boolean mEvent; + private final String mErrorMsg; + private final Object mResult; + + public Response(Builder builder) { + this.mId = builder.mId; + this.mVersion = builder.mVersion; + this.mStatus = builder.mStatus; + this.mEvent = builder.mEvent; + this.mErrorMsg = builder.mErrorMsg; + this.mResult = builder.mResult; + } + + public Builder newBuilder() { + return new Builder(this); + } + + public static class Builder { + private long mId = 0; + private String mVersion; + private byte mStatus = OK; + private boolean mEvent = false; + private String mErrorMsg; + private Object mResult; + + public Builder() { + } + + public Builder(long mId) { + this.mId = mId; + } + + public Builder(Response response) { + this.mId = response.mId; + this.mVersion = response.mVersion; + this.mStatus = response.mStatus; + this.mEvent = response.mEvent; + this.mErrorMsg = response.mErrorMsg; + this.mResult = response.mResult; + } + + public Builder id(long mId) { + this.mId = mId; + return this; + } + + public Builder version(String mVersion) { + this.mVersion = mVersion; + return this; + } + + public Builder status(byte mStatus) { + this.mStatus = mStatus; + return this; + } + + public Builder isEvent(boolean mEvent) { + this.mEvent = mEvent; + return this; + } + + public Builder errorMsg(String mErrorMsg) { + this.mErrorMsg = mErrorMsg; + return this; + } + + public Builder result(Object mResult) { + this.mResult = mResult; + return this; + } + + public Response build() { + return new Response(this); + } + } + + public long getId() { + return mId; + } + + public String getVersion() { + return mVersion; + } + + public byte getStatus() { + return mStatus; + } + + public boolean isEvent() { + return mEvent; + } + + public boolean isHeartbeat() { + return mEvent && HEARTBEAT_EVENT == mResult; + } + + public Object getResult() { + return mResult; + } + + public String getErrorMessage() { + return mErrorMsg; + } + + + @Override + public String toString() { + return "Response [id=" + mId + ", version=" + mVersion + ", status=" + mStatus + ", event=" + mEvent + + ", error=" + mErrorMsg + ", result=" + (mResult == this ? "this" : mResult) + "]"; + } +} \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Channel.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Channel.java similarity index 80% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Channel.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Channel.java index 465cadeb4eb..019dcc7f1c3 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Channel.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Channel.java @@ -13,16 +13,13 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting; +package com.alibaba.dubbo.remoting.transport; import java.net.InetSocketAddress; /** * Channel. (API/SPI, Prototype, ThreadSafe) - * - * @see com.alibaba.dubbo.remoting.Client - * @see com.alibaba.dubbo.remoting.Server#getChannels() - * @see com.alibaba.dubbo.remoting.Server#getChannel(InetSocketAddress) + * * @author qian.lei * @author william.liangf */ @@ -30,21 +27,21 @@ public interface Channel extends Endpoint { /** * get remote address. - * + * * @return remote address. */ InetSocketAddress getRemoteAddress(); /** * is connected. - * + * * @return connected */ boolean isConnected(); /** * has attribute. - * + * * @param key key. * @return has or has not. */ @@ -52,7 +49,7 @@ public interface Channel extends Endpoint { /** * get attribute. - * + * * @param key key. * @return value. */ @@ -60,15 +57,15 @@ public interface Channel extends Endpoint { /** * set attribute. - * - * @param key key. + * + * @param key key. * @param value value. */ - void setAttribute(String key,Object value); - + void setAttribute(String key, Object value); + /** * remove attribute. - * + * * @param key key. */ void removeAttribute(String key); diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/ChannelHandler.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandler.java similarity index 83% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/ChannelHandler.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandler.java index 6cc8777dd26..3f25af2d23c 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/ChannelHandler.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/ChannelHandler.java @@ -13,16 +13,15 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting; +package com.alibaba.dubbo.remoting.transport; import com.alibaba.dubbo.common.extension.SPI; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * ChannelHandler. (API, Prototype, ThreadSafe) - * - * @see com.alibaba.dubbo.remoting.Transporter#bind(com.alibaba.dubbo.common.URL, ChannelHandler) - * @see com.alibaba.dubbo.remoting.Transporter#connect(com.alibaba.dubbo.common.URL, ChannelHandler) + * * @author qian.lei * @author william.liangf */ @@ -31,21 +30,21 @@ public interface ChannelHandler { /** * on channel connected. - * + * * @param channel channel. */ void connected(Channel channel) throws RemotingException; /** * on channel disconnected. - * + * * @param channel channel. */ void disconnected(Channel channel) throws RemotingException; /** * on message sent. - * + * * @param channel channel. * @param message message. */ @@ -53,7 +52,7 @@ public interface ChannelHandler { /** * on message received. - * + * * @param channel channel. * @param message message. */ @@ -61,8 +60,8 @@ public interface ChannelHandler { /** * on exception caught. - * - * @param channel channel. + * + * @param channel channel. * @param exception exception. */ void caught(Channel channel, Throwable exception) throws RemotingException; diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Client.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Client.java similarity index 85% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Client.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Client.java index f547b8a8d6d..187163f1bad 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Client.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Client.java @@ -1,38 +1,39 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting; - -import com.alibaba.dubbo.common.Resetable; - -/** - * Remoting Client. (API/SPI, Prototype, ThreadSafe) - * - * Client/Server - * - * @see com.alibaba.dubbo.remoting.Transporter#connect(com.alibaba.dubbo.common.URL, ChannelHandler) - * @author qian.lei - */ -public interface Client extends Endpoint, Channel, Resetable { - - /** - * reconnect. - */ - void reconnect() throws RemotingException; - - @Deprecated - void reset(com.alibaba.dubbo.common.Parameters parameters); - +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.alibaba.dubbo.remoting.transport; + +import com.alibaba.dubbo.common.Resetable; +import com.alibaba.dubbo.remoting.exception.RemotingException; + +/** + * Remoting Client. (API/SPI, Prototype, ThreadSafe) + * + * Client/Server + * + * @see Transporter#connect(com.alibaba.dubbo.common.URL, ChannelHandler) + * @author qian.lei + */ +public interface Client extends Endpoint, Channel, Resetable { + + /** + * reconnect. + */ + void reconnect() throws RemotingException; + + @Deprecated + void reset(com.alibaba.dubbo.common.Parameters parameters); + } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Endpoint.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Endpoint.java similarity index 81% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Endpoint.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Endpoint.java index 267ad3031eb..b1ee26d1241 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Endpoint.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Endpoint.java @@ -1,86 +1,85 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting; - -import java.net.InetSocketAddress; - -import com.alibaba.dubbo.common.URL; - -/** - * Endpoint. (API/SPI, Prototype, ThreadSafe) - * - * @see com.alibaba.dubbo.remoting.Channel - * @see com.alibaba.dubbo.remoting.Client - * @see com.alibaba.dubbo.remoting.Server - * @author william.liangf - */ -public interface Endpoint { - - /** - * get url. - * - * @return url - */ - URL getUrl(); - - /** - * get channel handler. - * - * @return channel handler - */ - ChannelHandler getChannelHandler(); - - /** - * get local address. - * - * @return local address. - */ - InetSocketAddress getLocalAddress(); - - /** - * send message. - * - * @param message - * @throws RemotingException - */ - void send(Object message) throws RemotingException; - - /** - * send message. - * - * @param message - * @param sent 是否已发送完成 - */ - void send(Object message, boolean sent) throws RemotingException; - - /** - * close the channel. - */ - void close(); - - /** - * Graceful close the channel. - */ - void close(int timeout); - - /** - * is closed. - * - * @return closed - */ - boolean isClosed(); - +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.alibaba.dubbo.remoting.transport; + +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.remoting.exception.RemotingException; + +import java.net.InetSocketAddress; + +/** + * Endpoint. (API/SPI, Prototype, ThreadSafe) + * + * @author william.liangf + * @see Channel + */ +public interface Endpoint { + + /** + * get url. + * + * @return url + */ + URL getUrl(); + + /** + * get channel handler. + * + * @return channel handler + */ + ChannelHandler getChannelHandler(); + + /** + * get local address. + * + * @return local address. + */ + InetSocketAddress getLocalAddress(); + + /** + * send message. + * + * @param message + * @throws RemotingException + */ + void send(Object message) throws RemotingException; + + /** + * send message. + * + * @param message + * @param sent 是否已发送完成 + */ + void send(Object message, boolean sent) throws RemotingException; + + /** + * close the channel. + */ + void close(); + + /** + * Graceful close the channel. + */ + void close(int timeout); + + /** + * is closed. + * + * @return closed + */ + boolean isClosed(); + } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Server.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Server.java old mode 100755 new mode 100644 similarity index 87% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Server.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Server.java index afe655a78a1..0e2e64d3e26 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Server.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Server.java @@ -1,58 +1,58 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.remoting; - -import java.net.InetSocketAddress; -import java.util.Collection; - -import com.alibaba.dubbo.common.Resetable; - -/** - * Remoting Server. (API/SPI, Prototype, ThreadSafe) - * - * Client/Server - * - * @see com.alibaba.dubbo.remoting.Transporter#bind(com.alibaba.dubbo.common.URL, ChannelHandler) - * @author qian.lei - */ -public interface Server extends Endpoint, Resetable { - - /** - * is bound. - * - * @return bound - */ - boolean isBound(); - - /** - * get channels. - * - * @return channels - */ - Collection getChannels(); - - /** - * get channel. - * - * @param remoteAddress - * @return channel - */ - Channel getChannel(InetSocketAddress remoteAddress); - - @Deprecated - void reset(com.alibaba.dubbo.common.Parameters parameters); - +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.alibaba.dubbo.remoting.transport; + +import java.net.InetSocketAddress; +import java.util.Collection; + +import com.alibaba.dubbo.common.Resetable; + +/** + * Remoting Server. (API/SPI, Prototype, ThreadSafe) + * + * Client/Server + * + * @see Transporter#bind(com.alibaba.dubbo.common.URL, ChannelHandler) + * @author qian.lei + */ +public interface Server extends Endpoint, Resetable { + + /** + * is bound. + * + * @return bound + */ + boolean isBound(); + + /** + * get channels. + * + * @return channels + */ + Collection getChannels(); + + /** + * get channel. + * + * @param remoteAddress + * @return channel + */ + Channel getChannel(InetSocketAddress remoteAddress); + + @Deprecated + void reset(com.alibaba.dubbo.common.Parameters parameters); + } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Transporter.java b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Transporter.java similarity index 77% rename from dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Transporter.java rename to dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Transporter.java index 9408c6590a7..6b54e017708 100644 --- a/dubbo-remoting/dubbo-remoting-api/src/main/java/com/alibaba/dubbo/remoting/Transporter.java +++ b/dubbo-remoting/dubbo-remoting-common/src/main/java/com/alibaba/dubbo/remoting/transport/Transporter.java @@ -13,22 +13,20 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting; - -import javax.sound.midi.Receiver; +package com.alibaba.dubbo.remoting.transport; import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.Adaptive; import com.alibaba.dubbo.common.extension.SPI; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * Transporter. (SPI, Singleton, ThreadSafe) - * + *

* Transport Layer * Client/Server - * - * @see com.alibaba.dubbo.remoting.Transporters + * * @author ding.lid * @author william.liangf */ @@ -37,24 +35,22 @@ public interface Transporter { /** * Bind a server. - * - * @see com.alibaba.dubbo.remoting.Transporters#bind(URL, Receiver, ChannelHandler) - * @param url server url + * + * @param url server url * @param handler * @return server - * @throws RemotingException + * @throws RemotingException */ @Adaptive({Constants.SERVER_KEY, Constants.TRANSPORTER_KEY}) Server bind(URL url, ChannelHandler handler) throws RemotingException; /** * Connect to a server. - * - * @see com.alibaba.dubbo.remoting.Transporters#connect(URL, Receiver, ChannelListener) - * @param url server url + * + * @param url server url * @param handler * @return client - * @throws RemotingException + * @throws RemotingException */ @Adaptive({Constants.CLIENT_KEY, Constants.TRANSPORTER_KEY}) Client connect(URL url, ChannelHandler handler) throws RemotingException; diff --git a/dubbo-remoting/dubbo-remoting-grizzly/pom.xml b/dubbo-remoting/dubbo-remoting-grizzly/pom.xml index ce4b6520072..9d8c2a13e15 100644 --- a/dubbo-remoting/dubbo-remoting-grizzly/pom.xml +++ b/dubbo-remoting/dubbo-remoting-grizzly/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-remoting - 2.8.4 + 3.0.1 dubbo-remoting-grizzly jar diff --git a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyChannel.java b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyChannel.java index 65df0cffb1d..4dd9f33fe0c 100644 --- a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyChannel.java +++ b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyChannel.java @@ -28,8 +28,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.AbstractChannel; /** diff --git a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyClient.java b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyClient.java index 34a60506642..55ca7e3a393 100644 --- a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyClient.java +++ b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyClient.java @@ -29,9 +29,9 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.AbstractClient; /** diff --git a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyCodecAdapter.java b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyCodecAdapter.java index f3169e63ffe..caf2d71a1bf 100644 --- a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyCodecAdapter.java +++ b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyCodecAdapter.java @@ -25,9 +25,9 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec2; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; import com.alibaba.dubbo.remoting.buffer.ChannelBuffers; import com.alibaba.dubbo.remoting.buffer.DynamicChannelBuffer; diff --git a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyHandler.java b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyHandler.java index f7196cd305b..66b54c1e2ff 100644 --- a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyHandler.java +++ b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyHandler.java @@ -26,8 +26,8 @@ import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * GrizzlyHandler diff --git a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyServer.java b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyServer.java index 67ce00577c3..2a6d00813e5 100644 --- a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyServer.java +++ b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyServer.java @@ -33,9 +33,9 @@ import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.AbstractServer; /** diff --git a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyTransporter.java b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyTransporter.java index 5f663228056..0f130c60911 100644 --- a/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyTransporter.java +++ b/dubbo-remoting/dubbo-remoting-grizzly/src/main/java/com/alibaba/dubbo/remoting/transport/grizzly/GrizzlyTransporter.java @@ -16,11 +16,11 @@ package com.alibaba.dubbo.remoting.transport.grizzly; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; -import com.alibaba.dubbo.remoting.Transporter; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; +import com.alibaba.dubbo.remoting.transport.Transporter; /** * GrizzlyTransporter diff --git a/dubbo-remoting/dubbo-remoting-grizzly/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Transporter b/dubbo-remoting/dubbo-remoting-grizzly/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.transport.Transporter similarity index 100% rename from dubbo-remoting/dubbo-remoting-grizzly/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Transporter rename to dubbo-remoting/dubbo-remoting-grizzly/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.transport.Transporter diff --git a/dubbo-remoting/dubbo-remoting-http/pom.xml b/dubbo-remoting/dubbo-remoting-http/pom.xml index c08a31deb77..bc9e7ea609f 100644 --- a/dubbo-remoting/dubbo-remoting-http/pom.xml +++ b/dubbo-remoting/dubbo-remoting-http/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-remoting - 2.8.4 + 3.0.1 dubbo-remoting-http jar @@ -34,6 +34,11 @@ dubbo-common ${project.parent.version} + + com.alibaba + dubbo-tracker-api + ${project.parent.version} + org.mortbay.jetty jetty diff --git a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/jetty/JettyHttpBinder.java b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/jetty/JettyHttpBinder.java index 4741b90dcd0..b8f675e6fd6 100644 --- a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/jetty/JettyHttpBinder.java +++ b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/jetty/JettyHttpBinder.java @@ -19,6 +19,7 @@ import com.alibaba.dubbo.remoting.http.HttpBinder; import com.alibaba.dubbo.remoting.http.HttpHandler; import com.alibaba.dubbo.remoting.http.HttpServer; +import com.alibaba.dubbo.tracker.http.ServletFilterBuilder; /** * JettyHttpTransporter @@ -27,8 +28,14 @@ */ public class JettyHttpBinder implements HttpBinder { + private ServletFilterBuilder servletFilterBuilder; + + public void setServletFilterBuilder(ServletFilterBuilder servletFilterBuilder) { + this.servletFilterBuilder = servletFilterBuilder; + } + public HttpServer bind(URL url, HttpHandler handler) { - return new JettyHttpServer(url, handler); + return new JettyHttpServer(url, handler, servletFilterBuilder); } } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/jetty/JettyHttpServer.java b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/jetty/JettyHttpServer.java index fd3ca9465a4..2c3d330e70d 100644 --- a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/jetty/JettyHttpServer.java +++ b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/jetty/JettyHttpServer.java @@ -15,44 +15,44 @@ */ package com.alibaba.dubbo.remoting.http.jetty; +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.logger.Logger; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.common.utils.NetUtils; +import com.alibaba.dubbo.remoting.http.HttpHandler; +import com.alibaba.dubbo.remoting.http.servlet.DispatcherServlet; import com.alibaba.dubbo.remoting.http.servlet.ServletManager; +import com.alibaba.dubbo.remoting.http.support.AbstractHttpServer; +import com.alibaba.dubbo.tracker.http.ServletFilterBuilder; +import org.mortbay.jetty.Handler; import org.mortbay.jetty.Server; import org.mortbay.jetty.nio.SelectChannelConnector; import org.mortbay.jetty.servlet.Context; +import org.mortbay.jetty.servlet.FilterHolder; import org.mortbay.jetty.servlet.ServletHandler; import org.mortbay.jetty.servlet.ServletHolder; import org.mortbay.log.Log; import org.mortbay.log.StdErrLog; import org.mortbay.thread.QueuedThreadPool; -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.http.HttpHandler; -import com.alibaba.dubbo.remoting.http.servlet.DispatcherServlet; -import com.alibaba.dubbo.remoting.http.support.AbstractHttpServer; +import javax.servlet.Filter; public class JettyHttpServer extends AbstractHttpServer { private static final Logger logger = LoggerFactory.getLogger(JettyHttpServer.class); - private Server server; + private final Server server; - private URL url; + private final URL url; - public JettyHttpServer(URL url, final HttpHandler handler){ + public JettyHttpServer(URL url, final HttpHandler handler, ServletFilterBuilder servletFilterBuilder) { super(url, handler); - - // modified by lishen this.url = url; - // TODO we should leave this setting to slf4j Log.setLog(new StdErrLog()); Log.getLog().setDebugEnabled(false); DispatcherServlet.addHttpHandler(url.getPort(), handler); - int threads = url.getParameter(Constants.THREADS_KEY, Constants.DEFAULT_THREADS); QueuedThreadPool threadPool = new QueuedThreadPool(); threadPool.setDaemon(true); @@ -60,41 +60,40 @@ public JettyHttpServer(URL url, final HttpHandler handler){ threadPool.setMinThreads(threads); SelectChannelConnector connector = new SelectChannelConnector(); - if (! url.isAnyHost() && NetUtils.isValidLocalHost(url.getHost())) { + if (!url.isAnyHost() && NetUtils.isValidLocalHost(url.getHost())) { connector.setHost(url.getHost()); } connector.setPort(url.getPort()); - server = new Server(); server.setThreadPool(threadPool); server.addConnector(connector); + Context context = new Context(server, "/", Context.SESSIONS); ServletHandler servletHandler = new ServletHandler(); ServletHolder servletHolder = servletHandler.addServletWithMapping(DispatcherServlet.class, "/*"); servletHolder.setInitOrder(2); - - // modified by lishen - // dubbo's original impl can't support the use of ServletContext -// server.addHandler(servletHandler); - // TODO Context.SESSIONS is the best option here? - Context context = new Context(server, "/", Context.SESSIONS); context.setServletHandler(servletHandler); + + if (servletFilterBuilder != null) { + Filter filter = servletFilterBuilder.build(url); + if (filter != null) { + FilterHolder filterHolder = new FilterHolder(filter); + context.addFilter(filterHolder, "/*", Handler.REQUEST); + } + } ServletManager.getInstance().addServletContext(url.getPort(), context.getServletContext()); try { server.start(); } catch (Exception e) { throw new IllegalStateException("Failed to start jetty server on " + url.getAddress() + ", cause: " - + e.getMessage(), e); + + e.getMessage(), e); } } public void close() { super.close(); - - // modified by lishen ServletManager.getInstance().removeServletContext(url.getPort()); - if (server != null) { try { server.stop(); diff --git a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/servlet/DispatcherServlet.java b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/servlet/DispatcherServlet.java index ae3c7210bfe..5b82e20ca20 100644 --- a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/servlet/DispatcherServlet.java +++ b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/servlet/DispatcherServlet.java @@ -13,56 +13,54 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting.http.servlet; - -import java.io.IOException; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; +package com.alibaba.dubbo.remoting.http.servlet; + +import com.alibaba.dubbo.remoting.http.HttpHandler; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; -import com.alibaba.dubbo.remoting.http.HttpHandler; - -/** - * Service dispatcher Servlet. - * - * @author qian.lei - */ -public class DispatcherServlet extends HttpServlet { - - private static final long serialVersionUID = 5766349180380479888L; - - private static DispatcherServlet INSTANCE; - - private static final Map handlers = new ConcurrentHashMap(); - - public static void addHttpHandler(int port, HttpHandler processor) { - handlers.put(port, processor); - } - - public static void removeHttpHandler(int port) { - handlers.remove(port); +/** + * Service dispatcher Servlet. + * + * @author qian.lei + */ +public class DispatcherServlet extends HttpServlet { + + private static final long serialVersionUID = 5766349180380479888L; + + private static DispatcherServlet INSTANCE; + + private static final Map handlers = new ConcurrentHashMap(); + + public static void addHttpHandler(int port, HttpHandler processor) { + handlers.put(port, processor); + } + + public static void removeHttpHandler(int port) { + handlers.remove(port); } - + public static DispatcherServlet getInstance() { - return INSTANCE; + return INSTANCE; } - + public DispatcherServlet() { - DispatcherServlet.INSTANCE = this; - } - - protected void service(HttpServletRequest request, HttpServletResponse response) - throws ServletException, IOException { - HttpHandler handler = handlers.get(request.getLocalPort()); - if( handler == null ) {// service not found. - response.sendError(HttpServletResponse.SC_NOT_FOUND, "Service not found."); - } else { - handler.handle(request, response); - } - } - + DispatcherServlet.INSTANCE = this; + } + + protected void service(HttpServletRequest request, HttpServletResponse response) + throws ServletException, IOException { + HttpHandler handler = handlers.get(request.getLocalPort()); + if (handler == null) { + response.sendError(HttpServletResponse.SC_NOT_FOUND, "Service not found."); + } else { + handler.handle(request, response); + } + } } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/servlet/ServletHttpServer.java b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/servlet/ServletHttpServer.java index fa913556c51..eedb40e3a36 100644 --- a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/servlet/ServletHttpServer.java +++ b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/servlet/ServletHttpServer.java @@ -20,10 +20,9 @@ import com.alibaba.dubbo.remoting.http.support.AbstractHttpServer; public class ServletHttpServer extends AbstractHttpServer { - - public ServletHttpServer(URL url, HttpHandler handler){ + + public ServletHttpServer(URL url, HttpHandler handler) { super(url, handler); DispatcherServlet.addHttpHandler(url.getPort(), handler); } - } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/support/AbstractHttpServer.java b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/support/AbstractHttpServer.java index 295cb18854e..be5c5b97bb9 100644 --- a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/support/AbstractHttpServer.java +++ b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/support/AbstractHttpServer.java @@ -15,26 +15,26 @@ */ package com.alibaba.dubbo.remoting.http.support; -import java.net.InetSocketAddress; - import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.remoting.http.HttpHandler; import com.alibaba.dubbo.remoting.http.HttpServer; +import java.net.InetSocketAddress; + /** * AbstractHttpServer - * + * * @author william.liangf */ public abstract class AbstractHttpServer implements HttpServer { private final URL url; - + private final HttpHandler handler; private volatile boolean closed; - - public AbstractHttpServer(URL url, HttpHandler handler){ + + public AbstractHttpServer(URL url, HttpHandler handler) { if (url == null) { throw new IllegalArgumentException("url == null"); } @@ -44,7 +44,7 @@ public AbstractHttpServer(URL url, HttpHandler handler){ this.url = url; this.handler = handler; } - + public HttpHandler getHttpHandler() { return handler; } @@ -55,7 +55,7 @@ public URL getUrl() { public void reset(URL url) { } - + public boolean isBound() { return true; } diff --git a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/tomcat/TomcatHttpBinder.java b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/tomcat/TomcatHttpBinder.java index fd6a05eb36c..ca4220d94d5 100755 --- a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/tomcat/TomcatHttpBinder.java +++ b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/tomcat/TomcatHttpBinder.java @@ -1,12 +1,12 @@ /** * Copyright 1999-2014 dangdang.com. - * + *

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -19,14 +19,21 @@ import com.alibaba.dubbo.remoting.http.HttpBinder; import com.alibaba.dubbo.remoting.http.HttpHandler; import com.alibaba.dubbo.remoting.http.HttpServer; +import com.alibaba.dubbo.tracker.http.ServletFilterBuilder; /** * @author lishen */ public class TomcatHttpBinder implements HttpBinder { + private ServletFilterBuilder servletFilterBuilder; + + public void setServletFilterBuilder(ServletFilterBuilder servletFilterBuilder) { + this.servletFilterBuilder = servletFilterBuilder; + } + public HttpServer bind(URL url, HttpHandler handler) { - return new TomcatHttpServer(url, handler); + return new TomcatHttpServer(url, handler, servletFilterBuilder); } } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/tomcat/TomcatHttpServer.java b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/tomcat/TomcatHttpServer.java index 686d562ae68..fde3b6648b6 100755 --- a/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/tomcat/TomcatHttpServer.java +++ b/dubbo-remoting/dubbo-remoting-http/src/main/java/com/alibaba/dubbo/remoting/http/tomcat/TomcatHttpServer.java @@ -1,12 +1,12 @@ /** * Copyright 1999-2014 dangdang.com. - * + *

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -24,10 +24,14 @@ import com.alibaba.dubbo.remoting.http.servlet.DispatcherServlet; import com.alibaba.dubbo.remoting.http.servlet.ServletManager; import com.alibaba.dubbo.remoting.http.support.AbstractHttpServer; +import com.alibaba.dubbo.tracker.http.ServletFilterBuilder; import org.apache.catalina.Context; import org.apache.catalina.LifecycleException; import org.apache.catalina.startup.Tomcat; +import org.apache.tomcat.util.descriptor.web.FilterDef; +import org.apache.tomcat.util.descriptor.web.FilterMap; +import javax.servlet.Filter; import java.io.File; @@ -42,9 +46,8 @@ public class TomcatHttpServer extends AbstractHttpServer { private final URL url; - public TomcatHttpServer(URL url, final HttpHandler handler) { + public TomcatHttpServer(URL url, final HttpHandler handler, ServletFilterBuilder servletFilterBuilder) { super(url, handler); - this.url = url; DispatcherServlet.addHttpHandler(url.getPort(), handler); String baseDir = new File(System.getProperty("java.io.tmpdir")).getAbsolutePath(); @@ -53,23 +56,29 @@ public TomcatHttpServer(URL url, final HttpHandler handler) { tomcat.setPort(url.getPort()); tomcat.getConnector().setProperty( "maxThreads", String.valueOf(url.getParameter(Constants.THREADS_KEY, Constants.DEFAULT_THREADS))); -// tomcat.getConnector().setProperty( -// "minSpareThreads", String.valueOf(url.getParameter(Constants.THREADS_KEY, Constants.DEFAULT_THREADS))); - tomcat.getConnector().setProperty( "maxConnections", String.valueOf(url.getParameter(Constants.ACCEPTS_KEY, -1))); - tomcat.getConnector().setProperty("URIEncoding", "UTF-8"); tomcat.getConnector().setProperty("connectionTimeout", "60000"); - tomcat.getConnector().setProperty("maxKeepAliveRequests", "-1"); tomcat.getConnector().setProtocol("org.apache.coyote.http11.Http11NioProtocol"); - Context context = tomcat.addContext("/", baseDir); Tomcat.addServlet(context, "dispatcher", new DispatcherServlet()); context.addServletMapping("/*", "dispatcher"); + Filter filter = servletFilterBuilder.build(url); + if (filter != null) { + FilterDef filterDef = new FilterDef(); + filterDef.setFilter(filter); + filterDef.setFilterName("servletFilter"); + context.addFilterDef(filterDef); + + FilterMap filterMap = new FilterMap(); + filterMap.addServletName("dispatcher"); + filterMap.setFilterName("servletFilter"); + filterMap.addURLPattern("*"); + context.addFilterMap(filterMap); + } ServletManager.getInstance().addServletContext(url.getPort(), context.getServletContext()); - try { tomcat.start(); } catch (LifecycleException e) { @@ -79,9 +88,7 @@ public TomcatHttpServer(URL url, final HttpHandler handler) { public void close() { super.close(); - ServletManager.getInstance().removeServletContext(url.getPort()); - try { tomcat.stop(); } catch (Exception e) { diff --git a/dubbo-remoting/dubbo-remoting-mina/pom.xml b/dubbo-remoting/dubbo-remoting-mina/pom.xml index b3e36966f1a..cc6a98a9a7e 100644 --- a/dubbo-remoting/dubbo-remoting-mina/pom.xml +++ b/dubbo-remoting/dubbo-remoting-mina/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-remoting - 2.8.4 + 3.0.1 dubbo-remoting-mina jar diff --git a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaChannel.java b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaChannel.java index 12fd662a7db..1e731006c85 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaChannel.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaChannel.java @@ -1,18 +1,18 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.mina; import java.net.InetSocketAddress; @@ -24,8 +24,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.AbstractChannel; /** diff --git a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaClient.java b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaClient.java index 47cae52af11..693cf237efb 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaClient.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaClient.java @@ -1,47 +1,47 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.mina; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.CountDownLatch; -import java.util.concurrent.Executors; -import java.util.concurrent.TimeUnit; -import java.util.concurrent.atomic.AtomicReference; - -import org.apache.mina.common.ConnectFuture; -import org.apache.mina.common.IoFuture; -import org.apache.mina.common.IoFutureListener; -import org.apache.mina.common.IoSession; -import org.apache.mina.common.ThreadModel; -import org.apache.mina.filter.codec.ProtocolCodecFilter; -import org.apache.mina.transport.socket.nio.SocketConnector; -import org.apache.mina.transport.socket.nio.SocketConnectorConfig; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.Version; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.utils.NamedThreadFactory; -import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.transport.AbstractClient; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.CountDownLatch; +import java.util.concurrent.Executors; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.atomic.AtomicReference; + +import org.apache.mina.common.ConnectFuture; +import org.apache.mina.common.IoFuture; +import org.apache.mina.common.IoFutureListener; +import org.apache.mina.common.IoSession; +import org.apache.mina.common.ThreadModel; +import org.apache.mina.filter.codec.ProtocolCodecFilter; +import org.apache.mina.transport.socket.nio.SocketConnector; +import org.apache.mina.transport.socket.nio.SocketConnectorConfig; + +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.Version; +import com.alibaba.dubbo.common.logger.Logger; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.common.utils.NamedThreadFactory; +import com.alibaba.dubbo.common.utils.NetUtils; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.AbstractClient; /** * Mina client. @@ -49,8 +49,8 @@ * @author qian.lei * @author william.liangf */ -public class MinaClient extends AbstractClient { - +public class MinaClient extends AbstractClient { + private static final Logger logger = LoggerFactory.getLogger(MinaClient.class); private static final Map connectors = new ConcurrentHashMap(); @@ -63,7 +63,7 @@ public class MinaClient extends AbstractClient { public MinaClient(final URL url, final ChannelHandler handler) throws RemotingException { super(url, wrapChannelHandler(url, handler)); - } + } @Override protected void doOpen() throws Throwable { diff --git a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaCodecAdapter.java b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaCodecAdapter.java index 8d675af7b65..d77547645e6 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaCodecAdapter.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaCodecAdapter.java @@ -25,9 +25,9 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec2; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; import com.alibaba.dubbo.remoting.buffer.ChannelBuffers; import com.alibaba.dubbo.remoting.buffer.DynamicChannelBuffer; diff --git a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaHandler.java b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaHandler.java index 75108f56167..8e5a5300119 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaHandler.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaHandler.java @@ -1,25 +1,25 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.mina; import org.apache.mina.common.IoHandlerAdapter; import org.apache.mina.common.IoSession; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; /** * MinaHandler diff --git a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaServer.java b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaServer.java index b0191c6d50a..46553c68858 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaServer.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaServer.java @@ -33,9 +33,9 @@ import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.ExecutorUtil; import com.alibaba.dubbo.common.utils.NamedThreadFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.AbstractServer; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelHandlers; diff --git a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaTransporter.java b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaTransporter.java index 534f7f3d243..350b1d35ad2 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaTransporter.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/main/java/com/alibaba/dubbo/remoting/transport/mina/MinaTransporter.java @@ -13,28 +13,28 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting.transport.mina; - +package com.alibaba.dubbo.remoting.transport.mina; + import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; -import com.alibaba.dubbo.remoting.Transporter; - -/** - * @author ding.lid - */ -public class MinaTransporter implements Transporter { - - public static final String NAME = "mina"; - - public Server bind(URL url, ChannelHandler handler) throws RemotingException { - return new MinaServer(url, handler); - } - - public Client connect(URL url, ChannelHandler handler) throws RemotingException { - return new MinaClient(url, handler); - } - +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; +import com.alibaba.dubbo.remoting.transport.Transporter; + +/** + * @author ding.lid + */ +public class MinaTransporter implements Transporter { + + public static final String NAME = "mina"; + + public Server bind(URL url, ChannelHandler handler) throws RemotingException { + return new MinaServer(url, handler); + } + + public Client connect(URL url, ChannelHandler handler) throws RemotingException { + return new MinaClient(url, handler); + } + } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-mina/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Transporter b/dubbo-remoting/dubbo-remoting-mina/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.transport.Transporter similarity index 100% rename from dubbo-remoting/dubbo-remoting-mina/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Transporter rename to dubbo-remoting/dubbo-remoting-mina/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.transport.Transporter diff --git a/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/ClientToServerTest.java b/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/ClientToServerTest.java index d2b496f4ee2..0e273fc781f 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/ClientToServerTest.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/ClientToServerTest.java @@ -1,50 +1,45 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.remoting.transport.mina; -import junit.framework.Assert; -import junit.framework.TestCase; - -import org.junit.Test; - -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; import com.alibaba.dubbo.remoting.exchange.support.Replier; +import junit.framework.TestCase; /** * ClientToServer - * + * * @author william.liangf */ public abstract class ClientToServerTest extends TestCase { - + protected static final String LOCALHOST = "127.0.0.1"; - + protected ExchangeServer server; - + protected ExchangeChannel client; - + protected WorldHandler handler = new WorldHandler(); - + protected abstract ExchangeServer newServer(int port, Replier receiver) throws RemotingException; - + protected abstract ExchangeChannel newClient(int port) throws RemotingException; - + @Override protected void setUp() throws Exception { super.setUp(); @@ -64,30 +59,4 @@ protected void tearDown() throws Exception { client.close(); } } - - @Test - public void testFuture() throws Exception { - ResponseFuture future = client.request(new World("world")); - Hello result = (Hello)future.get(); - Assert.assertEquals("hello,world", result.getName()); - } - -// @Test -// public void testCallback() throws Exception { -// final Object waitter = new Object(); -// client.invoke(new World("world"), new InvokeCallback() { -// public void callback(Hello result) { -// Assert.assertEquals("hello,world", result.getName()); -// synchronized (waitter) { -// waitter.notifyAll(); -// } -// } -// public void onException(Throwable exception) { -// } -// }); -// synchronized (waitter) { -// waitter.wait(); -// } -// } - } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/ClientsTest.java b/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/ClientsTest.java index 98de2ea2b90..573af6ea0b7 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/ClientsTest.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/ClientsTest.java @@ -24,7 +24,7 @@ import org.junit.Test; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.Transporter; +import com.alibaba.dubbo.remoting.transport.Transporter; import com.alibaba.dubbo.remoting.transport.mina.MinaTransporter; /** diff --git a/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/MinaClientToServerTest.java b/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/MinaClientToServerTest.java index b0313cebf5a..2f3a8a945ad 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/MinaClientToServerTest.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/MinaClientToServerTest.java @@ -1,22 +1,22 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.remoting.transport.mina; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; import com.alibaba.dubbo.remoting.exchange.Exchangers; diff --git a/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/WorldHandler.java b/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/WorldHandler.java index 1175ab3e2fe..716b8a1e230 100644 --- a/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/WorldHandler.java +++ b/dubbo-remoting/dubbo-remoting-mina/src/test/java/com/alibaba/remoting/transport/mina/WorldHandler.java @@ -1,21 +1,21 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.remoting.transport.mina; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.support.Replier; diff --git a/dubbo-remoting/dubbo-remoting-netty/pom.xml b/dubbo-remoting/dubbo-remoting-netty/pom.xml index afe4f789749..2330a989483 100644 --- a/dubbo-remoting/dubbo-remoting-netty/pom.xml +++ b/dubbo-remoting/dubbo-remoting-netty/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-remoting - 2.8.4 + 3.0.1 dubbo-remoting-netty jar @@ -34,6 +34,13 @@ dubbo-remoting-api ${project.parent.version} + + + com.alibaba + dubbo-remoting-common + ${project.parent.version} + + io.netty netty diff --git a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyChannel.java b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyChannel.java index 7335c17f994..969b6b03855 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyChannel.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyChannel.java @@ -1,18 +1,18 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.netty; import java.net.InetSocketAddress; @@ -26,8 +26,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.AbstractChannel; /** @@ -98,17 +98,17 @@ public void send(Object message, boolean sent) throws RemotingException { ChannelFuture future = channel.write(message); if (sent) { timeout = getUrl().getPositiveParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); - success = future.await(timeout); - } - Throwable cause = future.getCause(); - if (cause != null) { - throw cause; + success = future.await(timeout); + } + Throwable cause = future.getCause(); + if (cause != null) { + throw cause; } } catch (Throwable e) { throw new RemotingException(this, "Failed to send message " + message + " to " + getRemoteAddress() + ", cause: " + e.getMessage(), e); } - if(! success) { + if(! success) { throw new RemotingException(this, "Failed to send message " + message + " to " + getRemoteAddress() + "in timeout(" + timeout + "ms) limit"); } diff --git a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyClient.java b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyClient.java index 830cfb5e573..800097847a8 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyClient.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyClient.java @@ -34,8 +34,8 @@ import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.NamedThreadFactory; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.AbstractClient; /** @@ -172,7 +172,7 @@ protected void doClose() throws Throwable { } @Override - protected com.alibaba.dubbo.remoting.Channel getChannel() { + protected com.alibaba.dubbo.remoting.transport.Channel getChannel() { Channel c = channel; if (c == null || ! c.isConnected()) return null; diff --git a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyCodecAdapter.java b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyCodecAdapter.java index 9173ac370fd..24f31840697 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyCodecAdapter.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyCodecAdapter.java @@ -51,9 +51,9 @@ final class NettyCodecAdapter { private final int bufferSize; - private final com.alibaba.dubbo.remoting.ChannelHandler handler; + private final com.alibaba.dubbo.remoting.transport.ChannelHandler handler; - public NettyCodecAdapter(Codec2 codec, URL url, com.alibaba.dubbo.remoting.ChannelHandler handler) { + public NettyCodecAdapter(Codec2 codec, URL url, com.alibaba.dubbo.remoting.transport.ChannelHandler handler) { this.codec = codec; this.url = url; this.handler = handler; diff --git a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyHandler.java b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyHandler.java index 1a05bd1ec87..c7a6379dba5 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyHandler.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyHandler.java @@ -1,18 +1,18 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.netty; import java.net.InetSocketAddress; @@ -28,8 +28,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; /** * NettyHandler @@ -74,7 +74,7 @@ public void channelConnected(ChannelHandlerContext ctx, ChannelStateEvent e) thr } @Override - public void channelDisconnected(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception { + public void channelDisconnected(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception { NettyChannel channel = NettyChannel.getOrAddChannel(ctx.getChannel(), url, handler); try { channels.remove(NetUtils.toAddressString((InetSocketAddress) ctx.getChannel().getRemoteAddress())); diff --git a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyServer.java b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyServer.java index 8f7a92d1deb..f427be2ad64 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyServer.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyServer.java @@ -15,20 +15,6 @@ */ package com.alibaba.dubbo.remoting.transport.netty; -import java.net.InetSocketAddress; -import java.util.Collection; -import java.util.HashSet; -import java.util.Map; -import java.util.concurrent.ExecutorService; -import java.util.concurrent.Executors; - -import org.jboss.netty.bootstrap.ServerBootstrap; -import org.jboss.netty.channel.ChannelFactory; -import org.jboss.netty.channel.ChannelPipeline; -import org.jboss.netty.channel.ChannelPipelineFactory; -import org.jboss.netty.channel.Channels; -import org.jboss.netty.channel.socket.nio.NioServerSocketChannelFactory; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; @@ -36,30 +22,43 @@ import com.alibaba.dubbo.common.utils.ExecutorUtil; import com.alibaba.dubbo.common.utils.NamedThreadFactory; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; import com.alibaba.dubbo.remoting.transport.AbstractServer; import com.alibaba.dubbo.remoting.transport.dispatcher.ChannelHandlers; +import org.jboss.netty.bootstrap.ServerBootstrap; +import org.jboss.netty.channel.ChannelFactory; +import org.jboss.netty.channel.ChannelPipeline; +import org.jboss.netty.channel.ChannelPipelineFactory; +import org.jboss.netty.channel.Channels; +import org.jboss.netty.channel.socket.nio.NioServerSocketChannelFactory; + +import java.net.InetSocketAddress; +import java.util.Collection; +import java.util.HashSet; +import java.util.Map; +import java.util.concurrent.ExecutorService; +import java.util.concurrent.Executors; /** * NettyServer - * + * * @author qian.lei * @author chao.liuc */ public class NettyServer extends AbstractServer implements Server { - + private static final Logger logger = LoggerFactory.getLogger(NettyServer.class); - private Map channels; // + private Map channels; // - private ServerBootstrap bootstrap; + private ServerBootstrap bootstrap; private org.jboss.netty.channel.Channel channel; - public NettyServer(URL url, ChannelHandler handler) throws RemotingException{ + public NettyServer(URL url, ChannelHandler handler) throws RemotingException { super(url, ChannelHandlers.wrap(handler, ExecutorUtil.setThreadName(url, SERVER_THREAD_POOL_NAME))); } @@ -70,7 +69,7 @@ protected void doOpen() throws Throwable { ExecutorService worker = Executors.newCachedThreadPool(new NamedThreadFactory("NettyServerWorker", true)); ChannelFactory channelFactory = new NioServerSocketChannelFactory(boss, worker, getUrl().getPositiveParameter(Constants.IO_THREADS_KEY, Constants.DEFAULT_IO_THREADS)); bootstrap = new ServerBootstrap(channelFactory); - + final NettyHandler nettyHandler = new NettyHandler(getUrl(), this); channels = nettyHandler.getChannels(); // https://issues.jboss.org/browse/NETTY-365 @@ -78,7 +77,7 @@ protected void doOpen() throws Throwable { // final Timer timer = new HashedWheelTimer(new NamedThreadFactory("NettyIdleTimer", true)); bootstrap.setPipelineFactory(new ChannelPipelineFactory() { public ChannelPipeline getPipeline() { - NettyCodecAdapter adapter = new NettyCodecAdapter(getCodec() ,getUrl(), NettyServer.this); + NettyCodecAdapter adapter = new NettyCodecAdapter(getCodec(), getUrl(), NettyServer.this); ChannelPipeline pipeline = Channels.pipeline(); /*int idleTimeout = getIdleTimeout(); if (idleTimeout > 10000) { @@ -105,9 +104,9 @@ protected void doClose() throws Throwable { logger.warn(e.getMessage(), e); } try { - Collection channels = getChannels(); + Collection channels = getChannels(); if (channels != null && channels.size() > 0) { - for (com.alibaba.dubbo.remoting.Channel channel : channels) { + for (Channel channel : channels) { try { channel.close(); } catch (Throwable e) { @@ -119,7 +118,7 @@ protected void doClose() throws Throwable { logger.warn(e.getMessage(), e); } try { - if (bootstrap != null) { + if (bootstrap != null) { // release external resource. bootstrap.releaseExternalResources(); } @@ -134,7 +133,7 @@ protected void doClose() throws Throwable { logger.warn(e.getMessage(), e); } } - + public Collection getChannels() { Collection chs = new HashSet(); for (Channel channel : this.channels.values()) { diff --git a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyTransporter.java b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyTransporter.java index f899a6f7d2c..1f78fbf8cca 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyTransporter.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/main/java/com/alibaba/dubbo/remoting/transport/netty/NettyTransporter.java @@ -13,28 +13,28 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting.transport.netty; - +package com.alibaba.dubbo.remoting.transport.netty; + import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; -import com.alibaba.dubbo.remoting.Transporter; - -/** - * @author ding.lid - */ -public class NettyTransporter implements Transporter { - - public static final String NAME = "netty"; - - public Server bind(URL url, ChannelHandler listener) throws RemotingException { - return new NettyServer(url, listener); - } - - public Client connect(URL url, ChannelHandler listener) throws RemotingException { - return new NettyClient(url, listener); - } - +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; +import com.alibaba.dubbo.remoting.transport.Transporter; + +/** + * @author ding.lid + */ +public class NettyTransporter implements Transporter { + + public static final String NAME = "netty"; + + public Server bind(URL url, ChannelHandler listener) throws RemotingException { + return new NettyServer(url, listener); + } + + public Client connect(URL url, ChannelHandler listener) throws RemotingException { + return new NettyClient(url, listener); + } + } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-netty/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Transporter b/dubbo-remoting/dubbo-remoting-netty/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.transport.Transporter similarity index 100% rename from dubbo-remoting/dubbo-remoting-netty/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Transporter rename to dubbo-remoting/dubbo-remoting-netty/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.transport.Transporter diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartbeatHandlerTest.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartbeatHandlerTest.java index d269b72e593..01d8a075b5d 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartbeatHandlerTest.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/exchange/support/header/HeartbeatHandlerTest.java @@ -23,8 +23,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/dispatcher/FakeChannelHandlers.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/dispatcher/FakeChannelHandlers.java index cc68e644c7a..3aab778d874 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/dispatcher/FakeChannelHandlers.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/dispatcher/FakeChannelHandlers.java @@ -18,7 +18,7 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; import com.alibaba.dubbo.remoting.Dispatcher; /** diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientReconnectTest.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientReconnectTest.java index f6ae87975fd..26865481076 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientReconnectTest.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientReconnectTest.java @@ -13,8 +13,8 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.remoting.transport.netty; - +package com.alibaba.dubbo.remoting.transport.netty; + import org.apache.log4j.Level; import org.junit.Assert; import org.junit.Test; @@ -23,45 +23,45 @@ import com.alibaba.dubbo.common.utils.DubboAppender; import com.alibaba.dubbo.common.utils.LogUtil; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; import com.alibaba.dubbo.remoting.exchange.Exchangers; import com.alibaba.dubbo.remoting.exchange.support.ExchangeHandlerAdapter; - -/** - * 客户端重连测试 - * @author chao.liuc - * - */ -public class ClientReconnectTest { - @Test - public void testReconnect() throws RemotingException, InterruptedException{ - { - int port = NetUtils.getAvailablePort(); - Client client = startClient(port, 200); - Assert.assertEquals(false, client.isConnected()); - Server server = startServer(port); - for (int i = 0; i < 100 && ! client.isConnected(); i++) { - Thread.sleep(10); - } - Assert.assertEquals(true, client.isConnected()); - client.close(2000); - server.close(2000); - } - { - int port = NetUtils.getAvailablePort(); - Client client = startClient(port, 20000); - Assert.assertEquals(false, client.isConnected()); - Server server = startServer(port); - for(int i=0;i<5;i++){ - Thread.sleep(200); - } - Assert.assertEquals(false, client.isConnected()); - client.close(2000); - server.close(2000); - } + +/** + * 客户端重连测试 + * @author chao.liuc + * + */ +public class ClientReconnectTest { + @Test + public void testReconnect() throws RemotingException, InterruptedException{ + { + int port = NetUtils.getAvailablePort(); + Client client = startClient(port, 200); + Assert.assertEquals(false, client.isConnected()); + Server server = startServer(port); + for (int i = 0; i < 100 && ! client.isConnected(); i++) { + Thread.sleep(10); + } + Assert.assertEquals(true, client.isConnected()); + client.close(2000); + server.close(2000); + } + { + int port = NetUtils.getAvailablePort(); + Client client = startClient(port, 20000); + Assert.assertEquals(false, client.isConnected()); + Server server = startServer(port); + for(int i=0;i<5;i++){ + Thread.sleep(200); + } + Assert.assertEquals(false, client.isConnected()); + client.close(2000); + server.close(2000); + } } /** @@ -156,24 +156,24 @@ public void testReconnectWaringLog() throws RemotingException, InterruptedExcept } Assert.assertTrue("warning message count must >= 1, real :"+count, count>= 1); DubboAppender.doStop(); - } - - public Client startClient(int port , int reconnectPeriod) throws RemotingException{ - final String url = "exchange://127.0.0.1:"+port + "/client.reconnect.test?check=false&"+Constants.RECONNECT_KEY+"="+reconnectPeriod; - return Exchangers.connect(url); - } - - public Server startServer(int port) throws RemotingException{ - final String url = "exchange://127.0.0.1:"+port +"/client.reconnect.test"; - return Exchangers.bind(url, new HandlerAdapter()); - } - - static class HandlerAdapter extends ExchangeHandlerAdapter{ - public void connected(Channel channel) throws RemotingException { - } - public void disconnected(Channel channel) throws RemotingException { - } - public void caught(Channel channel, Throwable exception) throws RemotingException { - } + } + + public Client startClient(int port , int reconnectPeriod) throws RemotingException{ + final String url = "exchange://127.0.0.1:"+port + "/client.reconnect.test?check=false&"+Constants.RECONNECT_KEY+"="+reconnectPeriod; + return Exchangers.connect(url); + } + + public Server startServer(int port) throws RemotingException{ + final String url = "exchange://127.0.0.1:"+port +"/client.reconnect.test"; + return Exchangers.bind(url, new HandlerAdapter()); + } + + static class HandlerAdapter extends ExchangeHandlerAdapter{ + public void connected(Channel channel) throws RemotingException { + } + public void disconnected(Channel channel) throws RemotingException { + } + public void caught(Channel channel, Throwable exception) throws RemotingException { + } } } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientToServerTest.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientToServerTest.java index 09e66523acd..e27d081772c 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientToServerTest.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientToServerTest.java @@ -1,50 +1,45 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.netty; -import junit.framework.Assert; -import junit.framework.TestCase; - -import org.junit.Test; - -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; import com.alibaba.dubbo.remoting.exchange.support.Replier; +import junit.framework.TestCase; /** * ClientToServer - * + * * @author william.liangf */ public abstract class ClientToServerTest extends TestCase { - + protected static final String LOCALHOST = "127.0.0.1"; - + protected ExchangeServer server; - + protected ExchangeChannel client; - + protected WorldHandler handler = new WorldHandler(); - + protected abstract ExchangeServer newServer(int port, Replier receiver) throws RemotingException; - + protected abstract ExchangeChannel newClient(int port) throws RemotingException; - + @Override protected void setUp() throws Exception { super.setUp(); @@ -64,30 +59,4 @@ protected void tearDown() throws Exception { client.close(); } } - - @Test - public void testFuture() throws Exception { - ResponseFuture future = client.request(new World("world")); - Hello result = (Hello)future.get(); - Assert.assertEquals("hello,world", result.getName()); - } - -// @Test -// public void testCallback() throws Exception { -// final Object waitter = new Object(); -// client.invoke(new World("world"), new InvokeCallback() { -// public void callback(Hello result) { -// Assert.assertEquals("hello,world", result.getName()); -// synchronized (waitter) { -// waitter.notifyAll(); -// } -// } -// public void onException(Throwable exception) { -// } -// }); -// synchronized (waitter) { -// waitter.wait(); -// } -// } - } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientsTest.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientsTest.java index 10aa3d7e9d4..e0696c1ea3a 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientsTest.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ClientsTest.java @@ -24,7 +24,7 @@ import org.junit.Test; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.Transporter; +import com.alibaba.dubbo.remoting.transport.Transporter; /** * @author ding.lid diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/NettyClientTest.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/NettyClientTest.java index c1da6d12fcc..81fcf74dfb9 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/NettyClientTest.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/NettyClientTest.java @@ -1,18 +1,18 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.netty; import java.util.ArrayList; @@ -23,8 +23,8 @@ import org.junit.Test; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.Exchangers; @@ -70,10 +70,10 @@ public static void tearDown() throws Exception { if (server != null) server.close(); } finally {} - } - - public static void main(String[] args) throws RemotingException, InterruptedException { - ExchangeChannel client = Exchangers.connect(URL.valueOf("exchange://10.20.153.10:20880?client=netty&heartbeat=1000")); - Thread.sleep(60*1000*50); + } + + public static void main(String[] args) throws RemotingException, InterruptedException { + ExchangeChannel client = Exchangers.connect(URL.valueOf("exchange://10.20.153.10:20880?client=netty&heartbeat=1000")); + Thread.sleep(60*1000*50); } } \ No newline at end of file diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/NettyClientToServerTest.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/NettyClientToServerTest.java index ea428718be7..e29b0625aa8 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/NettyClientToServerTest.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/NettyClientToServerTest.java @@ -1,22 +1,22 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.netty; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; import com.alibaba.dubbo.remoting.exchange.Exchangers; diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/TelnetClientHandler.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/TelnetClientHandler.java index 9f1aae580fb..8f874627e6d 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/TelnetClientHandler.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/TelnetClientHandler.java @@ -1,21 +1,21 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.netty; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.support.Replier; diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/TelnetServerHandler.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/TelnetServerHandler.java index ac5701b2403..92af6a0c048 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/TelnetServerHandler.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/TelnetServerHandler.java @@ -1,21 +1,21 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.netty; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.support.Replier; diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ThreadNameTest.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ThreadNameTest.java index 377fbb45015..907e04786ec 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ThreadNameTest.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/ThreadNameTest.java @@ -21,9 +21,9 @@ import org.junit.Test; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * @author kimi diff --git a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/WorldHandler.java b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/WorldHandler.java index 4e257bc4dfb..2e3b982ab93 100644 --- a/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/WorldHandler.java +++ b/dubbo-remoting/dubbo-remoting-netty/src/test/java/com/alibaba/dubbo/remoting/transport/netty/WorldHandler.java @@ -1,21 +1,21 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.remoting.transport.netty; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.support.Replier; diff --git a/dubbo-remoting/dubbo-remoting-p2p/pom.xml b/dubbo-remoting/dubbo-remoting-p2p/pom.xml index 0dce25f736f..1a261f46035 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/pom.xml +++ b/dubbo-remoting/dubbo-remoting-p2p/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-remoting - 2.8.4 + 3.0.1 dubbo-remoting-p2p jar diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Group.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Group.java index 60d003168e0..2a40348a779 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Group.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Group.java @@ -16,8 +16,8 @@ package com.alibaba.dubbo.remoting.p2p; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * Group. (SPI, Prototype, ThreadSafe) diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Networker.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Networker.java index 52983482e1b..cdc1192a10b 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Networker.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Networker.java @@ -17,7 +17,7 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.SPI; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * Networker. (SPI, Singleton, ThreadSafe) diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Networkers.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Networkers.java index 3df97f7b23d..3fa386d0df6 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Networkers.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Networkers.java @@ -17,8 +17,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * Networkers. (API, Static, ThreadSafe) diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Peer.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Peer.java index 5f511746a16..cf00655a56d 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Peer.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/Peer.java @@ -15,8 +15,8 @@ */ package com.alibaba.dubbo.remoting.p2p; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; /** * Peer. (SPI, Prototype, ThreadSafe) diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeGroup.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeGroup.java index a72587c5b7b..54f478e64f8 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeGroup.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeGroup.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.p2p.exchange; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; import com.alibaba.dubbo.remoting.p2p.Group; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeNetworker.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeNetworker.java index 84371195850..3a7de786faa 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeNetworker.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeNetworker.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.p2p.exchange; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; /** * Networker diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeNetworkers.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeNetworkers.java index fcb0f3af4bd..8867dc36376 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeNetworkers.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/ExchangeNetworkers.java @@ -17,7 +17,7 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; /** diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/AbstractExchangeGroup.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/AbstractExchangeGroup.java index d79ecd01e3c..b3f83432973 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/AbstractExchangeGroup.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/AbstractExchangeGroup.java @@ -22,10 +22,10 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/ExchangeServerPeer.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/ExchangeServerPeer.java index 5d59d992704..0c342aa4fb4 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/ExchangeServerPeer.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/ExchangeServerPeer.java @@ -24,9 +24,9 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/FileExchangeGroup.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/FileExchangeGroup.java index 83755345c0d..b2cfa88637f 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/FileExchangeGroup.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/FileExchangeGroup.java @@ -29,7 +29,7 @@ import com.alibaba.dubbo.common.utils.IOUtils; import com.alibaba.dubbo.common.utils.NamedThreadFactory; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; import com.alibaba.dubbo.remoting.p2p.exchange.ExchangePeer; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/FileExchangeNetworker.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/FileExchangeNetworker.java index 85d7a1b0fb5..f0b79008379 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/FileExchangeNetworker.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/FileExchangeNetworker.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.p2p.exchange.support; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.p2p.exchange.ExchangeGroup; import com.alibaba.dubbo.remoting.p2p.exchange.ExchangeNetworker; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/MulticastExchangeGroup.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/MulticastExchangeGroup.java index 3850261dbb1..e79941a4e38 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/MulticastExchangeGroup.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/MulticastExchangeGroup.java @@ -23,7 +23,7 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; import com.alibaba.dubbo.remoting.p2p.exchange.ExchangePeer; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/MulticastExchangeNetworker.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/MulticastExchangeNetworker.java index f2345cdb773..79508a7d20f 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/MulticastExchangeNetworker.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/exchange/support/MulticastExchangeNetworker.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.p2p.exchange.support; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.p2p.exchange.ExchangeGroup; import com.alibaba.dubbo.remoting.p2p.exchange.ExchangeNetworker; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/AbstractGroup.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/AbstractGroup.java index 2fff7bac359..ca9f9da448c 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/AbstractGroup.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/AbstractGroup.java @@ -22,10 +22,10 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; import com.alibaba.dubbo.remoting.Transporters; import com.alibaba.dubbo.remoting.p2p.Group; import com.alibaba.dubbo.remoting.p2p.Peer; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/FileGroup.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/FileGroup.java index 1ad645b79b1..6ad85a4adcc 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/FileGroup.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/FileGroup.java @@ -29,8 +29,8 @@ import com.alibaba.dubbo.common.utils.IOUtils; import com.alibaba.dubbo.common.utils.NamedThreadFactory; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.p2p.Peer; /** diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/FileNetworker.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/FileNetworker.java index 1aa4f8887dc..12e51f41f11 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/FileNetworker.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/FileNetworker.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.p2p.support; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.p2p.Group; import com.alibaba.dubbo.remoting.p2p.Networker; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/MulticastGroup.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/MulticastGroup.java index beca3ba9c96..82e24cc5c3f 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/MulticastGroup.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/MulticastGroup.java @@ -23,8 +23,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.p2p.Peer; /** diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/MulticastNetworker.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/MulticastNetworker.java index 4699f77ecce..218128787b9 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/MulticastNetworker.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/MulticastNetworker.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.remoting.p2p.support; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.p2p.Group; import com.alibaba.dubbo.remoting.p2p.Networker; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/ServerPeer.java b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/ServerPeer.java index a1ff4da47e2..ba1a49a28dd 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/ServerPeer.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/main/java/com/alibaba/dubbo/remoting/p2p/support/ServerPeer.java @@ -24,10 +24,10 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.Client; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Server; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.Client; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Server; import com.alibaba.dubbo.remoting.p2p.Group; import com.alibaba.dubbo.remoting.p2p.Peer; import com.alibaba.dubbo.remoting.transport.ServerDelegate; diff --git a/dubbo-remoting/dubbo-remoting-p2p/src/test/java/com/alibaba/dubbo/remoting/p2p/PeerMain.java b/dubbo-remoting/dubbo-remoting-p2p/src/test/java/com/alibaba/dubbo/remoting/p2p/PeerMain.java index de8d10995ab..0c9a91ccd78 100644 --- a/dubbo-remoting/dubbo-remoting-p2p/src/test/java/com/alibaba/dubbo/remoting/p2p/PeerMain.java +++ b/dubbo-remoting/dubbo-remoting-p2p/src/test/java/com/alibaba/dubbo/remoting/p2p/PeerMain.java @@ -17,8 +17,8 @@ import java.util.Collection; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.transport.ChannelHandlerAdapter; /** diff --git a/dubbo-remoting/dubbo-remoting-zookeeper/pom.xml b/dubbo-remoting/dubbo-remoting-zookeeper/pom.xml index 47520dae0d8..e9ed070ce81 100644 --- a/dubbo-remoting/dubbo-remoting-zookeeper/pom.xml +++ b/dubbo-remoting/dubbo-remoting-zookeeper/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-remoting - 2.8.4 + 3.0.1 dubbo-remoting-zookeeper jar diff --git a/dubbo-remoting/dubbo-remoting-zookeeper/src/main/java/com/alibaba/dubbo/remoting/zookeeper/curator/CuratorZookeeperClient.java b/dubbo-remoting/dubbo-remoting-zookeeper/src/main/java/com/alibaba/dubbo/remoting/zookeeper/curator/CuratorZookeeperClient.java index 6011e91c892..156d2d09df3 100644 --- a/dubbo-remoting/dubbo-remoting-zookeeper/src/main/java/com/alibaba/dubbo/remoting/zookeeper/curator/CuratorZookeeperClient.java +++ b/dubbo-remoting/dubbo-remoting-zookeeper/src/main/java/com/alibaba/dubbo/remoting/zookeeper/curator/CuratorZookeeperClient.java @@ -1,8 +1,10 @@ package com.alibaba.dubbo.remoting.zookeeper.curator; -import java.util.List; - import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.remoting.zookeeper.ChildListener; +import com.alibaba.dubbo.remoting.zookeeper.StateListener; +import com.alibaba.dubbo.remoting.zookeeper.support.AbstractZookeeperClient; import org.apache.curator.framework.CuratorFramework; import org.apache.curator.framework.CuratorFrameworkFactory; import org.apache.curator.framework.CuratorFrameworkFactory.Builder; @@ -14,131 +16,122 @@ import org.apache.zookeeper.KeeperException.NoNodeException; import org.apache.zookeeper.KeeperException.NodeExistsException; import org.apache.zookeeper.WatchedEvent; +import org.apache.zookeeper.Watcher; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.zookeeper.ChildListener; -import com.alibaba.dubbo.remoting.zookeeper.StateListener; -import com.alibaba.dubbo.remoting.zookeeper.support.AbstractZookeeperClient; +import java.util.List; -public class CuratorZookeeperClient extends - AbstractZookeeperClient { +public class CuratorZookeeperClient extends AbstractZookeeperClient { - private final CuratorFramework client; + private final CuratorFramework client; - public CuratorZookeeperClient(URL url) { - super(url); - Builder builder = CuratorFrameworkFactory.builder() - .connectString(url.getBackupAddress()) - .retryPolicy(new RetryNTimes(Integer.MAX_VALUE, 1000)) - .connectionTimeoutMs(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_REGISTRY_CONNECT_TIMEOUT)) + public CuratorZookeeperClient(URL url) { + super(url); + Builder builder = CuratorFrameworkFactory.builder() + .connectString(url.getBackupAddress()) + .retryPolicy(new RetryNTimes(Integer.MAX_VALUE, 1000)) + .connectionTimeoutMs(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_REGISTRY_CONNECT_TIMEOUT)) .sessionTimeoutMs(url.getParameter(Constants.SESSION_TIMEOUT_KEY, Constants.DEFAULT_SESSION_TIMEOUT)); - String authority = url.getAuthority(); - if (authority != null && authority.length() > 0) { - builder = builder.authorization("digest", authority.getBytes()); - } - client = builder.build(); - client.getConnectionStateListenable().addListener( - new ConnectionStateListener() { - public void stateChanged(CuratorFramework client, - ConnectionState state) { - if (state == ConnectionState.LOST) { - CuratorZookeeperClient.this - .stateChanged(StateListener.DISCONNECTED); - } else if (state == ConnectionState.CONNECTED) { - CuratorZookeeperClient.this - .stateChanged(StateListener.CONNECTED); - } else if (state == ConnectionState.RECONNECTED) { - CuratorZookeeperClient.this - .stateChanged(StateListener.RECONNECTED); - } - } - }); - client.start(); - } - - public void createPersistent(String path) { - try { - client.create().forPath(path); - } catch (NodeExistsException e) { - } catch (Exception e) { - throw new IllegalStateException(e.getMessage(), e); - } - } - - public void createEphemeral(String path) { - try { - client.create().withMode(CreateMode.EPHEMERAL).forPath(path); - } catch (NodeExistsException e) { - } catch (Exception e) { - throw new IllegalStateException(e.getMessage(), e); - } - } - - public void delete(String path) { - try { - client.delete().forPath(path); - } catch (NoNodeException e) { - } catch (Exception e) { - throw new IllegalStateException(e.getMessage(), e); - } - } - - public List getChildren(String path) { - try { - return client.getChildren().forPath(path); - } catch (NoNodeException e) { - return null; - } catch (Exception e) { - throw new IllegalStateException(e.getMessage(), e); - } - } - - public boolean isConnected() { - return client.getZookeeperClient().isConnected(); - } - - public void doClose() { - client.close(); - } - - private class CuratorWatcherImpl implements CuratorWatcher { - - private volatile ChildListener listener; - - public CuratorWatcherImpl(ChildListener listener) { - this.listener = listener; - } - - public void unwatch() { - this.listener = null; - } - - public void process(WatchedEvent event) throws Exception { - if (listener != null) { - listener.childChanged(event.getPath(), client.getChildren() - .usingWatcher(this).forPath(event.getPath())); - } - } - } - - public CuratorWatcher createTargetChildListener(String path, - ChildListener listener) { - return new CuratorWatcherImpl(listener); - } - - public List addTargetChildListener(String path, - CuratorWatcher listener) { - try { - return client.getChildren().usingWatcher(listener).forPath(path); - } catch (NoNodeException e) { - return null; - } catch (Exception e) { - throw new IllegalStateException(e.getMessage(), e); - } - } - - public void removeTargetChildListener(String path, CuratorWatcher listener) { - ((CuratorWatcherImpl) listener).unwatch(); - } + String authority = url.getAuthority(); + if (authority != null && authority.length() > 0) { + builder = builder.authorization("digest", authority.getBytes()); + } + client = builder.build(); + client.getConnectionStateListenable().addListener( + new ConnectionStateListener() { + public void stateChanged(CuratorFramework client, ConnectionState state) { + if (state == ConnectionState.LOST) { + CuratorZookeeperClient.this.stateChanged(StateListener.DISCONNECTED); + } else if (state == ConnectionState.CONNECTED) { + CuratorZookeeperClient.this.stateChanged(StateListener.CONNECTED); + } else if (state == ConnectionState.RECONNECTED) { + CuratorZookeeperClient.this.stateChanged(StateListener.RECONNECTED); + } + } + }); + client.start(); + } + + public void createPersistent(String path) { + try { + client.create().forPath(path); + } catch (NodeExistsException ignored) { + } catch (Exception e) { + throw new IllegalStateException(e.getMessage(), e); + } + } + + public void createEphemeral(String path) { + try { + client.create().withMode(CreateMode.EPHEMERAL).forPath(path); + } catch (NodeExistsException ignored) { + } catch (Exception e) { + throw new IllegalStateException(e.getMessage(), e); + } + } + + public void delete(String path) { + try { + client.delete().forPath(path); + } catch (NoNodeException ignored) { + } catch (Exception e) { + throw new IllegalStateException(e.getMessage(), e); + } + } + + public List getChildren(String path) { + try { + return client.getChildren().forPath(path); + } catch (NoNodeException e) { + return null; + } catch (Exception e) { + throw new IllegalStateException(e.getMessage(), e); + } + } + + public boolean isConnected() { + return client.getZookeeperClient().isConnected(); + } + + public void doClose() { + client.close(); + } + + private class CuratorWatcherImpl implements CuratorWatcher { + + private volatile ChildListener listener; + + public CuratorWatcherImpl(ChildListener listener) { + this.listener = listener; + } + + public void unwatch() { + this.listener = null; + } + + public void process(WatchedEvent event) throws Exception { + if (event.getType() == Watcher.Event.EventType.NodeChildrenChanged && listener != null) { + listener.childChanged(event.getPath(), client.getChildren() + .usingWatcher(this).forPath(event.getPath())); + } + } + } + + public CuratorWatcher createTargetChildListener(String path, ChildListener listener) { + return new CuratorWatcherImpl(listener); + } + + public List addTargetChildListener(String path, CuratorWatcher listener) { + try { + return client.getChildren().usingWatcher(listener).forPath(path); + } catch (NoNodeException e) { + return null; + } catch (Exception e) { + throw new IllegalStateException(e.getMessage(), e); + } + } + + public void removeTargetChildListener(String path, CuratorWatcher listener) { + ((CuratorWatcherImpl) listener).unwatch(); + } } diff --git a/dubbo-remoting/pom.xml b/dubbo-remoting/pom.xml index 0c7faf42bbc..6b79897f7ed 100644 --- a/dubbo-remoting/pom.xml +++ b/dubbo-remoting/pom.xml @@ -18,7 +18,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-remoting pom @@ -35,5 +35,6 @@ dubbo-remoting-p2p dubbo-remoting-http dubbo-remoting-zookeeper - + dubbo-remoting-common + \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/pom.xml b/dubbo-rpc/dubbo-rpc-api/pom.xml index e713642d38e..39f851fce98 100644 --- a/dubbo-rpc/dubbo-rpc-api/pom.xml +++ b/dubbo-rpc/dubbo-rpc-api/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-rpc - 2.8.4 + 3.0.1 dubbo-rpc-api jar @@ -34,5 +34,27 @@ dubbo-common ${project.parent.version} + + com.google.guava + guava + 19.0 + + + com.netflix.hystrix + hystrix-core + 1.5.10 + + + + com.netflix.hystrix + hystrix-metrics-event-stream + 1.5.10 + + + + net.bytebuddy + byte-buddy + 1.6.9 + \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/ProxyFactory.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/ProxyFactory.java index 4369050a547..87f63f7e970 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/ProxyFactory.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/ProxyFactory.java @@ -22,7 +22,7 @@ /** * ProxyFactory. (API/SPI, Singleton, ThreadSafe) - * + * * @author william.liangf */ @SPI("javassist") @@ -30,7 +30,7 @@ public interface ProxyFactory { /** * create proxy. - * + * * @param invoker * @return proxy */ @@ -39,7 +39,7 @@ public interface ProxyFactory { /** * create invoker. - * + * * @param * @param proxy * @param type diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcConstants.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcConstants.java deleted file mode 100644 index c1275d5e731..00000000000 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcConstants.java +++ /dev/null @@ -1,31 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.rpc; - -import com.alibaba.dubbo.common.Constants; - -/** - * RpcConstants - * - * @deprecated Replace to com.alibaba.dubbo.common.Constants - * @author william.liangf - */ -@Deprecated -public final class RpcConstants extends Constants { - - private RpcConstants() {} - -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcContext.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcContext.java index e0d6cd75236..aebd9dc62d9 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcContext.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcContext.java @@ -15,64 +15,50 @@ */ package com.alibaba.dubbo.rpc; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.utils.NetUtils; + import java.net.InetSocketAddress; -import java.util.ArrayList; -import java.util.Arrays; import java.util.HashMap; -import java.util.List; import java.util.Map; -import java.util.concurrent.Callable; -import java.util.concurrent.ExecutionException; -import java.util.concurrent.Future; -import java.util.concurrent.FutureTask; -import java.util.concurrent.TimeUnit; -import java.util.concurrent.TimeoutException; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.utils.NetUtils; /** * Thread local context. (API, ThreadLocal, ThreadSafe) - * + *

* 注意:RpcContext是一个临时状态记录器,当接收到RPC请求,或发起RPC请求时,RpcContext的状态都会变化。 * 比如:A调B,B再调C,则B机器上,在B调C之前,RpcContext记录的是A调B的信息,在B调C之后,RpcContext记录的是B调C的信息。 - * - * @see com.alibaba.dubbo.rpc.filter.ContextFilter + * * @author qian.lei * @author william.liangf * @export + * @see com.alibaba.dubbo.rpc.filter.ContextFilter */ public class RpcContext { - - private static final ThreadLocal LOCAL = new ThreadLocal() { - @Override - protected RpcContext initialValue() { - return new RpcContext(); - } - }; - - /** - * get context. - * - * @return context - */ - public static RpcContext getContext() { - return LOCAL.get(); - } - - /** - * remove context. - * - * @see com.alibaba.dubbo.rpc.filter.ContextFilter - */ - public static void removeContext() { - LOCAL.remove(); - } - - private Future future; - - private List urls; + + private static final ThreadLocal LOCAL = new ThreadLocal() { + @Override + protected RpcContext initialValue() { + return new RpcContext(); + } + }; + + /** + * get context. + * + * @return context + */ + public static RpcContext getContext() { + return LOCAL.get(); + } + + /** + * remove context. + * + * @see com.alibaba.dubbo.rpc.filter.ContextFilter + */ + public static void removeContext() { + LOCAL.remove(); + } private URL url; @@ -82,9 +68,9 @@ public static void removeContext() { private Object[] arguments; - private InetSocketAddress localAddress; + private InetSocketAddress localAddress; - private InetSocketAddress remoteAddress; + private InetSocketAddress remoteAddress; private final Map attachments = new HashMap(); @@ -95,17 +81,9 @@ public static void removeContext() { private Object request; private Object response; - @Deprecated - private List> invokers; - - @Deprecated - private Invoker invoker; - @Deprecated - private Invocation invocation; - - protected RpcContext() { - } + protected RpcContext() { + } /** * Get the request object of the underlying RPC protocol, e.g. HttpServletRequest @@ -154,81 +132,6 @@ public void setResponse(Object response) { this.response = response; } - /** - * is provider side. - * - * @return provider side. - */ - public boolean isProviderSide() { - URL url = getUrl(); - if (url == null) { - return false; - } - InetSocketAddress address = getRemoteAddress(); - if (address == null) { - return false; - } - String host; - if (address.getAddress() == null) { - host = address.getHostName(); - } else { - host = address.getAddress().getHostAddress(); - } - return url.getPort() != address.getPort() || - ! NetUtils.filterLocalHost(url.getIp()).equals(NetUtils.filterLocalHost(host)); - } - - /** - * is consumer side. - * - * @return consumer side. - */ - public boolean isConsumerSide() { - URL url = getUrl(); - if (url == null) { - return false; - } - InetSocketAddress address = getRemoteAddress(); - if (address == null) { - return false; - } - String host; - if (address.getAddress() == null) { - host = address.getHostName(); - } else { - host = address.getAddress().getHostAddress(); - } - return url.getPort() == address.getPort() && - NetUtils.filterLocalHost(url.getIp()).equals(NetUtils.filterLocalHost(host)); - } - - /** - * get future. - * - * @param - * @return future - */ - @SuppressWarnings("unchecked") - public Future getFuture() { - return (Future) future; - } - - /** - * set future. - * - * @param future - */ - public void setFuture(Future future) { - this.future = future; - } - - public List getUrls() { - return urls == null && url != null ? (List) Arrays.asList(url) : urls; - } - - public void setUrls(List urls) { - this.urls = urls; - } public URL getUrl() { return url; @@ -240,7 +143,7 @@ public void setUrl(URL url) { /** * get method name. - * + * * @return method name. */ public String getMethodName() { @@ -253,7 +156,7 @@ public void setMethodName(String methodName) { /** * get parameter types. - * + * * @serial */ public Class[] getParameterTypes() { @@ -266,7 +169,7 @@ public void setParameterTypes(Class[] parameterTypes) { /** * get arguments. - * + * * @return arguments. */ public Object[] getArguments() { @@ -279,22 +182,22 @@ public void setArguments(Object[] arguments) { /** * set local address. - * + * * @param address * @return context */ - public RpcContext setLocalAddress(InetSocketAddress address) { - this.localAddress = address; - return this; - } - - /** - * set local address. - * - * @param host - * @param port - * @return context - */ + public RpcContext setLocalAddress(InetSocketAddress address) { + this.localAddress = address; + return this; + } + + /** + * set local address. + * + * @param host + * @param port + * @return context + */ public RpcContext setLocalAddress(String host, int port) { if (port < 0) { port = 0; @@ -303,35 +206,35 @@ public RpcContext setLocalAddress(String host, int port) { return this; } - /** - * get local address. - * - * @return local address - */ - public InetSocketAddress getLocalAddress() { - return localAddress; - } + /** + * get local address. + * + * @return local address + */ + public InetSocketAddress getLocalAddress() { + return localAddress; + } - public String getLocalAddressString() { + public String getLocalAddressString() { return getLocalHost() + ":" + getLocalPort(); } - - /** - * get local host name. - * - * @return local host name - */ - public String getLocalHostName() { - String host = localAddress == null ? null : localAddress.getHostName(); - if (host == null || host.length() == 0) { - return getLocalHost(); - } - return host; - } + + /** + * get local host name. + * + * @return local host name + */ + public String getLocalHostName() { + String host = localAddress == null ? null : localAddress.getHostName(); + if (host == null || host.length() == 0) { + return getLocalHost(); + } + return host; + } /** * set remote address. - * + * * @param address * @return context */ @@ -339,10 +242,10 @@ public RpcContext setRemoteAddress(InetSocketAddress address) { this.remoteAddress = address; return this; } - + /** * set remote address. - * + * * @param host * @param port * @return context @@ -355,42 +258,42 @@ public RpcContext setRemoteAddress(String host, int port) { return this; } - /** - * get remote address. - * - * @return remote address - */ - public InetSocketAddress getRemoteAddress() { - return remoteAddress; - } - - /** - * get remote address string. - * - * @return remote address string. - */ - public String getRemoteAddressString() { - return getRemoteHost() + ":" + getRemotePort(); - } - - /** - * get remote host name. - * - * @return remote host name - */ - public String getRemoteHostName() { - return remoteAddress == null ? null : remoteAddress.getHostName(); - } + /** + * get remote address. + * + * @return remote address + */ + public InetSocketAddress getRemoteAddress() { + return remoteAddress; + } + + /** + * get remote address string. + * + * @return remote address string. + */ + public String getRemoteAddressString() { + return getRemoteHost() + ":" + getRemotePort(); + } + + /** + * get remote host name. + * + * @return remote host name + */ + public String getRemoteHostName() { + return remoteAddress == null ? null : remoteAddress.getHostName(); + } /** * get local host. - * + * * @return local host */ public String getLocalHost() { - String host = localAddress == null ? null : - localAddress.getAddress() == null ? localAddress.getHostName() - : NetUtils.filterLocalHost(localAddress.getAddress().getHostAddress()); + String host = localAddress == null ? null : + localAddress.getAddress() == null ? localAddress.getHostName() + : NetUtils.filterLocalHost(localAddress.getAddress().getHostAddress()); if (host == null || host.length() == 0) { return NetUtils.getLocalHost(); } @@ -399,7 +302,7 @@ public String getLocalHost() { /** * get local port. - * + * * @return port */ public int getLocalPort() { @@ -408,18 +311,18 @@ public int getLocalPort() { /** * get remote host. - * + * * @return remote host */ public String getRemoteHost() { - return remoteAddress == null ? null : - remoteAddress.getAddress() == null ? remoteAddress.getHostName() - : NetUtils.filterLocalHost(remoteAddress.getAddress().getHostAddress()); + return remoteAddress == null ? null : + remoteAddress.getAddress() == null ? remoteAddress.getHostName() + : NetUtils.filterLocalHost(remoteAddress.getAddress().getHostAddress()); } /** * get remote port. - * + * * @return remote port */ public int getRemotePort() { @@ -428,7 +331,7 @@ public int getRemotePort() { /** * get attachment. - * + * * @param key * @return attachment */ @@ -438,7 +341,7 @@ public String getAttachment(String key) { /** * set attachment. - * + * * @param key * @param value * @return context @@ -454,7 +357,7 @@ public RpcContext setAttachment(String key, String value) { /** * remove attachment. - * + * * @param key * @return context */ @@ -465,7 +368,7 @@ public RpcContext removeAttachment(String key) { /** * get attachments. - * + * * @return attachments */ public Map getAttachments() { @@ -474,7 +377,7 @@ public Map getAttachments() { /** * set attachments - * + * * @param attachment * @return context */ @@ -485,14 +388,14 @@ public RpcContext setAttachments(Map attachment) { } return this; } - + public void clearAttachments() { this.attachments.clear(); } /** * get values. - * + * * @return values */ public Map get() { @@ -501,7 +404,7 @@ public Map get() { /** * set value. - * + * * @param key * @param value * @return context @@ -517,7 +420,7 @@ public RpcContext set(String key, Object value) { /** * remove value. - * + * * @param key * @return value */ @@ -528,7 +431,7 @@ public RpcContext remove(String key) { /** * get value. - * + * * @param key * @return value */ @@ -536,20 +439,7 @@ public Object get(String key) { return values.get(key); } - public RpcContext setInvokers(List> invokers) { - this.invokers = invokers; - if (invokers != null && invokers.size() > 0) { - List urls = new ArrayList(invokers.size()); - for (Invoker invoker : invokers) { - urls.add(invoker.getUrl()); - } - setUrls(urls); - } - return this; - } - public RpcContext setInvoker(Invoker invoker) { - this.invoker = invoker; if (invoker != null) { setUrl(invoker.getUrl()); } @@ -557,7 +447,6 @@ public RpcContext setInvoker(Invoker invoker) { } public RpcContext setInvocation(Invocation invocation) { - this.invocation = invocation; if (invocation != null) { setMethodName(invocation.getMethodName()); setParameterTypes(invocation.getParameterTypes()); @@ -565,113 +454,4 @@ public RpcContext setInvocation(Invocation invocation) { } return this; } - - /** - * @deprecated Replace to isProviderSide() - */ - @Deprecated - public boolean isServerSide() { - return isProviderSide(); - } - - /** - * @deprecated Replace to isConsumerSide() - */ - @Deprecated - public boolean isClientSide() { - return isConsumerSide(); - } - - /** - * @deprecated Replace to getUrls() - */ - @Deprecated - @SuppressWarnings({ "unchecked", "rawtypes" }) - public List> getInvokers() { - return invokers == null && invoker != null ? (List)Arrays.asList(invoker) : invokers; - } - - /** - * @deprecated Replace to getUrl() - */ - @Deprecated - public Invoker getInvoker() { - return invoker; - } - - /** - * @deprecated Replace to getMethodName(), getParameterTypes(), getArguments() - */ - @Deprecated - public Invocation getInvocation() { - return invocation; - } - - /** - * 异步调用 ,需要返回值,即使步调用Future.get方法,也会处理调用超时问题. - * @param callable - * @return 通过future.get()获取返回结果. - */ - @SuppressWarnings("unchecked") - public Future asyncCall(Callable callable) { - try { - try { - setAttachment(Constants.ASYNC_KEY, Boolean.TRUE.toString()); - final T o = callable.call(); - //local调用会直接返回结果. - if (o != null) { - FutureTask f = new FutureTask(new Callable() { - public T call() throws Exception { - return o; - } - }); - f.run(); - return f; - } else { - - } - } catch (Exception e) { - throw new RpcException(e); - } finally { - removeAttachment(Constants.ASYNC_KEY); - } - } catch (final RpcException e) { - return new Future() { - public boolean cancel(boolean mayInterruptIfRunning) { - return false; - } - public boolean isCancelled() { - return false; - } - public boolean isDone() { - return true; - } - public T get() throws InterruptedException, ExecutionException { - throw new ExecutionException(e.getCause()); - } - public T get(long timeout, TimeUnit unit) - throws InterruptedException, ExecutionException, - TimeoutException { - return get(); - } - }; - } - return ((Future)getContext().getFuture()); - } - - /** - * oneway调用,只发送请求,不接收返回结果. - * @param callable - */ - public void asyncCall(Runnable runable) { - try { - setAttachment(Constants.RETURN_KEY, Boolean.FALSE.toString()); - runable.run(); - } catch (Throwable e) { - //FIXME 异常是否应该放在future中? - throw new RpcException("oneway call error ." + e.getMessage(), e); - } finally { - removeAttachment(Constants.RETURN_KEY); - } - } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcInvocation.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcInvocation.java index 92c5ce4de7d..d1d83dfbc66 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcInvocation.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcInvocation.java @@ -15,32 +15,32 @@ */ package com.alibaba.dubbo.rpc; +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.URL; + import java.io.Serializable; import java.lang.reflect.Method; import java.util.Arrays; import java.util.HashMap; import java.util.Map; -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; - /** * RPC Invocation. - * - * @serial Don't change the class name and properties. + * * @author qian.lei + * @serial Don't change the class name and properties. */ public class RpcInvocation implements Invocation, Serializable { private static final long serialVersionUID = -4355285085441097045L; - private String methodName; + private String methodName; - private Class[] parameterTypes; + private Class[] parameterTypes; - private Object[] arguments; + private Object[] arguments; - private Map attachments; + private Map attachments; private transient Invoker invoker; @@ -48,7 +48,7 @@ public RpcInvocation() { } public RpcInvocation(Invocation invocation, Invoker invoker) { - this(invocation.getMethodName(), invocation.getParameterTypes(), + this(invocation.getMethodName(), invocation.getParameterTypes(), invocation.getArguments(), new HashMap(invocation.getAttachments()), invocation.getInvoker()); if (invoker != null) { @@ -76,7 +76,7 @@ public RpcInvocation(Invocation invocation, Invoker invoker) { } public RpcInvocation(Invocation invocation) { - this(invocation.getMethodName(), invocation.getParameterTypes(), + this(invocation.getMethodName(), invocation.getParameterTypes(), invocation.getArguments(), invocation.getAttachments(), invocation.getInvoker()); } @@ -103,7 +103,7 @@ public RpcInvocation(String methodName, Class[] parameterTypes, Object[] argu this.attachments = attachments == null ? new HashMap() : attachments; this.invoker = invoker; } - + public Invoker getInvoker() { return invoker; } @@ -143,7 +143,7 @@ public void setArguments(Object[] arguments) { public void setAttachments(Map attachments) { this.attachments = attachments == null ? new HashMap() : attachments; } - + public void setAttachment(String key, String value) { if (attachments == null) { attachments = new HashMap(); @@ -155,28 +155,28 @@ public void setAttachmentIfAbsent(String key, String value) { if (attachments == null) { attachments = new HashMap(); } - if (! attachments.containsKey(key)) { - attachments.put(key, value); + if (!attachments.containsKey(key)) { + attachments.put(key, value); } } public void addAttachments(Map attachments) { - if (attachments == null) { - return; - } - if (this.attachments == null) { - this.attachments = new HashMap(); + if (attachments == null) { + return; + } + if (this.attachments == null) { + this.attachments = new HashMap(); } - this.attachments.putAll(attachments); + this.attachments.putAll(attachments); } public void addAttachmentsIfAbsent(Map attachments) { - if (attachments == null) { - return; - } - for (Map.Entry entry : attachments.entrySet()) { - setAttachmentIfAbsent(entry.getKey(), entry.getValue()); - } + if (attachments == null) { + return; + } + for (Map.Entry entry : attachments.entrySet()) { + setAttachmentIfAbsent(entry.getKey(), entry.getValue()); + } } public String getAttachment(String key) { @@ -185,7 +185,7 @@ public String getAttachment(String key) { } return attachments.get(key); } - + public String getAttachment(String key, String defaultValue) { if (attachments == null) { return defaultValue; diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcResult.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcResult.java index 64f36a5c299..ac96b8962d1 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcResult.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/RpcResult.java @@ -21,28 +21,28 @@ /** * RPC Result. - * - * @serial Don't change the class name and properties. + * * @author qianlei + * @serial Don't change the class name and properties. */ public class RpcResult implements Result, Serializable { - private static final long serialVersionUID = -6925924956850004727L; + private static final long serialVersionUID = -6925924956850004727L; - private Object result; + private Object result; - private Throwable exception; + private Throwable exception; - private Map attachments = new HashMap(); + private Map attachments = new HashMap(); - public RpcResult(){ + public RpcResult() { } - public RpcResult(Object result){ + public RpcResult(Object result) { this.result = result; } - public RpcResult(Throwable exception){ + public RpcResult(Throwable exception) { this.exception = exception; } @@ -54,8 +54,8 @@ public Object recreate() throws Throwable { } /** - * @deprecated Replace to getValue() * @see com.alibaba.dubbo.rpc.RpcResult#getValue() + * @deprecated Replace to getValue() */ @Deprecated public Object getResult() { @@ -63,8 +63,8 @@ public Object getResult() { } /** + * @see com.alibaba.dubbo.rpc.RpcResult * @deprecated Replace to setValue() - * @see com.alibaba.dubbo.rpc.RpcResult#setValue() */ @Deprecated public void setResult(Object result) { diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/StaticContext.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/StaticContext.java deleted file mode 100644 index 14825b7fa1f..00000000000 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/StaticContext.java +++ /dev/null @@ -1,72 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.rpc; - -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.utils.StringUtils; - -/** - * 系统存储,内部类. - */ -public class StaticContext extends ConcurrentHashMap{ - private static final long serialVersionUID = 1L; - private static final String SYSTEMNAME = "system"; - private String name ; - - private static final ConcurrentMap context_map = new ConcurrentHashMap() ; - - private StaticContext(String name) { - super(); - this.name = name; - } - - public String getName() { - return name; - } - - public static StaticContext getSystemContext() { - return getContext(SYSTEMNAME); - } - - public static StaticContext getContext(String name) { - StaticContext appContext = context_map.get(name); - if (appContext == null){ - appContext = context_map.putIfAbsent(name, new StaticContext(name)); - if (appContext == null){ - appContext = context_map.get(name); - } - } - return appContext; - } - public static StaticContext remove(String name){ - return context_map.remove(name); - } - - public static String getKey(URL url, String methodName, String suffix) { - return getKey(url.getServiceKey(), methodName, suffix); - } - public static String getKey(Map paras, String methodName, String suffix) { - return getKey(StringUtils.getServiceKey(paras), methodName, suffix); - } - private static String getKey(String servicekey, String methodName, String suffix) { - StringBuffer sb = new StringBuffer().append(servicekey).append(".").append(methodName).append(".").append(suffix); - return sb.toString(); - } -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/AsyncCommand.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/AsyncCommand.java new file mode 100644 index 00000000000..14614dc436d --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/AsyncCommand.java @@ -0,0 +1,65 @@ +package com.alibaba.dubbo.rpc.async; + +import com.alibaba.dubbo.rpc.RpcException; +import com.google.common.base.Preconditions; +import com.google.common.util.concurrent.ListenableFuture; + +import java.util.concurrent.atomic.AtomicReference; + +/** + * @author Xs + */ +public abstract class AsyncCommand { + + + public static final String COMMON_KEY = "common-command"; + + public static final int COMMON_CORE_SIZE = 64; + + public static final int UNKNOWN_CORE_SIZE = 10; + + private final CommandExecutor commandExecutor; + + private final CommandExecutorFactory factory = CommandExecutorFactory.getInstance(); + + protected final AtomicReference state = new AtomicReference(State.LATENT); + + protected enum State { + LATENT, STARTED, FINISHED + } + + public AsyncCommand() { + this(COMMON_KEY, COMMON_CORE_SIZE); + } + + public AsyncCommand(String key) { + this(key, UNKNOWN_CORE_SIZE); + } + + public AsyncCommand(String key, int coreSize) { + commandExecutor = initExecutor(key, coreSize); + } + + private CommandExecutor initExecutor(String key, int coreSize) { + return factory.getCommandExecutor(key, coreSize); + } + + public ListenableFuture queue() { + checkState(); + return commandExecutor.execute(this); + } + + public T execute() { + try { + return queue().get(); + } catch (Exception e) { + throw new RpcException(e); + } + } + + protected void checkState() { + Preconditions.checkState(state.compareAndSet(State.LATENT, State.STARTED), "command could not be executed more than once"); + } + + public abstract T run() throws Exception; +} diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandExecutor.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandExecutor.java new file mode 100644 index 00000000000..61047858e78 --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandExecutor.java @@ -0,0 +1,34 @@ +package com.alibaba.dubbo.rpc.async; + +import com.google.common.util.concurrent.ListenableFuture; +import com.google.common.util.concurrent.ListeningExecutorService; + +import java.io.Closeable; +import java.util.concurrent.Callable; + +/** + * @author Xs + */ +public class CommandExecutor implements Closeable { + + private final ListeningExecutorService commandExecutor; + + public CommandExecutor(ListeningExecutorService commandExecutor) { + this.commandExecutor = commandExecutor; + } + + public ListenableFuture execute(final AsyncCommand command) { + return commandExecutor.submit(new Callable() { + @Override + public T call() throws Exception { + return command.run(); + } + }); + } + + public void close() { + if (commandExecutor != null) { + commandExecutor.shutdown(); + } + } +} diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandExecutorFactory.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandExecutorFactory.java new file mode 100644 index 00000000000..edfba1504ff --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandExecutorFactory.java @@ -0,0 +1,42 @@ +package com.alibaba.dubbo.rpc.async; + +import com.alibaba.dubbo.common.utils.NamedThreadFactory; +import com.google.common.util.concurrent.MoreExecutors; + +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.Executors; + +/** + * @author Xs + */ +public class CommandExecutorFactory { + + private static final Map threadPools = new ConcurrentHashMap(); + + @SuppressWarnings("unchecked") + public CommandExecutor getCommandExecutor(String key, int coreSize) { + + CommandExecutor previouslyCached = threadPools.get(key); + if (previouslyCached != null) { + return previouslyCached; + } + synchronized (CommandExecutorFactory.class) { + if (!threadPools.containsKey(key)) { + CommandExecutor commandExecutor = new CommandExecutor(MoreExecutors.listeningDecorator( + Executors.newFixedThreadPool(coreSize, + new NamedThreadFactory("asyncCommand", Boolean.TRUE)))); + threadPools.put(key, commandExecutor); + } + } + return threadPools.get(key); + } + + public static CommandExecutorFactory getInstance() { + return Holder.INSTANCE; + } + + private static class Holder { + public static CommandExecutorFactory INSTANCE = new CommandExecutorFactory(); + } +} diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandListener.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandListener.java new file mode 100644 index 00000000000..1eff64e97fb --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/CommandListener.java @@ -0,0 +1,6 @@ +package com.alibaba.dubbo.rpc.async; + +import com.google.common.util.concurrent.FutureCallback; + +public interface CommandListener extends FutureCallback { +} diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/ListenableAsyncCommand.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/ListenableAsyncCommand.java new file mode 100644 index 00000000000..9a6d3c7abbd --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/async/ListenableAsyncCommand.java @@ -0,0 +1,38 @@ +package com.alibaba.dubbo.rpc.async; + +import com.alibaba.dubbo.common.utils.Assert; +import com.google.common.util.concurrent.Futures; + +/** + * @author Xs + */ +public abstract class ListenableAsyncCommand extends AsyncCommand { + + private CommandListener listener; + + public void submit() { + if (listener != null) { + Futures.addCallback(queue(), listener); + } else { + throw new IllegalStateException("listener must not be null, you can use queue() instead"); + } + } + + public void submitWithListener(CommandListener listener) { + Assert.notNull(listener, "listener must be null"); + this.listener = listener; + this.submit(); + } + + public ListenableAsyncCommand addListener(CommandListener listener) { + check(); + this.listener = listener; + return this; + } + + private void check() { + if (state.get() != State.LATENT) { + throw new IllegalStateException("listener should be added before command started."); + } + } +} diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ActiveLimitFilter.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ActiveLimitFilter.java index c7d33a35494..bfe90cc830b 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ActiveLimitFilter.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ActiveLimitFilter.java @@ -18,16 +18,11 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.Activate; -import com.alibaba.dubbo.rpc.Filter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcStatus; +import com.alibaba.dubbo.rpc.*; /** * LimitInvokerFilter - * + * * @author william.liangf */ @Activate(group = Constants.CONSUMER, value = Constants.ACTIVES_KEY) @@ -44,20 +39,20 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept long remain = timeout; int active = count.getActive(); if (active >= max) { - synchronized (count) { + synchronized (this) { while ((active = count.getActive()) >= max) { try { count.wait(remain); - } catch (InterruptedException e) { + } catch (InterruptedException ignored) { } long elapsed = System.currentTimeMillis() - start; remain = timeout - elapsed; if (remain <= 0) { throw new RpcException("Waiting concurrent invoke timeout in client-side for service: " - + invoker.getInterface().getName() + ", method: " - + invocation.getMethodName() + ", elapsed: " + elapsed - + ", timeout: " + timeout + ". concurrent invokes: " + active - + ". max concurrent invoke limit: " + max); + + invoker.getInterface().getName() + ", method: " + + invocation.getMethodName() + ", elapsed: " + elapsed + + ", timeout: " + timeout + ". concurrent invokes: " + active + + ". max concurrent invoke limit: " + max); } } } @@ -75,10 +70,10 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept throw t; } } finally { - if(max>0){ - synchronized (count) { + if (max > 0) { + synchronized (this) { count.notify(); - } + } } } } diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ConsumerContextFilter.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ConsumerContextFilter.java index 710786528da..1f62d5a65f1 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ConsumerContextFilter.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ConsumerContextFilter.java @@ -18,17 +18,11 @@ import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.rpc.Filter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; +import com.alibaba.dubbo.rpc.*; /** * ConsumerContextInvokerFilter - * + * * @author william.liangf */ @Activate(group = Constants.CONSUMER, order = -10000) @@ -39,10 +33,10 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept .setInvoker(invoker) .setInvocation(invocation) .setLocalAddress(NetUtils.getLocalHost(), 0) - .setRemoteAddress(invoker.getUrl().getHost(), - invoker.getUrl().getPort()); + .setRemoteAddress(invoker.getUrl().getHost(), + invoker.getUrl().getPort()); if (invocation instanceof RpcInvocation) { - ((RpcInvocation)invocation).setInvoker(invoker); + ((RpcInvocation) invocation).setInvoker(invoker); } try { return invoker.invoke(invocation); diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ContextFilter.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ContextFilter.java index 4097697ecfb..cdf7ad73430 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ContextFilter.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ContextFilter.java @@ -15,22 +15,16 @@ */ package com.alibaba.dubbo.rpc.filter; -import java.util.HashMap; -import java.util.Map; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.extension.Activate; -import com.alibaba.dubbo.rpc.Filter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; +import com.alibaba.dubbo.rpc.*; + +import java.util.HashMap; +import java.util.Map; /** * ContextInvokerFilter - * + * * @author william.liangf */ @Activate(group = Constants.PROVIDER, order = -10000) @@ -50,7 +44,6 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept RpcContext.getContext() .setInvoker(invoker) .setInvocation(invocation) -// .setAttachments(attachments) // modified by lishen .setLocalAddress(invoker.getUrl().getHost(), invoker.getUrl().getPort()); @@ -64,7 +57,7 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept } if (invocation instanceof RpcInvocation) { - ((RpcInvocation)invocation).setInvoker(invoker); + ((RpcInvocation) invocation).setInvoker(invoker); } try { return invoker.invoke(invocation); diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ExecuteLimitFilter.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ExecuteLimitFilter.java index 64c13c2309a..de176d57bba 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ExecuteLimitFilter.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/ExecuteLimitFilter.java @@ -47,8 +47,7 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept boolean isException = false; RpcStatus.beginCount(url, methodName); try { - Result result = invoker.invoke(invocation); - return result; + return invoker.invoke(invocation); } catch (Throwable t) { isException = true; if(t instanceof RuntimeException) { diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/HystrixFilter.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/HystrixFilter.java new file mode 100644 index 00000000000..5c8ff5da4cf --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/HystrixFilter.java @@ -0,0 +1,62 @@ +package com.alibaba.dubbo.rpc.filter; + +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.extension.Activate; +import com.alibaba.dubbo.rpc.*; +import com.netflix.hystrix.*; + +/** + * for test now + * + * @author Xs + */ +@Activate(group = Constants.CONSUMER, value = "threads") +public class HystrixFilter implements Filter { + + @Override + public Result invoke(Invoker invoker, Invocation invocation) throws RpcException { + return new DefaultCommand(invoker, invocation).execute(); + } + + private static class DefaultCommand extends HystrixCommand { + + private final Invoker invoker; + private final Invocation invocation; + + public DefaultCommand(Invoker invoker, Invocation invocation) { + super(Setter + .withGroupKey(HystrixCommandGroupKey.Factory.asKey(groupKey(invoker))) + .andCommandKey(HystrixCommandKey.Factory.asKey(commandKey(invoker, invocation))) + .andCommandPropertiesDefaults(HystrixCommandProperties.Setter() + .withCircuitBreakerRequestVolumeThreshold(20) + .withCircuitBreakerSleepWindowInMilliseconds(30000) + .withCircuitBreakerErrorThresholdPercentage(50) + .withExecutionTimeoutEnabled(false)) + .andThreadPoolPropertiesDefaults(HystrixThreadPoolProperties.Setter().withCoreSize(threads(invoker)))); + this.invoker = invoker; + this.invocation = invocation; + } + + private static String groupKey(Invoker invoker) { + return invoker.getInterface().getName() + getVersion(invoker); + } + + private static String getVersion(Invoker invoker) { + return invoker.getUrl().getParameter("version", ""); + } + + private static String commandKey(Invoker invoker, Invocation invocation) { + return String.format("%s_%d", invoker.getInterface().getName() + invocation.getMethodName(), + invocation.getArguments() == null ? 0 : invocation.getArguments().length); + } + + private static int threads(Invoker invoker) { + return invoker.getUrl().getParameter("threads", 20); + } + + @Override + protected Result run() throws Exception { + return invoker.invoke(invocation); + } + } +} diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/TimeoutFilter.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/TimeoutFilter.java index b63ff232e26..45578261fc1 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/TimeoutFilter.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/TimeoutFilter.java @@ -13,8 +13,8 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.rpc.filter; - +package com.alibaba.dubbo.rpc.filter; + import java.util.Arrays; import com.alibaba.dubbo.common.Constants; @@ -26,13 +26,13 @@ import com.alibaba.dubbo.rpc.Invoker; import com.alibaba.dubbo.rpc.Result; import com.alibaba.dubbo.rpc.RpcException; - -/** - * 如果执行timeout,则log记录下,不干涉服务的运行 - * - * @author chao.liuc + +/** + * 如果执行timeout,则log记录下,不干涉服务的运行 + * + * @author chao.liuc */ -@Activate(group = Constants.PROVIDER) +@Activate(group = Constants.PROVIDER) public class TimeoutFilter implements Filter { private static final Logger logger = LoggerFactory.getLogger(TimeoutFilter.class); @@ -52,5 +52,4 @@ public Result invoke(Invoker invoker, Invocation invocation) throws RpcExcept } return result; } - } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/TokenFilter.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/TokenFilter.java index 5ff698eb666..27bad1d0b00 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/TokenFilter.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/filter/TokenFilter.java @@ -15,38 +15,32 @@ */ package com.alibaba.dubbo.rpc.filter; -import java.util.Map; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.utils.ConfigUtils; -import com.alibaba.dubbo.rpc.Filter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.*; + +import java.util.Map; /** * TokenInvokerFilter - * + * * @author william.liangf */ @Activate(group = Constants.PROVIDER, value = Constants.TOKEN_KEY) public class TokenFilter implements Filter { - public Result invoke(Invoker invoker, Invocation inv) - throws RpcException { - String token = invoker.getUrl().getParameter(Constants.TOKEN_KEY); - if (ConfigUtils.isNotEmpty(token)) { - Class serviceType = invoker.getInterface(); - Map attachments = inv.getAttachments(); - String remoteToken = attachments == null ? null : attachments.get(Constants.TOKEN_KEY); - if (! token.equals(remoteToken)) { - throw new RpcException("Invalid token! Forbid invoke remote service " + serviceType + " method " + inv.getMethodName() + "() from consumer " + RpcContext.getContext().getRemoteHost() + " to provider " + RpcContext.getContext().getLocalHost()); - } - } - return invoker.invoke(inv); - } - + public Result invoke(Invoker invoker, Invocation inv) + throws RpcException { + String token = invoker.getUrl().getParameter(Constants.TOKEN_KEY); + if (ConfigUtils.isNotEmpty(token)) { + Class serviceType = invoker.getInterface(); + Map attachments = inv.getAttachments(); + String remoteToken = attachments == null ? null : attachments.get(Constants.TOKEN_KEY); + if (!token.equals(remoteToken)) { + throw new RpcException("Invalid token! Forbid invoke remote service " + serviceType + " method " + inv.getMethodName() + "() from consumer " + RpcContext.getContext().getRemoteHost() + " to provider " + RpcContext.getContext().getLocalHost()); + } + } + return invoker.invoke(inv); + } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/listener/ListenerInvokerWrapper.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/listener/ListenerInvokerWrapper.java index 767c7338a9c..d1650a6d815 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/listener/ListenerInvokerWrapper.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/listener/ListenerInvokerWrapper.java @@ -15,20 +15,16 @@ */ package com.alibaba.dubbo.rpc.listener; -import java.util.List; - import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.InvokerListener; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Result; +import com.alibaba.dubbo.rpc.*; + +import java.util.List; /** * ListenerInvoker - * + * * @author william.liangf */ public class ListenerInvokerWrapper implements Invoker { @@ -36,10 +32,10 @@ public class ListenerInvokerWrapper implements Invoker { private static final Logger logger = LoggerFactory.getLogger(ListenerInvokerWrapper.class); private final Invoker invoker; - + private final List listeners; - public ListenerInvokerWrapper(Invoker invoker, List listeners){ + public ListenerInvokerWrapper(Invoker invoker, List listeners) { if (invoker == null) { throw new IllegalArgumentException("invoker == null"); } @@ -73,10 +69,10 @@ public boolean isAvailable() { public Result invoke(Invocation invocation) throws RpcException { return invoker.invoke(invocation); } - + @Override public String toString() { - return getInterface() + " -> " + getUrl()==null?" ":getUrl().toString(); + return getUrl().toString(); } public void destroy() { diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractExporter.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractExporter.java index d529354a9ca..cbcfd4fb8af 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractExporter.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractExporter.java @@ -22,13 +22,13 @@ /** * AbstractExporter. - * + * * @author qianlei * @author william.liangf */ public abstract class AbstractExporter implements Exporter { - protected final Logger logger = LoggerFactory.getLogger(getClass()); + protected final Logger logger = LoggerFactory.getLogger(getClass()); private final Invoker invoker; @@ -50,7 +50,7 @@ public Invoker getInvoker() { public void unexport() { if (unexported) { - return ; + return; } unexported = true; getInvoker().destroy(); diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractInvoker.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractInvoker.java index b5f2b6ff1ad..fd864534934 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractInvoker.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractInvoker.java @@ -1,64 +1,58 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.protocol; -import java.lang.reflect.InvocationTargetException; -import java.util.Collections; -import java.util.HashMap; -import java.util.Map; - -import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.RpcResult; -import com.alibaba.dubbo.rpc.support.RpcUtils; +import com.alibaba.dubbo.rpc.*; +import com.alibaba.dubbo.rpc.support.RpcUtils; + +import java.lang.reflect.InvocationTargetException; +import java.util.Collections; +import java.util.HashMap; +import java.util.Map; /** * AbstractInvoker. - * + * * @author qian.lei * @author william.liangf */ public abstract class AbstractInvoker implements Invoker { - protected final Logger logger = LoggerFactory.getLogger(getClass()); + protected final Logger logger = LoggerFactory.getLogger(getClass()); - private final Class type; + private final Class type; - private final URL url; + private final URL url; private final Map attachment; private volatile boolean available = true; private volatile boolean destroyed = false; - - public AbstractInvoker(Class type, URL url){ + + public AbstractInvoker(Class type, URL url) { this(type, url, (Map) null); } - + public AbstractInvoker(Class type, URL url, String[] keys) { this(type, url, convertAttachment(url, keys)); } @@ -72,7 +66,7 @@ public AbstractInvoker(Class type, URL url, Map attachment) { this.url = url; this.attachment = attachment == null ? null : Collections.unmodifiableMap(attachment); } - + private static Map convertAttachment(URL url, String[] keys) { if (keys == null || keys.length == 0) { return null; @@ -98,48 +92,47 @@ public URL getUrl() { public boolean isAvailable() { return available; } - + protected void setAvailable(boolean available) { this.available = available; } public void destroy() { - if (isDestroyed()) { - return; + if (isDestroyed()) { + return; } destroyed = true; setAvailable(false); - } - - public boolean isDestroyed() { - return destroyed; - } - + } + + public boolean isDestroyed() { + return destroyed; + } + public String toString() { return getInterface() + " -> " + (getUrl() == null ? "" : getUrl().toString()); } public Result invoke(Invocation inv) throws RpcException { - if(destroyed) { - throw new RpcException("Rpc invoker for service " + this + " on consumer " + NetUtils.getLocalHost() - + " use dubbo version " + Version.getVersion() - + " is DESTROYED, can not be invoked any more!"); + if (destroyed) { + throw new RpcException("Rpc invoker for service " + this + " on consumer " + NetUtils.getLocalHost() + + " use dubbo version " + Version.getVersion() + + " is DESTROYED, can not be invoked any more!"); } - RpcInvocation invocation = (RpcInvocation) inv; + RpcInvocation invocation = (RpcInvocation) inv; invocation.setInvoker(this); if (attachment != null && attachment.size() > 0) { - invocation.addAttachmentsIfAbsent(attachment); + invocation.addAttachmentsIfAbsent(attachment); } Map context = RpcContext.getContext().getAttachments(); if (context != null) { - invocation.addAttachmentsIfAbsent(context); - } - if (getUrl().getMethodParameter(invocation.getMethodName(), Constants.ASYNC_KEY, false)){ - invocation.setAttachment(Constants.ASYNC_KEY, Boolean.TRUE.toString()); - } - RpcUtils.attachInvocationIdIfAsync(getUrl(), invocation); - - + invocation.addAttachmentsIfAbsent(context); + } + if (getUrl().getMethodParameter(invocation.getMethodName(), Constants.ASYNC_KEY, false)) { + invocation.setAttachment(Constants.ASYNC_KEY, Boolean.TRUE.toString()); + } + RpcUtils.attachInvocationIdIfAsync(getUrl(), invocation); + try { return doInvoke(invocation); } catch (InvocationTargetException e) { // biz exception diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractProtocol.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractProtocol.java index 29050a7f1d6..031400fc95c 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractProtocol.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractProtocol.java @@ -89,14 +89,14 @@ protected static int getServerShutdownTimeout() { if (value != null && value.length() > 0) { try{ timeout = Integer.parseInt(value); - }catch (Exception e) { + }catch (Exception ignored) { } } else { value = ConfigUtils.getProperty(Constants.SHUTDOWN_WAIT_SECONDS_KEY); if (value != null && value.length() > 0) { try{ timeout = Integer.parseInt(value) * 1000; - }catch (Exception e) { + }catch (Exception ignored) { } } } diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractProxyProtocol.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractProxyProtocol.java index 72dac1d04c7..95e14d8ce5a 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractProxyProtocol.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/AbstractProxyProtocol.java @@ -85,12 +85,12 @@ public void unexport() { } public Invoker refer(final Class type, final URL url) throws RpcException { - final Invoker tagert = proxyFactory.getInvoker(doRefer(type, url), type, url); + final Invoker target = proxyFactory.getInvoker(doRefer(type, url), type, url); Invoker invoker = new AbstractInvoker(type, url) { @Override protected Result doInvoke(Invocation invocation) throws Throwable { try { - Result result = tagert.invoke(invocation); + Result result = target.invoke(invocation); Throwable e = result.getException(); if (e != null) { for (Class rpcException : rpcExceptions) { diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/ProtocolFilterWrapper.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/ProtocolFilterWrapper.java index ad760f5c380..df335bb3b8e 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/ProtocolFilterWrapper.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/protocol/ProtocolFilterWrapper.java @@ -104,5 +104,4 @@ public String toString() { } return last; } - } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/AbstractProxyInvoker.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/AbstractProxyInvoker.java index d0f25307b4c..fed3831d0de 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/AbstractProxyInvoker.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/AbstractProxyInvoker.java @@ -1,50 +1,46 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.proxy; -import java.lang.reflect.InvocationTargetException; - import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcResult; +import com.alibaba.dubbo.rpc.*; + +import java.lang.reflect.InvocationTargetException; /** * InvokerWrapper - * + * * @author william.liangf */ public abstract class AbstractProxyInvoker implements Invoker { - + private final T proxy; - + private final Class type; - + private final URL url; - public AbstractProxyInvoker(T proxy, Class type, URL url){ + public AbstractProxyInvoker(T proxy, Class type, URL url) { if (proxy == null) { throw new IllegalArgumentException("proxy == null"); } if (type == null) { throw new IllegalArgumentException("interface == null"); } - if (! type.isInstance(proxy)) { + if (!type.isInstance(proxy)) { throw new IllegalArgumentException(proxy.getClass().getName() + " not implement interface " + type); } this.proxy = proxy; @@ -76,13 +72,12 @@ public Result invoke(Invocation invocation) throws RpcException { throw new RpcException("Failed to invoke remote proxy method " + invocation.getMethodName() + " to " + getUrl() + ", cause: " + e.getMessage(), e); } } - + protected abstract Object doInvoke(T proxy, String methodName, Class[] parameterTypes, Object[] arguments) throws Throwable; @Override public String toString() { - return getInterface() + " -> " + getUrl()==null?" ":getUrl().toString(); + return getUrl().toString(); } - } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/AsyncableInvocationHandler.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/AsyncableInvocationHandler.java new file mode 100644 index 00000000000..76e3af8d56d --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/AsyncableInvocationHandler.java @@ -0,0 +1,70 @@ +package com.alibaba.dubbo.rpc.proxy; + +import com.alibaba.dubbo.common.utils.MethodCache; +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.async.AsyncCommand; + +import java.lang.reflect.Method; +import java.util.concurrent.Future; + +public class AsyncableInvocationHandler extends InvokerInvocationHandler { + + private static final MethodCache methodCache = MethodCache.newCache(); + + public AsyncableInvocationHandler(Invoker handler) { + super(handler); + } + + public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { + if (!isAsyncMethod(method)) { + return invokeSuper(proxy, method, args); + } else { + AsyncCommand command = new AsyncMethodCommand(proxy, method, args); + return command.queue(); + } + } + + private boolean isAsyncMethod(Method method) { + return Future.class.isAssignableFrom(method.getReturnType()) && + method.getName().startsWith("async_"); + } + + /** + * async method wrapper + */ + class AsyncMethodCommand extends AsyncCommand { + + private final Object proxy; + + private final Method asyncMethod; + + private final Object[] args; + + public AsyncMethodCommand(Object proxy, Method asyncMethod, Object[] args) { + this.proxy = proxy; + this.asyncMethod = asyncMethod; + this.args = args; + } + + private Method getCorrespondingSyncMethod() throws Exception { + String methodName = asyncMethod.getName(); + Class[] parameterTypes = asyncMethod.getParameterTypes(); + String syncMethodName = methodName.substring(methodName.indexOf("async_") + "async_".length()); + return methodCache.get(proxy.getClass(), syncMethodName, parameterTypes); + } + + @Override + public Object run() throws Exception { + return AsyncableInvocationHandler.this.invokeSuper(proxy, getCorrespondingSyncMethod(), args); + } + } + + private Object invokeSuper(Object proxy, Method method, Object[] args) { + try { + return super.invoke(proxy, method, args); + } catch (Throwable e) { + throw new RpcException(e.getMessage(), e); + } + } +} diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/InvokerInvocationHandler.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/InvokerInvocationHandler.java index 9e21becc3be..e6a19e577e4 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/InvokerInvocationHandler.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/InvokerInvocationHandler.java @@ -1,40 +1,40 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.proxy; -import java.lang.reflect.InvocationHandler; -import java.lang.reflect.Method; - import com.alibaba.dubbo.rpc.Invoker; import com.alibaba.dubbo.rpc.RpcInvocation; +import java.lang.reflect.InvocationHandler; +import java.lang.reflect.Method; + /** * InvokerHandler - * + * * @author william.liangf */ public class InvokerInvocationHandler implements InvocationHandler { - private final Invoker invoker; - - public InvokerInvocationHandler(Invoker handler){ + protected final Invoker invoker; + + public InvokerInvocationHandler(Invoker handler) { this.invoker = handler; } - public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { + public Object invoke(final Object proxy, final Method method, final Object[] args) throws Throwable { String methodName = method.getName(); Class[] parameterTypes = method.getParameterTypes(); if (method.getDeclaringClass() == Object.class) { @@ -51,5 +51,4 @@ public Object invoke(Object proxy, Method method, Object[] args) throws Throwabl } return invoker.invoke(new RpcInvocation(method, args)).recreate(); } - } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/javassist/JavassistProxyFactory.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/javassist/JavassistProxyFactory.java index 7e776af539e..e06dd61d5f2 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/javassist/JavassistProxyFactory.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/javassist/JavassistProxyFactory.java @@ -1,38 +1,38 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.proxy.javassist; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.bytecode.Proxy; -import com.alibaba.dubbo.common.bytecode.Wrapper; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.proxy.AbstractProxyFactory; -import com.alibaba.dubbo.rpc.proxy.AbstractProxyInvoker; -import com.alibaba.dubbo.rpc.proxy.InvokerInvocationHandler; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.bytecode.Proxy; +import com.alibaba.dubbo.common.bytecode.Wrapper; +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.proxy.AbstractProxyFactory; +import com.alibaba.dubbo.rpc.proxy.AbstractProxyInvoker; +import com.alibaba.dubbo.rpc.proxy.AsyncableInvocationHandler; /** - * JavaassistRpcProxyFactory - + * JavassistRpcProxyFactory + * * @author william.liangf */ public class JavassistProxyFactory extends AbstractProxyFactory { @SuppressWarnings("unchecked") public T getProxy(Invoker invoker, Class[] interfaces) { - return (T) Proxy.getProxy(interfaces).newInstance(new InvokerInvocationHandler(invoker)); + return (T) Proxy.getProxy(interfaces).newInstance(new AsyncableInvocationHandler(invoker)); } public Invoker getInvoker(T proxy, Class type, URL url) { @@ -40,12 +40,11 @@ public Invoker getInvoker(T proxy, Class type, URL url) { final Wrapper wrapper = Wrapper.getWrapper(proxy.getClass().getName().indexOf('$') < 0 ? proxy.getClass() : type); return new AbstractProxyInvoker(proxy, type, url) { @Override - protected Object doInvoke(T proxy, String methodName, - Class[] parameterTypes, + protected Object doInvoke(T proxy, String methodName, + Class[] parameterTypes, Object[] arguments) throws Throwable { return wrapper.invokeMethod(proxy, methodName, parameterTypes, arguments); } }; } - } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/jdk/JdkProxyFactory.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/jdk/JdkProxyFactory.java index afa805421b9..f9eb90f67ec 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/jdk/JdkProxyFactory.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/jdk/JdkProxyFactory.java @@ -1,51 +1,60 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.proxy.jdk; -import java.lang.reflect.Method; -import java.lang.reflect.Proxy; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.proxy.AbstractProxyFactory; -import com.alibaba.dubbo.rpc.proxy.AbstractProxyInvoker; -import com.alibaba.dubbo.rpc.proxy.InvokerInvocationHandler; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.utils.MethodCache; +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.proxy.AbstractProxyFactory; +import com.alibaba.dubbo.rpc.proxy.AbstractProxyInvoker; +import com.alibaba.dubbo.rpc.proxy.AsyncableInvocationHandler; -/** - * JavaassistRpcProxyFactory +import java.lang.reflect.Method; +import java.lang.reflect.Proxy; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; +/** + * JdkProxyFactory + * * @author william.liangf */ public class JdkProxyFactory extends AbstractProxyFactory { @SuppressWarnings("unchecked") public T getProxy(Invoker invoker, Class[] interfaces) { - return (T) Proxy.newProxyInstance(Thread.currentThread().getContextClassLoader(), interfaces, new InvokerInvocationHandler(invoker)); + return (T) Proxy.newProxyInstance(Thread.currentThread().getContextClassLoader(), + interfaces, new AsyncableInvocationHandler(invoker)); } public Invoker getInvoker(T proxy, Class type, URL url) { - return new AbstractProxyInvoker(proxy, type, url) { - @Override - protected Object doInvoke(T proxy, String methodName, - Class[] parameterTypes, - Object[] arguments) throws Throwable { - Method method = proxy.getClass().getMethod(methodName, parameterTypes); - return method.invoke(proxy, arguments); - } - }; + return new CachedProxyInvoker(proxy, type, url); } + static class CachedProxyInvoker extends AbstractProxyInvoker { + + private final static MethodCache methodCache = MethodCache.newCache(); + + public CachedProxyInvoker(T proxy, Class type, URL url) { + super(proxy, type, url); + } + + @Override + protected Object doInvoke(T proxy, String methodName, Class[] parameterTypes, Object[] arguments) throws Throwable { + return methodCache.get(proxy.getClass(), methodName, parameterTypes); + } + } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/wrapper/StubProxyFactoryWrapper.java b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/wrapper/StubProxyFactoryWrapper.java index 23b43789d2e..4bd004f6f9d 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/wrapper/StubProxyFactoryWrapper.java +++ b/dubbo-rpc/dubbo-rpc-api/src/main/java/com/alibaba/dubbo/rpc/proxy/wrapper/StubProxyFactoryWrapper.java @@ -76,7 +76,7 @@ public T getProxy(Invoker invoker) throws RpcException { } try { Constructor constructor = ReflectUtils.findConstructor(stubClass, serviceType); - proxy = (T) constructor.newInstance(new Object[] {proxy}); + proxy = (T) constructor.newInstance(proxy); //export stub service URL url = invoker.getUrl(); if (url.getParameter(Constants.STUB_EVENT_KEY, Constants.DEFAULT_STUB_EVENT)){ diff --git a/dubbo-rpc/dubbo-rpc-api/src/test/java/com/alibaba/dubbo/rpc/filter/ConsumerContextFilterTest.java b/dubbo-rpc/dubbo-rpc-api/src/test/java/com/alibaba/dubbo/rpc/filter/ConsumerContextFilterTest.java index 136a6732797..7709f737bcf 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/test/java/com/alibaba/dubbo/rpc/filter/ConsumerContextFilterTest.java +++ b/dubbo-rpc/dubbo-rpc-api/src/test/java/com/alibaba/dubbo/rpc/filter/ConsumerContextFilterTest.java @@ -41,8 +41,6 @@ public void testSetContext(){ Invoker invoker = new MyInvoker(url); Invocation invocation = new MockInvocation(); consumerContextFilter.invoke(invoker, invocation); - assertEquals(invoker,RpcContext.getContext().getInvoker()); - assertEquals(invocation,RpcContext.getContext().getInvocation()); assertEquals(NetUtils.getLocalHost() + ":0",RpcContext.getContext().getLocalAddressString()); assertEquals("test:11",RpcContext.getContext().getRemoteAddressString()); diff --git a/dubbo-rpc/dubbo-rpc-api/src/test/java/com/alibaba/dubbo/rpc/filter/ContextFilterTest.java b/dubbo-rpc/dubbo-rpc-api/src/test/java/com/alibaba/dubbo/rpc/filter/ContextFilterTest.java index 3a8017560b6..77dbdbe4595 100644 --- a/dubbo-rpc/dubbo-rpc-api/src/test/java/com/alibaba/dubbo/rpc/filter/ContextFilterTest.java +++ b/dubbo-rpc/dubbo-rpc-api/src/test/java/com/alibaba/dubbo/rpc/filter/ContextFilterTest.java @@ -61,7 +61,6 @@ public void testSetContext() { EasyMock.expect(invoker.getUrl()).andReturn(url).anyTimes(); EasyMock.replay(invoker); contextFilter.invoke(invoker, invocation); - assertNull(RpcContext.getContext().getInvoker()); } @Test @@ -70,6 +69,5 @@ public void testWithAttachments() { Invoker invoker = new MyInvoker(url); Invocation invocation = new MockInvocation(); Result result = contextFilter.invoke(invoker, invocation); - assertNull(RpcContext.getContext().getInvoker()); } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/pom.xml b/dubbo-rpc/dubbo-rpc-default/pom.xml index a31250d37db..da766dc76fd 100644 --- a/dubbo-rpc/dubbo-rpc-default/pom.xml +++ b/dubbo-rpc/dubbo-rpc-default/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-rpc - 2.8.4 + 3.0.1 dubbo-rpc-default jar diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/CallbackServiceCodec.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/CallbackServiceCodec.java index cb5c5a51566..416f786e299 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/CallbackServiceCodec.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/CallbackServiceCodec.java @@ -1,40 +1,40 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.io.IOException; -import java.util.HashMap; -import java.util.Map; -import java.util.Set; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.bytecode.Wrapper; -import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.utils.ConcurrentHashSet; -import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.rpc.Exporter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.ProxyFactory; -import com.alibaba.dubbo.rpc.RpcInvocation; +import java.io.IOException; +import java.util.HashMap; +import java.util.Map; +import java.util.Set; + +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.bytecode.Wrapper; +import com.alibaba.dubbo.common.extension.ExtensionLoader; +import com.alibaba.dubbo.common.logger.Logger; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.common.utils.ConcurrentHashSet; +import com.alibaba.dubbo.common.utils.StringUtils; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.rpc.Exporter; +import com.alibaba.dubbo.rpc.Invocation; +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.ProxyFactory; +import com.alibaba.dubbo.rpc.RpcInvocation; /** * callback 服务帮助类. @@ -49,7 +49,7 @@ class CallbackServiceCodec { private static final byte CALLBACK_NONE = 0x0; private static final byte CALLBACK_CREATE = 0x1; private static final byte CALLBACK_DESTROY = 0x2; - private static final String INV_ATT_CALLBACK_KEY = "sys_callback_arg-"; + private static final String INV_ATT_CALLBACK_KEY = "sys_callback_arg-"; private static byte isCallBack(URL url, String methodName ,int argIndex){ //参数callback的规则是 方法名称.参数index(0开始).callback @@ -68,11 +68,11 @@ private static byte isCallBack(URL url, String methodName ,int argIndex){ } /** - * client 端export callback service - * @param channel - * @param clazz - * @param inst - * @param export + * client 端export callback service + * @param channel + * @param clazz + * @param inst + * @param export * @param out * @throws IOException */ @@ -94,7 +94,7 @@ private static String exportOrunexportCallbackService(Channel channel, URL url, Map tmpmap = new HashMap(url.getParameters()); tmpmap.putAll(params); - tmpmap.remove(Constants.VERSION_KEY);//callback不需要区分version + tmpmap.remove(Constants.VERSION_KEY);//callback不需要区分version tmpmap.put(Constants.INTERFACE_KEY, clazz.getName()); URL exporturl = new URL(DubboProtocol.NAME, channel.getLocalAddress().getAddress().getHostAddress(), channel.getLocalAddress().getPort(), clazz.getName()+"."+instid, tmpmap); @@ -126,7 +126,7 @@ private static String exportOrunexportCallbackService(Channel channel, URL url, } /** - * server端 应用一个callbackservice + * server端 应用一个callbackservice * @param url */ @SuppressWarnings("unchecked") @@ -138,10 +138,10 @@ private static Object referOrdestroyCallbackService(Channel channel, URL url, Cl String countkey = getServerSideCountKey(channel, clazz.getName()); if (isRefer){ if( proxy == null ){ - URL referurl = URL.valueOf("callback://" + url.getAddress() + "/" + clazz.getName() + "?" + Constants.INTERFACE_KEY + "=" + clazz.getName()); - referurl = referurl.addParametersIfAbsent(url.getParameters()).removeParameter(Constants.METHODS_KEY); - if (!isInstancesOverLimit(channel, referurl, clazz.getName(), instid, true)){ - @SuppressWarnings("rawtypes") + URL referurl = URL.valueOf("callback://" + url.getAddress() + "/" + clazz.getName() + "?" + Constants.INTERFACE_KEY + "=" + clazz.getName()); + referurl = referurl.addParametersIfAbsent(url.getParameters()).removeParameter(Constants.METHODS_KEY); + if (!isInstancesOverLimit(channel, referurl, clazz.getName(), instid, true)){ + @SuppressWarnings("rawtypes") Invoker invoker = new ChannelWrappedInvoker(clazz, channel, referurl, String.valueOf(instid)); proxy = proxyFactory.getProxy(invoker); channel.setAttribute(proxyCacheKey, proxy); @@ -235,8 +235,8 @@ private static void decreaseInstanceCount(Channel channel, String countkey){ } } - public static Object encodeInvocationArgument(Channel channel, RpcInvocation inv, int paraIndex) throws IOException{ - //encode时可直接获取url + public static Object encodeInvocationArgument(Channel channel, RpcInvocation inv, int paraIndex) throws IOException{ + //encode时可直接获取url URL url = inv.getInvoker() == null ? null : inv.getInvoker().getUrl(); byte callbackstatus = isCallBack(url, inv.getMethodName(), paraIndex); Object[] args = inv.getArguments(); @@ -255,16 +255,16 @@ public static Object encodeInvocationArgument(Channel channel, RpcInvocation inv } } public static Object decodeInvocationArgument(Channel channel, RpcInvocation inv, Class[] pts, int paraIndex, Object inObject) throws IOException{ - //如果是callback,则创建proxy到客户端,方法的执行可通过channel调用到client端的callback接口 - //decode时需要根据channel及env获取url - URL url = null ; - try { - url = DubboProtocol.getDubboProtocol().getInvoker(channel, inv).getUrl(); - } catch (RemotingException e) { - if (logger.isInfoEnabled()) { - logger.info(e.getMessage(), e); - } - return inObject; + //如果是callback,则创建proxy到客户端,方法的执行可通过channel调用到client端的callback接口 + //decode时需要根据channel及env获取url + URL url = null ; + try { + url = DubboProtocol.getDubboProtocol().getInvoker(channel, inv).getUrl(); + } catch (RemotingException e) { + if (logger.isInfoEnabled()) { + logger.info(e.getMessage(), e); + } + return inObject; } byte callbackstatus = isCallBack(url, inv.getMethodName(), paraIndex); switch (callbackstatus) { @@ -286,5 +286,5 @@ public static Object decodeInvocationArgument(Channel channel, RpcInvocation inv default: return inObject ; } - } + } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/ChannelWrappedInvoker.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/ChannelWrappedInvoker.java index 33d234aaae3..7031d46a965 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/ChannelWrappedInvoker.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/ChannelWrappedInvoker.java @@ -1,52 +1,50 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.net.InetSocketAddress; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.TimeoutException; +import com.alibaba.dubbo.common.Version; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.exception.TimeoutException; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; import com.alibaba.dubbo.remoting.exchange.support.header.HeaderExchangeClient; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; import com.alibaba.dubbo.remoting.transport.ClientDelegate; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.RpcResult; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.protocol.AbstractInvoker; +import java.net.InetSocketAddress; + /** - * 基于已有channel的invoker. - * + * 基于已有channel的invoker. + * * @author chao.liuc */ class ChannelWrappedInvoker extends AbstractInvoker { private final Channel channel; - private final String serviceKey ; + private final String serviceKey; public ChannelWrappedInvoker(Class serviceType, Channel channel, URL url, String serviceKey) { - - super(serviceType, url, new String[] { Constants.GROUP_KEY, - Constants.TOKEN_KEY, Constants.TIMEOUT_KEY }); + super(serviceType, url, new String[]{Constants.GROUP_KEY, + Constants.TOKEN_KEY, Constants.TIMEOUT_KEY}); this.channel = channel; this.serviceKey = serviceKey; } @@ -57,21 +55,22 @@ protected Result doInvoke(Invocation invocation) throws Throwable { //拿不到client端export 的service path.约定为interface的名称. inv.setAttachment(Constants.PATH_KEY, getInterface().getName()); inv.setAttachment(Constants.CALLBACK_SERVICE_KEY, serviceKey); - ExchangeClient currentClient = new HeaderExchangeClient(new ChannelWrapper(this.channel)); - try { if (getUrl().getMethodParameter(invocation.getMethodName(), Constants.ASYNC_KEY, false)) { // 不可靠异步 - currentClient.send(inv,getUrl().getMethodParameter(invocation.getMethodName(), Constants.SENT_KEY, false)); + currentClient.send(inv, getUrl().getMethodParameter(invocation.getMethodName(), Constants.SENT_KEY, false)); return new RpcResult(); } int timeout = getUrl().getMethodParameter(invocation.getMethodName(), Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); + Request request = new Request.Builder().newId().version(Version.getVersion()).data(inv).build(); + Response response; if (timeout > 0) { - return (Result) currentClient.request(inv, timeout).get(); + response = currentClient.request(request, timeout); } else { - return (Result) currentClient.request(inv).get(); + response = currentClient.request(request); } + return (Result) response.getResult(); } catch (RpcException e) { throw e; } catch (TimeoutException e) { @@ -86,7 +85,7 @@ protected Result doInvoke(Invocation invocation) throws Throwable { public static class ChannelWrapper extends ClientDelegate { private final Channel channel; - private final URL url; + private final URL url; public ChannelWrapper(Channel channel) { this.channel = channel; @@ -110,7 +109,7 @@ public void close() { } public boolean isClosed() { - return channel == null ? true : channel.isClosed(); + return channel.isClosed(); } public void reset(URL url) { @@ -122,7 +121,7 @@ public InetSocketAddress getRemoteAddress() { } public boolean isConnected() { - return channel == null ? false : channel.isConnected(); + return channel.isConnected(); } public boolean hasAttribute(String key) { @@ -152,17 +151,5 @@ public void send(Object message) throws RemotingException { public void send(Object message, boolean sent) throws RemotingException { channel.send(message, sent); } - } - - public void destroy() { - //channel资源的清空由channel创建者清除. -// super.destroy(); -// try { -// channel.close(); -// } catch (Throwable t) { -// logger.warn(t.getMessage(), t); -// } - } - } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DecodeableRpcInvocation.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DecodeableRpcInvocation.java index 8c1e46759c4..d6ccb8ad857 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DecodeableRpcInvocation.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DecodeableRpcInvocation.java @@ -16,29 +16,27 @@ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.io.IOException; -import java.io.InputStream; -import java.io.OutputStream; -import java.util.HashMap; -import java.util.Map; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.serialize.Cleanable; import com.alibaba.dubbo.common.serialize.ObjectInput; -import com.alibaba.dubbo.common.serialize.OptimizedSerialization; -import com.alibaba.dubbo.common.serialize.support.kryo.KryoSerialization; import com.alibaba.dubbo.common.utils.Assert; import com.alibaba.dubbo.common.utils.ReflectUtils; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec; import com.alibaba.dubbo.remoting.Decodeable; -import com.alibaba.dubbo.remoting.exchange.Request; +import com.alibaba.dubbo.remoting.message.Request; import com.alibaba.dubbo.remoting.transport.CodecSupport; import com.alibaba.dubbo.rpc.RpcInvocation; +import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStream; +import java.util.HashMap; +import java.util.Map; + import static com.alibaba.dubbo.rpc.protocol.dubbo.CallbackServiceCodec.decodeInvocationArgument; /** @@ -48,13 +46,13 @@ public class DecodeableRpcInvocation extends RpcInvocation implements Codec, Dec private static final Logger log = LoggerFactory.getLogger(DecodeableRpcInvocation.class); - private Channel channel; + private Channel channel; - private byte serializationType; + private byte serializationType; private InputStream inputStream; - private Request request; + private Request request; private volatile boolean hasDecoded; @@ -76,8 +74,7 @@ public void decode() throws Exception { if (log.isWarnEnabled()) { log.warn("Decode rpc invocation failed: " + e.getMessage(), e); } - request.setBroken(true); - request.setData(e); + request = request.newBuilder().broken(true).data(e).build(); } finally { hasDecoded = true; } @@ -101,7 +98,6 @@ public Object decode(Channel channel, InputStream input) throws IOException { try { Object[] args; Class[] pts; - // NOTICE modified by lishen int argNum = in.readInt(); if (argNum >= 0) { @@ -142,7 +138,6 @@ public Object decode(Channel channel, InputStream input) throws IOException { } } setParameterTypes(pts); - Map map = (Map) in.readObject(Map.class); if (map != null && map.size() > 0) { Map attachment = getAttachments(); @@ -171,4 +166,8 @@ public Object decode(Channel channel, InputStream input) throws IOException { return this; } + public Channel getChannel(){ + return channel; + } + } diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DecodeableRpcResult.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DecodeableRpcResult.java index 6c1d0b46be3..64bdc370b55 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DecodeableRpcResult.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DecodeableRpcResult.java @@ -16,25 +16,22 @@ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.io.IOException; -import java.io.InputStream; -import java.io.OutputStream; -import java.lang.reflect.Type; - import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.serialize.Cleanable; import com.alibaba.dubbo.common.serialize.ObjectInput; import com.alibaba.dubbo.common.utils.Assert; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec; import com.alibaba.dubbo.remoting.Decodeable; -import com.alibaba.dubbo.remoting.exchange.Response; +import com.alibaba.dubbo.remoting.message.Response; import com.alibaba.dubbo.remoting.transport.CodecSupport; -import com.alibaba.dubbo.rpc.Invocation; import com.alibaba.dubbo.rpc.RpcResult; -import com.alibaba.dubbo.rpc.support.RpcUtils; + +import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStream; /** * @author kimi @@ -43,26 +40,23 @@ public class DecodeableRpcResult extends RpcResult implements Codec, Decodeable private static final Logger log = LoggerFactory.getLogger(DecodeableRpcResult.class); - private Channel channel; + private Channel channel; - private byte serializationType; + private byte serializationType; private InputStream inputStream; - private Response response; - - private Invocation invocation; + private Response response; private volatile boolean hasDecoded; - public DecodeableRpcResult(Channel channel, Response response, InputStream is, Invocation invocation, byte id) { + public DecodeableRpcResult(Channel channel, Response response, InputStream is, byte id) { Assert.notNull(channel, "channel == null"); Assert.notNull(response, "response == null"); Assert.notNull(is, "inputStream == null"); this.channel = channel; this.response = response; this.inputStream = is; - this.invocation = invocation; this.serializationType = id; } @@ -72,7 +66,7 @@ public void encode(Channel channel, OutputStream output, Object message) throws public Object decode(Channel channel, InputStream input) throws IOException { ObjectInput in = CodecSupport.getSerialization(channel.getUrl(), serializationType) - .deserialize(channel.getUrl(), input); + .deserialize(channel.getUrl(), input); try { byte flag = in.readByte(); @@ -81,10 +75,7 @@ public Object decode(Channel channel, InputStream input) throws IOException { break; case DubboCodec.RESPONSE_VALUE: try { - Type[] returnType = RpcUtils.getReturnTypes(invocation); - setValue(returnType == null || returnType.length == 0 ? in.readObject() : - (returnType.length == 1 ? in.readObject((Class) returnType[0]) - : in.readObject((Class) returnType[0], returnType[1]))); + setValue(in.readObject()); } catch (ClassNotFoundException e) { throw new IOException(StringUtils.toString("Read response data failed.", e)); } @@ -92,7 +83,7 @@ public Object decode(Channel channel, InputStream input) throws IOException { case DubboCodec.RESPONSE_WITH_EXCEPTION: try { Object obj = in.readObject(); - if (obj instanceof Throwable == false) + if (!(obj instanceof Throwable)) throw new IOException("Response data error, expect Throwable, but get " + obj); setException((Throwable) obj); } catch (ClassNotFoundException e) { @@ -104,7 +95,6 @@ public Object decode(Channel channel, InputStream input) throws IOException { } return this; } finally { - // modified by lishen if (in instanceof Cleanable) { ((Cleanable) in).cleanup(); } @@ -119,8 +109,7 @@ public void decode() throws Exception { if (log.isWarnEnabled()) { log.warn("Decode rpc result failed: " + e.getMessage(), e); } - response.setStatus(Response.CLIENT_ERROR); - response.setErrorMessage(StringUtils.toString(e)); + response = response.newBuilder().status(Response.CLIENT_ERROR).errorMsg(StringUtils.toString(e)).build(); } finally { hasDecoded = true; } diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboCodec.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboCodec.java index 3e5fd8944f1..78a15fd0403 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboCodec.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboCodec.java @@ -15,9 +15,6 @@ */ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.io.IOException; -import java.io.InputStream; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; @@ -31,16 +28,18 @@ import com.alibaba.dubbo.common.serialize.Serialization; import com.alibaba.dubbo.common.utils.ReflectUtils; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec2; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; import com.alibaba.dubbo.remoting.exchange.codec.ExchangeCodec; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; import com.alibaba.dubbo.remoting.transport.CodecSupport; -import com.alibaba.dubbo.rpc.Invocation; import com.alibaba.dubbo.rpc.Result; import com.alibaba.dubbo.rpc.RpcInvocation; +import java.io.IOException; +import java.io.InputStream; + import static com.alibaba.dubbo.rpc.protocol.dubbo.CallbackServiceCodec.encodeInvocationArgument; /** @@ -74,66 +73,65 @@ protected Object decodeBody(Channel channel, InputStream is, byte[] header) thro long id = Bytes.bytes2long(header, 4); if ((flag & FLAG_REQUEST) == 0) { // decode response. - Response res = new Response(id); - if ((flag & FLAG_EVENT) != 0) { - res.setEvent(Response.HEARTBEAT_EVENT); + Response.Builder builder = new Response.Builder(id); + boolean isEvent = (flag & FLAG_EVENT) != 0; + builder.isEvent(isEvent); + if (isEvent) { + builder.result(Response.HEARTBEAT_EVENT); } // get status. byte status = header[3]; - res.setStatus(status); + builder.status(status); + Response res = builder.build(); if (status == Response.OK) { try { Object data; - if (res.isHeartbeat()) { - data = decodeHeartbeatData(channel, deserialize(s, channel.getUrl(), is)); - } else if (res.isEvent()) { + if (isEvent) { data = decodeEventData(channel, deserialize(s, channel.getUrl(), is)); } else { DecodeableRpcResult result; if (channel.getUrl().getParameter( Constants.DECODE_IN_IO_THREAD_KEY, Constants.DEFAULT_DECODE_IN_IO_THREAD)) { - result = new DecodeableRpcResult(channel, res, is, - (Invocation)getRequestData(id), proto); + result = new DecodeableRpcResult(channel, res, is, proto); result.decode(); } else { result = new DecodeableRpcResult(channel, res, - new UnsafeByteArrayInputStream(readMessageData(is)), - (Invocation) getRequestData(id), proto); + new UnsafeByteArrayInputStream(readMessageData(is)), proto); } data = result; } - res.setResult(data); + res = res.newBuilder().result(data).build(); } catch (Throwable t) { if (log.isWarnEnabled()) { log.warn("Decode response failed: " + t.getMessage(), t); } - res.setStatus(Response.CLIENT_ERROR); - res.setErrorMessage(StringUtils.toString(t)); + res = res.newBuilder().status(Response.CLIENT_ERROR).errorMsg(StringUtils.toString(t)).build(); } } else { - res.setErrorMessage(deserialize(s, channel.getUrl(), is).readUTF()); + res = res.newBuilder().errorMsg(deserialize(s, channel.getUrl(), is).readUTF()).build(); } return res; } else { // decode request. - Request req = new Request(id); - req.setVersion("2.0.0"); - req.setTwoWay((flag & FLAG_TWOWAY) != 0); - if ((flag & FLAG_EVENT) != 0) { - req.setEvent(Request.HEARTBEAT_EVENT); + Request.Builder builder = new Request.Builder(id); + builder.version(Version.getVersion()).twoWay((flag & FLAG_TWOWAY) != 0); + boolean isEvent = (flag & FLAG_EVENT) != 0; + builder.isEvent(isEvent); + if (isEvent) { + builder.data(Request.HEARTBEAT_EVENT); } + Request req = builder.build(); try { Object data; - if (req.isHeartbeat()) { - data = decodeHeartbeatData(channel, deserialize(s, channel.getUrl(), is)); - } else if (req.isEvent()) { + if (isEvent) { data = decodeEventData(channel, deserialize(s, channel.getUrl(), is)); } else { DecodeableRpcInvocation inv; if (channel.getUrl().getParameter( Constants.DECODE_IN_IO_THREAD_KEY, Constants.DEFAULT_DECODE_IN_IO_THREAD)) { + inv = new DecodeableRpcInvocation(channel, req, is, proto); inv.decode(); } else { @@ -142,14 +140,12 @@ protected Object decodeBody(Channel channel, InputStream is, byte[] header) thro } data = inv; } - req.setData(data); + req = req.newBuilder().data(data).build(); } catch (Throwable t) { if (log.isWarnEnabled()) { log.warn("Decode request failed: " + t.getMessage(), t); } - // bad request - req.setBroken(true); - req.setData(t); + req = req.newBuilder().broken(true).data(t).build(); } return req; } @@ -172,15 +168,10 @@ private byte[] readMessageData(InputStream is) throws IOException { @Override protected void encodeRequestData(Channel channel, ObjectOutput out, Object data) throws IOException { RpcInvocation inv = (RpcInvocation) data; - out.writeUTF(inv.getAttachment(Constants.DUBBO_VERSION_KEY, DUBBO_VERSION)); out.writeUTF(inv.getAttachment(Constants.PATH_KEY)); out.writeUTF(inv.getAttachment(Constants.VERSION_KEY)); - out.writeUTF(inv.getMethodName()); - - // NOTICE modified by lishen - // TODO if (getSerialization(channel) instanceof OptimizedSerialization && !containComplexArguments(inv)) { out.writeInt(inv.getParameterTypes().length); } else { @@ -190,7 +181,7 @@ protected void encodeRequestData(Channel channel, ObjectOutput out, Object data) Object[] args = inv.getArguments(); if (args != null) - for (int i = 0; i < args.length; i++){ + for (int i = 0; i < args.length; i++) { out.writeObject(encodeInvocationArgument(channel, inv, i)); } out.writeObject(inv.getAttachments()); @@ -199,7 +190,6 @@ protected void encodeRequestData(Channel channel, ObjectOutput out, Object data) @Override protected void encodeResponseData(Channel channel, ObjectOutput out, Object data) throws IOException { Result result = (Result) data; - Throwable th = result.getException(); if (th == null) { Object ret = result.getValue(); diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboCountCodec.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboCountCodec.java index 9c6b02cf236..c906083eb49 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboCountCodec.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboCountCodec.java @@ -19,12 +19,12 @@ import java.io.IOException; import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.Codec2; import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; import com.alibaba.dubbo.remoting.exchange.support.MultiMessage; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; import com.alibaba.dubbo.rpc.RpcInvocation; import com.alibaba.dubbo.rpc.RpcResult; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboExporter.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboExporter.java index e965da96263..e8abc4c772b 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboExporter.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboExporter.java @@ -15,24 +15,24 @@ */ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.util.Map; - import com.alibaba.dubbo.rpc.Exporter; import com.alibaba.dubbo.rpc.Invoker; import com.alibaba.dubbo.rpc.protocol.AbstractExporter; +import java.util.Map; + /** * DubboExporter - * + * * @author william.liangf */ public class DubboExporter extends AbstractExporter { - private final String key; + private final String key; private final Map> exporterMap; - public DubboExporter(Invoker invoker, String key, Map> exporterMap){ + public DubboExporter(Invoker invoker, String key, Map> exporterMap) { super(invoker); this.key = key; this.exporterMap = exporterMap; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboInvoker.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboInvoker.java index 57519200f67..8d5e07da544 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboInvoker.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboInvoker.java @@ -15,54 +15,49 @@ */ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.util.Set; -import java.util.concurrent.locks.ReentrantLock; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.utils.AtomicPositiveInteger; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.TimeoutException; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.exception.TimeoutException; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.RpcResult; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.protocol.AbstractInvoker; import com.alibaba.dubbo.rpc.support.RpcUtils; +import java.util.Set; +import java.util.concurrent.locks.ReentrantLock; + /** * DubboInvoker - * + * * @author william.liangf * @author chao.liuc */ public class DubboInvoker extends AbstractInvoker { - private final ExchangeClient[] clients; + private final ExchangeClient[] clients; private final AtomicPositiveInteger index = new AtomicPositiveInteger(); - private final String version; - - private final ReentrantLock destroyLock = new ReentrantLock(); - + private final String version; + + private final ReentrantLock destroyLock = new ReentrantLock(); + private final Set> invokers; - - public DubboInvoker(Class serviceType, URL url, ExchangeClient[] clients){ + + public DubboInvoker(Class serviceType, URL url, ExchangeClient[] clients) { this(serviceType, url, clients, null); } - - public DubboInvoker(Class serviceType, URL url, ExchangeClient[] clients, Set> invokers){ - super(serviceType, url, new String[] {Constants.INTERFACE_KEY, Constants.GROUP_KEY, Constants.TOKEN_KEY, Constants.TIMEOUT_KEY}); + + public DubboInvoker(Class serviceType, URL url, ExchangeClient[] clients, Set> invokers) { + super(serviceType, url, new String[]{Constants.INTERFACE_KEY, Constants.GROUP_KEY, Constants.TOKEN_KEY, Constants.TIMEOUT_KEY}); this.clients = clients; // get version. this.version = url.getParameter(Constants.VERSION_KEY, "0.0.0"); - this.invokers = invokers; + this.invokers = invokers; } @Override @@ -71,7 +66,7 @@ protected Result doInvoke(final Invocation invocation) throws Throwable { final String methodName = RpcUtils.getMethodName(invocation); inv.setAttachment(Constants.PATH_KEY, getUrl().getPath()); inv.setAttachment(Constants.VERSION_KEY, version); - + ExchangeClient currentClient; if (clients.length == 1) { currentClient = clients[0]; @@ -79,37 +74,33 @@ protected Result doInvoke(final Invocation invocation) throws Throwable { currentClient = clients[index.getAndIncrement() % clients.length]; } try { - boolean isAsync = RpcUtils.isAsync(getUrl(), invocation); boolean isOneway = RpcUtils.isOneway(getUrl(), invocation); - int timeout = getUrl().getMethodParameter(methodName, Constants.TIMEOUT_KEY,Constants.DEFAULT_TIMEOUT); + int timeout = getUrl().getMethodParameter(methodName, Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); if (isOneway) { - boolean isSent = getUrl().getMethodParameter(methodName, Constants.SENT_KEY, false); + boolean isSent = getUrl().getMethodParameter(methodName, Constants.SENT_KEY, false); currentClient.send(inv, isSent); - RpcContext.getContext().setFuture(null); - return new RpcResult(); - } else if (isAsync) { - ResponseFuture future = currentClient.request(inv, timeout) ; - RpcContext.getContext().setFuture(new FutureAdapter(future)); return new RpcResult(); } else { - RpcContext.getContext().setFuture(null); - return (Result) currentClient.request(inv, timeout).get(); + Request request = new Request.Builder().newId().data(inv).build(); + Response response = currentClient.request(request, timeout); + return (Result) response.getResult(); } } catch (TimeoutException e) { - throw new RpcException(RpcException.TIMEOUT_EXCEPTION, "Invoke remote method timeout. method: " + invocation.getMethodName() + ", provider: " + getUrl() + ", cause: " + e.getMessage(), e); + throw new RpcException(RpcException.TIMEOUT_EXCEPTION, "Invoke remote method timeout. method: " + + invocation.getMethodName() + ", provider: " + getUrl() + ", cause: " + e.getMessage(), e); } catch (RemotingException e) { - throw new RpcException(RpcException.NETWORK_EXCEPTION, "Failed to invoke remote method: " + invocation.getMethodName() + ", provider: " + getUrl() + ", cause: " + e.getMessage(), e); + throw new RpcException(RpcException.NETWORK_EXCEPTION, "Failed to invoke remote method: " + + invocation.getMethodName() + ", provider: " + getUrl() + ", cause: " + e.getMessage(), e); } } - + @Override public boolean isAvailable() { if (!super.isAvailable()) return false; - for (ExchangeClient client : clients){ - if (client.isConnected() && !client.hasAttribute(Constants.CHANNEL_ATTRIBUTE_READONLY_KEY)){ - //cannot write == not Available ? - return true ; + for (ExchangeClient client : clients) { + if (client.isConnected() && !client.hasAttribute(Constants.CHANNEL_ATTRIBUTE_READONLY_KEY)) { + return true; } } return false; @@ -117,30 +108,29 @@ public boolean isAvailable() { public void destroy() { //防止client被关闭多次.在connect per jvm的情况下,client.close方法会调用计数器-1,当计数器小于等于0的情况下,才真正关闭 - if (super.isDestroyed()){ - return ; - } else { - //dubbo check ,避免多次关闭 - destroyLock.lock(); - try{ - if (super.isDestroyed()){ - return ; - } - super.destroy(); - if (invokers != null){ - invokers.remove(this); - } - for (ExchangeClient client : clients) { - try { - client.close(); - } catch (Throwable t) { - logger.warn(t.getMessage(), t); - } + if (isDestroyed()) { + return; + } + //dubbo check ,避免多次关闭 + destroyLock.lock(); + try { + if (super.isDestroyed()) { + return; + } + super.destroy(); + if (invokers != null) { + invokers.remove(this); + } + for (ExchangeClient client : clients) { + try { + client.close(); + } catch (Throwable t) { + logger.warn(t.getMessage(), t); } - - }finally { - destroyLock.unlock(); } + + } finally { + destroyLock.unlock(); } } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboProtocol.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboProtocol.java index b90cd1274db..04b327f3812 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboProtocol.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/DubboProtocol.java @@ -15,16 +15,6 @@ */ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.net.InetSocketAddress; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.Map; -import java.util.Set; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; -import java.util.concurrent.locks.ReentrantLock; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.Version; @@ -34,24 +24,19 @@ import com.alibaba.dubbo.common.utils.ConcurrentHashSet; import com.alibaba.dubbo.common.utils.NetUtils; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Transporter; -import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; -import com.alibaba.dubbo.remoting.exchange.ExchangeClient; -import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.ExchangeServer; -import com.alibaba.dubbo.remoting.exchange.Exchangers; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.transport.Transporter; +import com.alibaba.dubbo.remoting.exchange.*; import com.alibaba.dubbo.remoting.exchange.support.ExchangeHandlerAdapter; -import com.alibaba.dubbo.rpc.Exporter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Protocol; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.protocol.AbstractProtocol; +import java.net.InetSocketAddress; +import java.util.*; +import java.util.concurrent.ConcurrentHashMap; +import java.util.concurrent.ConcurrentMap; + /** * dubbo protocol support. * @@ -64,55 +49,65 @@ public class DubboProtocol extends AbstractProtocol { public static final String NAME = "dubbo"; public static final String COMPATIBLE_CODEC_NAME = "dubbo1compatible"; - + public static final int DEFAULT_PORT = 20880; - - public final ReentrantLock lock = new ReentrantLock(); - + private final Map serverMap = new ConcurrentHashMap(); // - + private final Map referenceClientMap = new ConcurrentHashMap(); // - + private final ConcurrentMap ghostClientMap = new ConcurrentHashMap(); private final Set optimizers = new ConcurrentHashSet(); - //consumer side export a stub service for dispatching event - //servicekey-stubmethods - private final ConcurrentMap stubServiceMethodsMap = new ConcurrentHashMap(); - private static final String IS_CALLBACK_SERVICE_INVOKE = "_isCallBackServiceInvoke"; + private static DubboProtocol INSTANCE; + + public DubboProtocol() { + INSTANCE = this; + } + + public static DubboProtocol getDubboProtocol() { + if (INSTANCE == null) { + ExtensionLoader.getExtensionLoader(Protocol.class).getExtension(DubboProtocol.NAME); + } + return INSTANCE; + } + private ExchangeHandler requestHandler = new ExchangeHandlerAdapter() { - + public Object reply(ExchangeChannel channel, Object message) throws RemotingException { if (message instanceof Invocation) { Invocation inv = (Invocation) message; Invoker invoker = getInvoker(channel, inv); //如果是callback 需要处理高版本调用低版本的问题 - if (Boolean.TRUE.toString().equals(inv.getAttachments().get(IS_CALLBACK_SERVICE_INVOKE))){ + if (Boolean.TRUE.toString().equals(inv.getAttachments().get(IS_CALLBACK_SERVICE_INVOKE))) { String methodsStr = invoker.getUrl().getParameters().get("methods"); boolean hasMethod = false; - if (methodsStr == null || methodsStr.indexOf(",") == -1){ + if (methodsStr == null || !methodsStr.contains(",")) { hasMethod = inv.getMethodName().equals(methodsStr); } else { String[] methods = methodsStr.split(","); - for (String method : methods){ - if (inv.getMethodName().equals(method)){ + for (String method : methods) { + if (inv.getMethodName().equals(method)) { hasMethod = true; break; } } } - if (!hasMethod){ - logger.warn(new IllegalStateException("The methodName "+inv.getMethodName()+" not found in callback service interface ,invoke will be ignored. please update the api interface. url is:" + invoker.getUrl()) +" ,invocation is :"+inv ); + if (!hasMethod) { + logger.warn(new IllegalStateException("The methodName " + inv.getMethodName() + + " not found in callback service interface ,invoke will be ignored. " + + "please update the api interface. url is:" + invoker.getUrl()) + " ,invocation is :" + inv); return null; } } RpcContext.getContext().setRemoteAddress(channel.getRemoteAddress()); return invoker.invoke(inv); } - throw new RemotingException(channel, "Unsupported request: " + message == null ? null : (message.getClass().getName() + ": " + message) + ", channel: consumer: " + channel.getRemoteAddress() + " --> provider: " + channel.getLocalAddress()); + throw new RemotingException(channel, (message.getClass().getName() + ": " + message) + ", channel: consumer: " + + channel.getRemoteAddress() + " --> provider: " + channel.getLocalAddress()); } @Override @@ -131,12 +126,12 @@ public void connected(Channel channel) throws RemotingException { @Override public void disconnected(Channel channel) throws RemotingException { - if(logger.isInfoEnabled()){ - logger.info("disconected from "+ channel.getRemoteAddress() + ",url:" + channel.getUrl()); + if (logger.isInfoEnabled()) { + logger.info("disconnected from " + channel.getRemoteAddress() + ",url:" + channel.getUrl()); } invoke(channel, Constants.ON_DISCONNECT_KEY); } - + private void invoke(Channel channel, String methodKey) { Invocation invocation = createInvocation(channel, channel.getUrl(), methodKey); if (invocation != null) { @@ -147,7 +142,7 @@ private void invoke(Channel channel, String methodKey) { } } } - + private Invocation createInvocation(Channel channel, URL url, String methodKey) { String method = url.getParameter(methodKey); if (method == null || method.length() == 0) { @@ -158,25 +153,12 @@ private Invocation createInvocation(Channel channel, URL url, String methodKey) invocation.setAttachment(Constants.GROUP_KEY, url.getParameter(Constants.GROUP_KEY)); invocation.setAttachment(Constants.INTERFACE_KEY, url.getParameter(Constants.INTERFACE_KEY)); invocation.setAttachment(Constants.VERSION_KEY, url.getParameter(Constants.VERSION_KEY)); - if (url.getParameter(Constants.STUB_EVENT_KEY, false)){ + if (url.getParameter(Constants.STUB_EVENT_KEY, false)) { invocation.setAttachment(Constants.STUB_EVENT_KEY, Boolean.TRUE.toString()); } return invocation; } }; - - private static DubboProtocol INSTANCE; - - public DubboProtocol() { - INSTANCE = this; - } - - public static DubboProtocol getDubboProtocol() { - if (INSTANCE == null) { - ExtensionLoader.getExtensionLoader(Protocol.class).getExtension(DubboProtocol.NAME); // load - } - return INSTANCE; - } public Collection getServers() { return Collections.unmodifiableCollection(serverMap.values()); @@ -185,45 +167,43 @@ public Collection getServers() { public Collection> getExporters() { return Collections.unmodifiableCollection(exporterMap.values()); } - - Map> getExporterMap(){ - return exporterMap; - } - + private boolean isClientSide(Channel channel) { InetSocketAddress address = channel.getRemoteAddress(); URL url = channel.getUrl(); - return url.getPort() == address.getPort() && - NetUtils.filterLocalHost(channel.getUrl().getIp()) - .equals(NetUtils.filterLocalHost(address.getAddress().getHostAddress())); + return url.getPort() == address.getPort() && + NetUtils.filterLocalHost(channel.getUrl().getIp()) + .equals(NetUtils.filterLocalHost(address.getAddress().getHostAddress())); } - - Invoker getInvoker(Channel channel, Invocation inv) throws RemotingException{ + + Invoker getInvoker(Channel channel, Invocation inv) throws RemotingException { boolean isCallBackServiceInvoke = false; boolean isStubServiceInvoke = false; int port = channel.getLocalAddress().getPort(); String path = inv.getAttachments().get(Constants.PATH_KEY); //如果是客户端的回调服务. isStubServiceInvoke = Boolean.TRUE.toString().equals(inv.getAttachments().get(Constants.STUB_EVENT_KEY)); - if (isStubServiceInvoke){ + if (isStubServiceInvoke) { port = channel.getRemoteAddress().getPort(); } //callback isCallBackServiceInvoke = isClientSide(channel) && !isStubServiceInvoke; - if(isCallBackServiceInvoke){ - path = inv.getAttachments().get(Constants.PATH_KEY)+"."+inv.getAttachments().get(Constants.CALLBACK_SERVICE_KEY); + if (isCallBackServiceInvoke) { + path = inv.getAttachments().get(Constants.PATH_KEY) + "." + inv.getAttachments().get(Constants.CALLBACK_SERVICE_KEY); inv.getAttachments().put(IS_CALLBACK_SERVICE_INVOKE, Boolean.TRUE.toString()); } String serviceKey = serviceKey(port, path, inv.getAttachments().get(Constants.VERSION_KEY), inv.getAttachments().get(Constants.GROUP_KEY)); DubboExporter exporter = (DubboExporter) exporterMap.get(serviceKey); - + if (exporter == null) - throw new RemotingException(channel, "Not found exported service: " + serviceKey + " in " + exporterMap.keySet() + ", may be version or group mismatch " + ", channel: consumer: " + channel.getRemoteAddress() + " --> provider: " + channel.getLocalAddress() + ", message:" + inv); + throw new RemotingException(channel, "Not found exported service: " + serviceKey + " in " + + exporterMap.keySet() + ", may be version or group mismatch " + ", channel: consumer: " + + channel.getRemoteAddress() + " --> provider: " + channel.getLocalAddress() + ", message:" + inv); return exporter.getInvoker(); } - + public Collection> getInvokers() { return Collections.unmodifiableCollection(invokers); } @@ -234,32 +214,25 @@ public int getDefaultPort() { public Exporter export(Invoker invoker) throws RpcException { URL url = invoker.getUrl(); - // export service. String key = serviceKey(url); DubboExporter exporter = new DubboExporter(invoker, key, exporterMap); exporterMap.put(key, exporter); - - //export an stub service for dispaching event - Boolean isStubSupportEvent = url.getParameter(Constants.STUB_EVENT_KEY,Constants.DEFAULT_STUB_EVENT); - Boolean isCallbackservice = url.getParameter(Constants.IS_CALLBACK_SERVICE, false); - if (isStubSupportEvent && !isCallbackservice){ + //export an stub service for dispatching event + Boolean isStubSupportEvent = url.getParameter(Constants.STUB_EVENT_KEY, Constants.DEFAULT_STUB_EVENT); + Boolean isCallbackService = url.getParameter(Constants.IS_CALLBACK_SERVICE, false); + if (isStubSupportEvent && !isCallbackService) { String stubServiceMethods = url.getParameter(Constants.STUB_EVENT_METHODS_KEY); - if (stubServiceMethods == null || stubServiceMethods.length() == 0 ){ - if (logger.isWarnEnabled()){ - logger.warn(new IllegalStateException("consumer [" +url.getParameter(Constants.INTERFACE_KEY) + + if (stubServiceMethods == null || stubServiceMethods.length() == 0) { + if (logger.isWarnEnabled()) { + logger.warn(new IllegalStateException("consumer [" + url.getParameter(Constants.INTERFACE_KEY) + "], has set stubproxy support event ,but no stub methods founded.")); } - } else { - stubServiceMethodsMap.put(url.getServiceKey(), stubServiceMethods); } } - openServer(url); - // modified by lishen optimizeSerialization(url); - return exporter; } @@ -286,7 +259,6 @@ private void optimizeSerialization(URL url) throws RpcException { for (Class c : optimizer.getSerializableClasses()) { SerializableClassRegistry.registerClass(c); } - optimizers.add(className); } catch (ClassNotFoundException e) { throw new RpcException("Cannot find the serialization optimizer class: " + className, e); @@ -296,23 +268,23 @@ private void optimizeSerialization(URL url) throws RpcException { throw new RpcException("Cannot instantiate the serialization optimizer class: " + className, e); } } - + private void openServer(URL url) { // find server. String key = url.getAddress(); //client 也可以暴露一个只有server可以调用的服务。 - boolean isServer = url.getParameter(Constants.IS_SERVER_KEY,true); + boolean isServer = url.getParameter(Constants.IS_SERVER_KEY, true); if (isServer) { - ExchangeServer server = serverMap.get(key); - if (server == null) { - serverMap.put(key, createServer(url)); - } else { - //server支持reset,配合override功能使用 - server.reset(url); - } + ExchangeServer server = serverMap.get(key); + if (server == null) { + serverMap.put(key, createServer(url)); + } else { + //server支持reset,配合override功能使用 + server.reset(url); + } } } - + private ExchangeServer createServer(URL url) { //默认开启server关闭时发送readonly事件 url = url.addParameterIfAbsent(Constants.CHANNEL_READONLYEVENT_SENT_KEY, Boolean.TRUE.toString()); @@ -320,7 +292,7 @@ private ExchangeServer createServer(URL url) { url = url.addParameterIfAbsent(Constants.HEARTBEAT_KEY, String.valueOf(Constants.DEFAULT_HEARTBEAT)); String str = url.getParameter(Constants.SERVER_KEY, Constants.DEFAULT_REMOTING_SERVER); - if (str != null && str.length() > 0 && ! ExtensionLoader.getExtensionLoader(Transporter.class).hasExtension(str)) + if (str != null && str.length() > 0 && !ExtensionLoader.getExtensionLoader(Transporter.class).hasExtension(str)) throw new RpcException("Unsupported server type: " + str + ", url: " + url); url = url.addParameter(Constants.CODEC_KEY, Version.isCompatibleVersion() ? COMPATIBLE_CODEC_NAME : DubboCodec.NAME); @@ -341,29 +313,27 @@ private ExchangeServer createServer(URL url) { } public Invoker refer(Class serviceType, URL url) throws RpcException { - // modified by lishen optimizeSerialization(url); - // create rpc invoker. DubboInvoker invoker = new DubboInvoker(serviceType, url, getClients(url), invokers); invokers.add(invoker); return invoker; } - - private ExchangeClient[] getClients(URL url){ + + private ExchangeClient[] getClients(URL url) { //是否共享连接 boolean service_share_connect = false; int connections = url.getParameter(Constants.CONNECTIONS_KEY, 0); //如果connections不配置,则共享连接,否则每服务每连接 - if (connections == 0){ + if (connections == 0) { service_share_connect = true; connections = 1; } - + ExchangeClient[] clients = new ExchangeClient[connections]; for (int i = 0; i < clients.length; i++) { - if (service_share_connect){ + if (service_share_connect) { clients[i] = getSharedClient(url); } else { clients[i] = initClient(url); @@ -371,35 +341,32 @@ private ExchangeClient[] getClients(URL url){ } return clients; } - + /** - *获取共享连接 + * 获取共享连接 */ - private ExchangeClient getSharedClient(URL url){ + private ExchangeClient getSharedClient(URL url) { String key = url.getAddress(); ReferenceCountExchangeClient client = referenceClientMap.get(key); - if ( client != null ){ - if ( !client.isClosed()){ + if (client != null) { + if (!client.isClosed()) { client.incrementAndGetCount(); return client; } else { -// logger.warn(new IllegalStateException("client is closed,but stay in clientmap .client :"+ client)); referenceClientMap.remove(key); } } - ExchangeClient exchagneclient = initClient(url); - - client = new ReferenceCountExchangeClient(exchagneclient, ghostClientMap); + ExchangeClient exchangeClient = initClient(url); + client = new ReferenceCountExchangeClient(exchangeClient, ghostClientMap); referenceClientMap.put(key, client); ghostClientMap.remove(key); - return client; + return client; } /** * 创建新连接. */ private ExchangeClient initClient(URL url) { - // client type setting. String str = url.getParameter(Constants.CLIENT_KEY, url.getParameter(Constants.SERVER_KEY, Constants.DEFAULT_REMOTING_CLIENT)); @@ -408,20 +375,20 @@ private ExchangeClient initClient(URL url) { url = url.addParameter(Constants.CODEC_KEY, Version.isCompatibleVersion() && compatible ? COMPATIBLE_CODEC_NAME : DubboCodec.NAME); //默认开启heartbeat url = url.addParameterIfAbsent(Constants.HEARTBEAT_KEY, String.valueOf(Constants.DEFAULT_HEARTBEAT)); - + // BIO存在严重性能问题,暂时不允许使用 - if (str != null && str.length() > 0 && ! ExtensionLoader.getExtensionLoader(Transporter.class).hasExtension(str)) { + if (str != null && str.length() > 0 && !ExtensionLoader.getExtensionLoader(Transporter.class).hasExtension(str)) { throw new RpcException("Unsupported client type: " + str + "," + " supported client type is " + StringUtils.join(ExtensionLoader.getExtensionLoader(Transporter.class).getSupportedExtensions(), " ")); } - - ExchangeClient client ; + + ExchangeClient client; try { //设置连接应该是lazy的 - if (url.getParameter(Constants.LAZY_CONNECT_KEY, false)){ - client = new LazyConnectExchangeClient(url ,requestHandler); + if (url.getParameter(Constants.LAZY_CONNECT_KEY, false)) { + client = new LazyConnectExchangeClient(url, requestHandler); } else { - client = Exchangers.connect(url ,requestHandler); + client = Exchangers.connect(url, requestHandler); } } catch (RemotingException e) { throw new RpcException("Fail to create remoting client for service(" + url @@ -444,7 +411,7 @@ public void destroy() { } } } - + for (String key : new ArrayList(referenceClientMap.keySet())) { ExchangeClient client = referenceClientMap.remove(key); if (client != null) { @@ -458,7 +425,7 @@ public void destroy() { } } } - + for (String key : new ArrayList(ghostClientMap.keySet())) { ExchangeClient client = ghostClientMap.remove(key); if (client != null) { @@ -472,7 +439,6 @@ public void destroy() { } } } - stubServiceMethodsMap.clear(); super.destroy(); } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/FutureAdapter.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/FutureAdapter.java deleted file mode 100644 index c213116a9ff..00000000000 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/FutureAdapter.java +++ /dev/null @@ -1,83 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.rpc.protocol.dubbo; - -import java.util.concurrent.ExecutionException; -import java.util.concurrent.Future; -import java.util.concurrent.TimeUnit; -import java.util.concurrent.TimeoutException; - -import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; - -/** - * FutureAdapter - * - * @author william.liangf - */ -public class FutureAdapter implements Future { - - private final ResponseFuture future; - - public FutureAdapter(ResponseFuture future){ - this.future = future; - } - - public ResponseFuture getFuture() { - return future; - } - - public boolean cancel(boolean mayInterruptIfRunning) { - return false; - } - - public boolean isCancelled() { - return false; - } - - public boolean isDone() { - return future.isDone(); - } - - @SuppressWarnings("unchecked") - public V get() throws InterruptedException, ExecutionException { - try { - return (V) (((Result) future.get()).recreate()); - } catch (RemotingException e) { - throw new ExecutionException(e.getMessage(), e); - } catch (Throwable e) { - throw new RpcException(e); - } - } - - @SuppressWarnings("unchecked") - public V get(long timeout, TimeUnit unit) throws InterruptedException, ExecutionException, TimeoutException { - int timeoutInMillis = (int) unit.convert(timeout, TimeUnit.MILLISECONDS); - try { - return (V) (((Result) future.get(timeoutInMillis)).recreate()); - } catch (com.alibaba.dubbo.remoting.TimeoutException e) { - throw new TimeoutException(StringUtils.toString(e)); - } catch (RemotingException e) { - throw new ExecutionException(e.getMessage(), e); - } catch (Throwable e) { - throw new RpcException(e); - } - } - -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/LazyConnectExchangeClient.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/LazyConnectExchangeClient.java index dd27a534736..67d3eed7b9c 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/LazyConnectExchangeClient.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/LazyConnectExchangeClient.java @@ -1,73 +1,75 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.protocol.dubbo; -import java.net.InetSocketAddress; -import java.util.concurrent.atomic.AtomicLong; -import java.util.concurrent.locks.Lock; -import java.util.concurrent.locks.ReentrantLock; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.Parameters; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.exchange.ExchangeClient; -import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.Exchangers; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.Parameters; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.logger.Logger; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.common.utils.NetUtils; +import com.alibaba.dubbo.remoting.exception.RemotingException; +import com.alibaba.dubbo.remoting.exchange.ExchangeClient; +import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; +import com.alibaba.dubbo.remoting.exchange.Exchangers; +import com.alibaba.dubbo.remoting.message.Interceptor; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; + +import java.net.InetSocketAddress; +import java.util.concurrent.atomic.AtomicLong; +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; /** * dubbo protocol support class. - * + * * @author chao.liuc */ -@SuppressWarnings("deprecation") -final class LazyConnectExchangeClient implements ExchangeClient{ +@SuppressWarnings("deprecation") +final class LazyConnectExchangeClient implements ExchangeClient { - private final static Logger logger = LoggerFactory.getLogger(LazyConnectExchangeClient.class); + private final static Logger logger = LoggerFactory.getLogger(LazyConnectExchangeClient.class); - private final URL url; - private final ExchangeHandler requestHandler; - private volatile ExchangeClient client; - private final Lock connectLock = new ReentrantLock(); + private final URL url; + private final ExchangeHandler requestHandler; + private volatile ExchangeClient client; + private final Lock connectLock = new ReentrantLock(); //lazy connect 如果没有初始化时的连接状态 - private final boolean initialState ; - - protected final boolean requestWithWarning; - - //当调用时warning,出现这个warning,表示程序可能存在bug. - static final String REQUEST_WITH_WARNING_KEY = "lazyclient_request_with_warning"; - - private AtomicLong warningcount = new AtomicLong(0); - + private final boolean initialState; + + protected final boolean requestWithWarning; + + //当调用时warning,出现这个warning,表示程序可能存在bug. + static final String REQUEST_WITH_WARNING_KEY = "lazyclient_request_with_warning"; + + private AtomicLong warningcount = new AtomicLong(0); + public LazyConnectExchangeClient(URL url, ExchangeHandler requestHandler) { //lazy connect ,need set send.reconnect = true, to avoid channel bad status. this.url = url.addParameter(Constants.SEND_RECONNECT_KEY, Boolean.TRUE.toString()); this.requestHandler = requestHandler; - this.initialState = url.getParameter(Constants.LAZY_CONNECT_INITIAL_STATE_KEY,Constants.DEFAULT_LAZY_CONNECT_INITIAL_STATE); + this.initialState = url.getParameter(Constants.LAZY_CONNECT_INITIAL_STATE_KEY, Constants.DEFAULT_LAZY_CONNECT_INITIAL_STATE); this.requestWithWarning = url.getParameter(REQUEST_WITH_WARNING_KEY, false); - } - + } + private void initClient() throws RemotingException { - if (client != null ) + if (client != null) return; if (logger.isInfoEnabled()) { logger.info("Lazy connect to " + url); @@ -82,45 +84,45 @@ private void initClient() throws RemotingException { } } - public ResponseFuture request(Object request) throws RemotingException { - warning(request); - initClient(); - return client.request(request); - } - public URL getUrl() { return url; } public InetSocketAddress getRemoteAddress() { - if (client == null){ - return InetSocketAddress.createUnresolved(url.getHost(), url.getPort()); - } else { - return client.getRemoteAddress(); + if (client == null) { + return InetSocketAddress.createUnresolved(url.getHost(), url.getPort()); + } else { + return client.getRemoteAddress(); } } - public ResponseFuture request(Object request, int timeout) throws RemotingException { - warning(request); - initClient(); + + @Override + public Response request(Request request) throws RemotingException { + return client.request(request); + } + + @Override + public Response request(Request request, int timeout) throws RemotingException { return client.request(request, timeout); - } - - /** - * 如果配置了调用warning,则每调用5000次warning一次. - * @param request - */ - private void warning(Object request){ - if (requestWithWarning ){ - if (warningcount.get() % 5000 == 0){ - logger.warn(new IllegalStateException("safe guard client , should not be called ,must have a bug.")); - } - warningcount.incrementAndGet() ; - } - } - + } + + /** + * 如果配置了调用warning,则每调用5000次warning一次. + * + * @param request + */ + private void warning(Object request) { + if (requestWithWarning) { + if (warningcount.get() % 5000 == 0) { + logger.warn(new IllegalStateException("safe guard client , should not be called ,must have a bug.")); + } + warningcount.incrementAndGet(); + } + } + public ChannelHandler getChannelHandler() { checkClient(); - return client.getChannelHandler(); + return client.getChannelHandler(); } public boolean isConnected() { @@ -132,10 +134,10 @@ public boolean isConnected() { } public InetSocketAddress getLocalAddress() { - if (client == null){ - return InetSocketAddress.createUnresolved(NetUtils.getLocalHost(), 0); - } else { - return client.getLocalAddress(); + if (client == null) { + return InetSocketAddress.createUnresolved(NetUtils.getLocalHost(), 0); + } else { + return client.getLocalAddress(); } } @@ -173,11 +175,11 @@ public void close(int timeout) { public void reset(URL url) { checkClient(); client.reset(url); - } - - @Deprecated - public void reset(Parameters parameters){ - reset(getUrl().addParameters(parameters.getParameters())); + } + + @Deprecated + public void reset(Parameters parameters) { + reset(getUrl().addParameters(parameters.getParameters())); } public void reconnect() throws RemotingException { @@ -186,10 +188,10 @@ public void reconnect() throws RemotingException { } public Object getAttribute(String key) { - if (client == null){ - return null; - } else { - return client.getAttribute(key); + if (client == null) { + return null; + } else { + return client.getAttribute(key); } } @@ -204,10 +206,10 @@ public void removeAttribute(String key) { } public boolean hasAttribute(String key) { - if (client == null){ - return false; + if (client == null) { + return false; } else { - return client.hasAttribute(key); + return client.hasAttribute(key); } } @@ -216,5 +218,10 @@ private void checkClient() { throw new IllegalStateException( "LazyConnectExchangeClient state error. the client has not be init .url:" + url); } - } + } + + @Override + public void addInterceptor(Interceptor interceptor) { + client.addInterceptor(interceptor); + } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/ReferenceCountExchangeClient.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/ReferenceCountExchangeClient.java index ccfb35c2923..def511dda59 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/ReferenceCountExchangeClient.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/ReferenceCountExchangeClient.java @@ -13,57 +13,53 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.rpc.protocol.dubbo; - -import java.net.InetSocketAddress; -import java.util.concurrent.ConcurrentMap; -import java.util.concurrent.atomic.AtomicInteger; +package com.alibaba.dubbo.rpc.protocol.dubbo; import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.Parameters; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; - -/** - * dubbo protocol support class. - * - * @author chao.liuc - */ +import com.alibaba.dubbo.remoting.message.Interceptor; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.ChannelHandler; + +import java.net.InetSocketAddress; +import java.util.concurrent.ConcurrentMap; +import java.util.concurrent.atomic.AtomicInteger; + +/** + * dubbo protocol support class. + * + * @author chao.liuc + */ @SuppressWarnings("deprecation") -final class ReferenceCountExchangeClient implements ExchangeClient { - +final class ReferenceCountExchangeClient implements ExchangeClient { + private ExchangeClient client; - + private final URL url; - -// private final ExchangeHandler handler; - - private final AtomicInteger refenceCount = new AtomicInteger(0); - + + private final AtomicInteger referenceCount = new AtomicInteger(0); + private final ConcurrentMap ghostClientMap; - - + public ReferenceCountExchangeClient(ExchangeClient client, ConcurrentMap ghostClientMap) { this.client = client; - refenceCount.incrementAndGet(); + referenceCount.incrementAndGet(); this.url = client.getUrl(); - if (ghostClientMap == null){ + if (ghostClientMap == null) { throw new IllegalStateException("ghostClientMap can not be null, url: " + url); } this.ghostClientMap = ghostClientMap; - } - + } + public void reset(URL url) { client.reset(url); } - public ResponseFuture request(Object request) throws RemotingException { - return client.request(request); - } public URL getUrl() { return client.getUrl(); @@ -77,7 +73,13 @@ public ChannelHandler getChannelHandler() { return client.getChannelHandler(); } - public ResponseFuture request(Object request, int timeout) throws RemotingException { + @Override + public Response request(Request request) throws RemotingException { + return client.request(request); + } + + @Override + public Response request(Request request, int timeout) throws RemotingException { return client.request(request, timeout); } @@ -124,7 +126,8 @@ public void setAttribute(String key, Object value) { public void removeAttribute(String key) { client.removeAttribute(key); } - /* + + /* * close方法将不再幂等,调用需要注意. */ public void close() { @@ -132,8 +135,8 @@ public void close() { } public void close(int timeout) { - if (refenceCount.decrementAndGet() <= 0){ - if (timeout == 0){ + if (referenceCount.decrementAndGet() <= 0) { + if (timeout == 0) { client.close(); } else { client.close(timeout); @@ -141,9 +144,9 @@ public void close(int timeout) { client = replaceWithLazyClient(); } } - + //幽灵client, - private LazyConnectExchangeClient replaceWithLazyClient(){ + private LazyConnectExchangeClient replaceWithLazyClient() { //这个操作只为了防止程序bug错误关闭client做的防御措施,初始client必须为false状态 URL lazyUrl = url.addParameter(Constants.LAZY_CONNECT_INITIAL_STATE_KEY, Boolean.FALSE) .addParameter(Constants.RECONNECT_KEY, Boolean.FALSE) @@ -151,11 +154,11 @@ private LazyConnectExchangeClient replaceWithLazyClient(){ .addParameter("warning", Boolean.TRUE.toString()) .addParameter(LazyConnectExchangeClient.REQUEST_WITH_WARNING_KEY, true) .addParameter("_client_memo", "referencecounthandler.replacewithlazyclient"); - + String key = url.getAddress(); //最差情况下只有一个幽灵连接 LazyConnectExchangeClient gclient = ghostClientMap.get(key); - if (gclient == null || gclient.isClosed()){ + if (gclient == null || gclient.isClosed()) { gclient = new LazyConnectExchangeClient(lazyUrl, client.getExchangeHandler()); ghostClientMap.put(key, gclient); } @@ -165,8 +168,13 @@ private LazyConnectExchangeClient replaceWithLazyClient(){ public boolean isClosed() { return client.isClosed(); } - - public void incrementAndGetCount(){ - refenceCount.incrementAndGet(); + + public void incrementAndGetCount() { + referenceCount.incrementAndGet(); + } + + @Override + public void addInterceptor(Interceptor interceptor) { + client.addInterceptor(interceptor); } } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/filter/FutureFilter.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/filter/FutureFilter.java deleted file mode 100644 index cc5cf7d9998..00000000000 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/filter/FutureFilter.java +++ /dev/null @@ -1,205 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.rpc.protocol.dubbo.filter; - -import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.concurrent.Future; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.extension.Activate; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.exchange.ResponseCallback; -import com.alibaba.dubbo.remoting.exchange.ResponseFuture; -import com.alibaba.dubbo.rpc.Filter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.StaticContext; -import com.alibaba.dubbo.rpc.protocol.dubbo.FutureAdapter; -import com.alibaba.dubbo.rpc.support.RpcUtils; - -/** - * EventFilter - * @author chao.liuc - * @author william.liangf - */ -@Activate(group = Constants.CONSUMER) -public class FutureFilter implements Filter { - - protected static final Logger logger = LoggerFactory.getLogger(FutureFilter.class); - - public Result invoke(final Invoker invoker, final Invocation invocation) throws RpcException { - final boolean isAsync = RpcUtils.isAsync(invoker.getUrl(), invocation); - - fireInvokeCallback(invoker, invocation); - //需要在调用前配置好是否有返回值,已供invoker判断是否需要返回future. - Result result = invoker.invoke(invocation); - if (isAsync) { - asyncCallback(invoker, invocation); - } else { - syncCallback(invoker, invocation, result); - } - return result; - } - - private void syncCallback(final Invoker invoker, final Invocation invocation, final Result result) { - if (result.hasException()) { - fireThrowCallback(invoker, invocation, result.getException()); - } else { - fireReturnCallback(invoker, invocation, result.getValue()); - } - } - - private void asyncCallback(final Invoker invoker, final Invocation invocation) { - Future f = RpcContext.getContext().getFuture(); - if (f instanceof FutureAdapter) { - ResponseFuture future = ((FutureAdapter)f).getFuture(); - future.setCallback(new ResponseCallback() { - public void done(Object rpcResult) { - if (rpcResult == null){ - logger.error(new IllegalStateException("invalid result value : null, expected "+Result.class.getName())); - return; - } - ///must be rpcResult - if (! (rpcResult instanceof Result)){ - logger.error(new IllegalStateException("invalid result type :" + rpcResult.getClass() + ", expected "+Result.class.getName())); - return; - } - Result result = (Result) rpcResult; - if (result.hasException()) { - fireThrowCallback(invoker, invocation, result.getException()); - } else { - fireReturnCallback(invoker, invocation, result.getValue()); - } - } - public void caught(Throwable exception) { - fireThrowCallback(invoker, invocation, exception); - } - }); - } - } - - private void fireInvokeCallback(final Invoker invoker, final Invocation invocation) { - final Method onInvokeMethod = (Method)StaticContext.getSystemContext().get(StaticContext.getKey(invoker.getUrl(), invocation.getMethodName(), Constants.ON_INVOKE_METHOD_KEY)); - final Object onInvokeInst = StaticContext.getSystemContext().get(StaticContext.getKey(invoker.getUrl(), invocation.getMethodName(), Constants.ON_INVOKE_INSTANCE_KEY)); - - if (onInvokeMethod == null && onInvokeInst == null ){ - return ; - } - if (onInvokeMethod == null || onInvokeInst == null ){ - throw new IllegalStateException("service:" + invoker.getUrl().getServiceKey() +" has a onreturn callback config , but no such "+(onInvokeMethod == null ? "method" : "instance")+" found. url:"+invoker.getUrl()); - } - if (onInvokeMethod != null && ! onInvokeMethod.isAccessible()) { - onInvokeMethod.setAccessible(true); - } - - Object[] params = invocation.getArguments(); - try { - onInvokeMethod.invoke(onInvokeInst, params); - } catch (InvocationTargetException e) { - fireThrowCallback(invoker, invocation, e.getTargetException()); - } catch (Throwable e) { - fireThrowCallback(invoker, invocation, e); - } - } - - private void fireReturnCallback(final Invoker invoker, final Invocation invocation, final Object result) { - final Method onReturnMethod = (Method)StaticContext.getSystemContext().get(StaticContext.getKey(invoker.getUrl(), invocation.getMethodName(), Constants.ON_RETURN_METHOD_KEY)); - final Object onReturnInst = StaticContext.getSystemContext().get(StaticContext.getKey(invoker.getUrl(), invocation.getMethodName(), Constants.ON_RETURN_INSTANCE_KEY)); - - //not set onreturn callback - if (onReturnMethod == null && onReturnInst == null ){ - return ; - } - - if (onReturnMethod == null || onReturnInst == null ){ - throw new IllegalStateException("service:" + invoker.getUrl().getServiceKey() +" has a onreturn callback config , but no such "+(onReturnMethod == null ? "method" : "instance")+" found. url:"+invoker.getUrl()); - } - if (onReturnMethod != null && ! onReturnMethod.isAccessible()) { - onReturnMethod.setAccessible(true); - } - - Object[] args = invocation.getArguments(); - Object[] params ; - Class[] rParaTypes = onReturnMethod.getParameterTypes() ; - if (rParaTypes.length >1 ) { - if (rParaTypes.length == 2 && rParaTypes[1].isAssignableFrom(Object[].class)){ - params = new Object[2]; - params[0] = result; - params[1] = args ; - }else { - params = new Object[args.length + 1]; - params[0] = result; - System.arraycopy(args, 0, params, 1, args.length); - } - } else { - params = new Object[] { result }; - } - try { - onReturnMethod.invoke(onReturnInst, params); - } catch (InvocationTargetException e) { - fireThrowCallback(invoker, invocation, e.getTargetException()); - } catch (Throwable e) { - fireThrowCallback(invoker, invocation, e); - } - } - - private void fireThrowCallback(final Invoker invoker, final Invocation invocation, final Throwable exception) { - final Method onthrowMethod = (Method)StaticContext.getSystemContext().get(StaticContext.getKey(invoker.getUrl(), invocation.getMethodName(), Constants.ON_THROW_METHOD_KEY)); - final Object onthrowInst = StaticContext.getSystemContext().get(StaticContext.getKey(invoker.getUrl(), invocation.getMethodName(), Constants.ON_THROW_INSTANCE_KEY)); - - //没有设置onthrow callback. - if (onthrowMethod == null && onthrowInst == null ){ - return ; - } - if (onthrowMethod == null || onthrowInst == null ){ - throw new IllegalStateException("service:" + invoker.getUrl().getServiceKey() +" has a onthrow callback config , but no such "+(onthrowMethod == null ? "method" : "instance")+" found. url:"+invoker.getUrl()); - } - if (onthrowMethod != null && ! onthrowMethod.isAccessible()) { - onthrowMethod.setAccessible(true); - } - Class[] rParaTypes = onthrowMethod.getParameterTypes() ; - if (rParaTypes[0].isAssignableFrom(exception.getClass())){ - try { - Object[] args = invocation.getArguments(); - Object[] params; - - if (rParaTypes.length >1 ) { - if (rParaTypes.length == 2 && rParaTypes[1].isAssignableFrom(Object[].class)){ - params = new Object[2]; - params[0] = exception; - params[1] = args ; - }else { - params = new Object[args.length + 1]; - params[0] = exception; - System.arraycopy(args, 0, params, 1, args.length); - } - } else { - params = new Object[] { exception }; - } - onthrowMethod.invoke(onthrowInst,params); - } catch (Throwable e) { - logger.error(invocation.getMethodName() +".call back method invoke error . callback method :" + onthrowMethod + ", url:"+ invoker.getUrl(), e); - } - } else { - logger.error(invocation.getMethodName() +".call back method invoke error . callback method :" + onthrowMethod + ", url:"+ invoker.getUrl(), exception); - } - } -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/filter/TraceFilter.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/filter/TraceFilter.java index 26309233ec3..8bcd6d26a90 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/filter/TraceFilter.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/filter/TraceFilter.java @@ -27,7 +27,7 @@ import com.alibaba.dubbo.common.logger.Logger; import com.alibaba.dubbo.common.logger.LoggerFactory; import com.alibaba.dubbo.common.utils.ConcurrentHashSet; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.rpc.Filter; import com.alibaba.dubbo.rpc.Invocation; import com.alibaba.dubbo.rpc.Invoker; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ChangeTelnetHandler.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ChangeTelnetHandler.java index 1f998bfab3f..b3162a39e71 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ChangeTelnetHandler.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ChangeTelnetHandler.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.rpc.protocol.dubbo.telnet; import com.alibaba.dubbo.common.extension.Activate; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; import com.alibaba.dubbo.rpc.Exporter; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CountTelnetHandler.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CountTelnetHandler.java index b58be301212..d8071f10066 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CountTelnetHandler.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CountTelnetHandler.java @@ -22,8 +22,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; import com.alibaba.dubbo.remoting.telnet.support.TelnetUtils; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CurrentTelnetHandler.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CurrentTelnetHandler.java index 529c05b1e04..dae36192f59 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CurrentTelnetHandler.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CurrentTelnetHandler.java @@ -16,7 +16,7 @@ package com.alibaba.dubbo.rpc.protocol.dubbo.telnet; import com.alibaba.dubbo.common.extension.Activate; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/InvokeTelnetHandler.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/InvokeTelnetHandler.java index 4bd16895815..c902c03f5a0 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/InvokeTelnetHandler.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/InvokeTelnetHandler.java @@ -25,7 +25,7 @@ import com.alibaba.dubbo.common.utils.PojoUtils; import com.alibaba.dubbo.common.utils.ReflectUtils; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; import com.alibaba.dubbo.rpc.Exporter; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ListTelnetHandler.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ListTelnetHandler.java index 2f60210f8cb..eba5641d9e2 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ListTelnetHandler.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ListTelnetHandler.java @@ -19,7 +19,7 @@ import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.utils.ReflectUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; import com.alibaba.dubbo.rpc.Exporter; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/LogTelnetHandler.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/LogTelnetHandler.java index e2c37df37be..85442b87493 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/LogTelnetHandler.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/LogTelnetHandler.java @@ -1,41 +1,41 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/* + * Copyright 1999-2011 Alibaba Group. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ package com.alibaba.dubbo.rpc.protocol.dubbo.telnet; -import java.io.File; -import java.io.FileInputStream; -import java.nio.ByteBuffer; -import java.nio.channels.FileChannel; -import java.text.SimpleDateFormat; -import java.util.Date; - -import com.alibaba.dubbo.common.extension.Activate; -import com.alibaba.dubbo.common.logger.Level; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.telnet.TelnetHandler; -import com.alibaba.dubbo.remoting.telnet.support.Help; +import java.io.File; +import java.io.FileInputStream; +import java.nio.ByteBuffer; +import java.nio.channels.FileChannel; +import java.text.SimpleDateFormat; +import java.util.Date; + +import com.alibaba.dubbo.common.extension.Activate; +import com.alibaba.dubbo.common.logger.Level; +import com.alibaba.dubbo.common.logger.LoggerFactory; +import com.alibaba.dubbo.common.utils.StringUtils; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.telnet.TelnetHandler; +import com.alibaba.dubbo.remoting.telnet.support.Help; /** * LogTelnetHandler * @author chao.liuc * - */ + */ @Activate @Help(parameter = "level", summary = "Change log level or show log ", detail = "Change log level or show log") public class LogTelnetHandler implements TelnetHandler { diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/PortTelnetHandler.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/PortTelnetHandler.java index 62add429e3e..d7282da369f 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/PortTelnetHandler.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/PortTelnetHandler.java @@ -19,7 +19,7 @@ import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.ExchangeServer; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; diff --git a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/TraceTelnetHandler.java b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/TraceTelnetHandler.java index 615438d3b86..aa0312c35b4 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/TraceTelnetHandler.java +++ b/dubbo-rpc/dubbo-rpc-default/src/main/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/TraceTelnetHandler.java @@ -19,7 +19,7 @@ import com.alibaba.dubbo.common.extension.Activate; import com.alibaba.dubbo.common.utils.StringUtils; -import com.alibaba.dubbo.remoting.Channel; +import com.alibaba.dubbo.remoting.transport.Channel; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.remoting.telnet.support.Help; import com.alibaba.dubbo.rpc.Exporter; diff --git a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/FutureFilterTest.java b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/FutureFilterTest.java deleted file mode 100644 index 15d06a0f893..00000000000 --- a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/FutureFilterTest.java +++ /dev/null @@ -1,83 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.rpc.protocol.dubbo; - -import static org.junit.Assert.assertEquals; - -import org.easymock.EasyMock; -import org.junit.BeforeClass; -import org.junit.Test; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.Filter; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.RpcResult; -import com.alibaba.dubbo.rpc.protocol.dubbo.filter.FutureFilter; -import com.alibaba.dubbo.rpc.protocol.dubbo.support.DemoService; - -/** - * EventFilterTest.java - * - * @author tony.chenl - * TODO 暂时依赖callback集成测试,后续补充 - */ -public class FutureFilterTest { - Filter eventFilter = new FutureFilter(); - private static RpcInvocation invocation; - - @BeforeClass - public static void setUp() { - invocation = new RpcInvocation(); - invocation.setMethodName("echo"); - invocation.setParameterTypes(new Class[] { Enum.class }); - invocation.setArguments(new Object[] { "hello" }); - } - - @Test - public void testSyncCallback() { - @SuppressWarnings("unchecked") - Invoker invoker = EasyMock.createMock(Invoker.class); - EasyMock.expect(invoker.isAvailable()).andReturn(true).anyTimes(); - EasyMock.expect(invoker.getInterface()).andReturn(DemoService.class).anyTimes(); - RpcResult result = new RpcResult(); - result.setValue("High"); - EasyMock.expect(invoker.invoke(invocation)).andReturn(result).anyTimes(); - URL url = URL.valueOf("test://test:11/test?group=dubbo&version=1.1"); - EasyMock.expect(invoker.getUrl()).andReturn(url).anyTimes(); - EasyMock.replay(invoker); - Result filterResult = eventFilter.invoke(invoker, invocation); - assertEquals("High", filterResult.getValue()); - } - - @Test(expected = RuntimeException.class) - public void testSyncCallbackHasException() throws RpcException, Throwable { - @SuppressWarnings("unchecked") - Invoker invoker = EasyMock.createMock(Invoker.class); - EasyMock.expect(invoker.isAvailable()).andReturn(true).anyTimes(); - EasyMock.expect(invoker.getInterface()).andReturn(DemoService.class).anyTimes(); - RpcResult result = new RpcResult(); - result.setException(new RuntimeException()); - EasyMock.expect(invoker.invoke(invocation)).andReturn(result).anyTimes(); - URL url = URL.valueOf("test://test:11/test?group=dubbo&version=1.1&"+Constants.ON_THROW_METHOD_KEY+"=echo"); - EasyMock.expect(invoker.getUrl()).andReturn(url).anyTimes(); - EasyMock.replay(invoker); - eventFilter.invoke(invoker, invocation).recreate(); - } -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/ImplicitCallBackTest.java b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/ImplicitCallBackTest.java deleted file mode 100644 index 936e58261d9..00000000000 --- a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/ImplicitCallBackTest.java +++ /dev/null @@ -1,373 +0,0 @@ -/* - * Copyright 1999-2011 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.rpc.protocol.dubbo; - - -import java.io.Serializable; -import java.lang.reflect.Method; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.concurrent.Future; -import java.util.concurrent.TimeUnit; - -import junit.framework.Assert; - -import org.junit.After; -import org.junit.Before; -import org.junit.Test; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.rpc.Exporter; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.StaticContext; -import com.alibaba.dubbo.rpc.protocol.dubbo.support.ProtocolUtils; - -public class ImplicitCallBackTest{ - - protected Exporter exporter = null; - protected Invoker reference = null; - - protected URL serviceURL = null ; - protected URL consumerUrl = null ; - Method onReturnMethod; - Method onThrowMethod ; - Method onInvokeMethod ; - - @Before - public void setUp() throws SecurityException, NoSuchMethodException{ - onReturnMethod = Nofify.class.getMethod("onreturn", new Class[]{Person.class, Integer.class}); - onThrowMethod = Nofify.class.getMethod("onthrow", new Class[]{Throwable.class, Integer.class}); - onInvokeMethod = Nofify.class.getMethod("oninvoke", new Class[]{Integer.class}); - } - - @After - public void tearDown(){ - ProtocolUtils.closeAll(); - } - - public void initOrResetService(){ - destroyService(); - exportService(); - referService(); - } - public void destroyService(){ - demoProxy = null ; - try { - if (exporter!=null) exporter.unexport(); - if (reference!=null) reference.destroy(); - }catch (Exception e) { - } - } - - void referService() { - demoProxy = (IDemoService)ProtocolUtils.refer(IDemoService.class, consumerUrl); - } - - public void exportService(){ - exporter = ProtocolUtils.export(new NormalDemoService(), IDemoService.class, serviceURL); - } - public void exportExService(){ - exporter = ProtocolUtils.export(new ExceptionDemoExService(), IDemoService.class, serviceURL); - } - - public void initOrResetUrl(boolean isAsync) throws Exception { - int port = NetUtils.getAvailablePort() ; - consumerUrl = serviceURL = URL.valueOf("dubbo://127.0.0.1:"+port+"/"+IDemoService.class.getName()+"?group=test&async="+isAsync+"&timeout=100000&reference.filter=future" ); - StaticContext.getSystemContext().clear(); - } - - public void initImplicitCallBackURL_onlyOnthrow() throws Exception { - StaticContext.getSystemContext().put(StaticContext.getKey(consumerUrl, "get", Constants.ON_THROW_METHOD_KEY),onThrowMethod); - StaticContext.getSystemContext().put(StaticContext.getKey(consumerUrl, "get", Constants.ON_THROW_INSTANCE_KEY),notify); - } - public void initImplicitCallBackURL_onlyOnreturn() throws Exception { - StaticContext.getSystemContext().put(StaticContext.getKey(consumerUrl, "get", Constants.ON_RETURN_METHOD_KEY),onReturnMethod); - StaticContext.getSystemContext().put(StaticContext.getKey(consumerUrl, "get", Constants.ON_RETURN_INSTANCE_KEY),notify); - - } - public void initImplicitCallBackURL_onlyOninvoke() throws Exception { - StaticContext.getSystemContext().put(StaticContext.getKey(consumerUrl, "get", Constants.ON_INVOKE_METHOD_KEY),onInvokeMethod); - StaticContext.getSystemContext().put(StaticContext.getKey(consumerUrl, "get", Constants.ON_INVOKE_INSTANCE_KEY),notify); - } - - //================================================================================================ - - NofifyImpl notify = new NofifyImpl(); - - interface Nofify { - public void onreturn(Person msg, Integer id); - public void onthrow(Throwable ex, Integer id); - public void oninvoke(Integer id); - } - class NofifyImpl implements Nofify{ - public List inv = new ArrayList (); - public Map ret = new HashMap (); - public Map errors = new HashMap (); - public boolean exd = false; - public void onreturn(Person msg, Integer id) { - System.out.println("onNotify:"+msg); - ret.put(id, msg); - } - public void onthrow(Throwable ex, Integer id) { - errors.put(id, ex); -// ex.printStackTrace(); - } - public void oninvoke(Integer id) { - inv.add(id); - } - } - - interface IDemoService{ - public Person get(int id); - } - - class NormalDemoService implements IDemoService { - public Person get(int id){ - return new Person(id, "charles", 4); - } - } - class ExceptionDemoExService implements IDemoService { - public Person get(int id){ - throw new RuntimeException("request persion id is :"+ id); - } - } - - public static class Person implements Serializable{ - private static final long serialVersionUID = 1L; - public Person(int id, String name, int age) { - this.id = id; - this.name = name; - this.age = age; - } - private int id; - private String name ; - private int age; - public String getName() { - return name; - } - public void setName(String name) { - this.name = name; - } - public int getAge() { - return age; - } - public void setAge(int age) { - this.age = age; - } - public int getId() { - return id; - } - public void setId(int id) { - this.id = id; - } - @Override - public String toString() { - return "Person [name=" + name + ", age=" + age + "]"; - } - } - //================================================================================================ - IDemoService demoProxy = null; - - @Test - public void test_CloseCallback() throws Exception { - initOrResetUrl(false); - initOrResetService() ; - Person ret = demoProxy.get(1); - Assert.assertEquals(1, ret.getId()); - destroyService(); - } - - @Test - public void test_Sync_Onreturn() throws Exception { - initOrResetUrl(false); - initImplicitCallBackURL_onlyOnreturn(); - initOrResetService() ; - int requestId = 2; - Person ret = demoProxy.get(requestId); - Assert.assertEquals(requestId, ret.getId()); - for (int i = 0; i < 10; i++) { - if (! notify.ret.containsKey(requestId)){ - Thread.sleep(200); - }else { - break; - } - } - Assert.assertEquals(requestId, notify.ret.get(requestId).getId()); - destroyService(); - } - - @Test - public void test_Ex_OnReturn() throws Exception { - initOrResetUrl(true); - initImplicitCallBackURL_onlyOnreturn(); - - destroyService(); - exportExService(); - referService(); - - int requestId = 2; - Person ret = demoProxy.get(requestId); - Assert.assertEquals(null, ret); - for (int i = 0; i < 10; i++) { - if (! notify.errors.containsKey(requestId)){ - Thread.sleep(200); - }else { - break; - } - } - Assert.assertTrue(! notify.errors.containsKey(requestId)); - destroyService(); - } - - @Test - public void test_Ex_OnInvoke() throws Exception { - initOrResetUrl(true); - initImplicitCallBackURL_onlyOninvoke(); - - destroyService(); - exportExService(); - referService(); - - int requestId = 2; - Person ret = demoProxy.get(requestId); - Assert.assertEquals(null, ret); - for (int i = 0; i < 10; i++) { - if (! notify.inv.contains(requestId)){ - Thread.sleep(200); - }else { - break; - } - } - Assert.assertTrue(notify.inv.contains(requestId)); - destroyService(); - } - - @Test - public void test_Ex_Onthrow() throws Exception { - initOrResetUrl(true); - initImplicitCallBackURL_onlyOnthrow(); - - destroyService(); - exportExService(); - referService(); - - int requestId = 2; - Person ret = demoProxy.get(requestId); - Assert.assertEquals(null, ret); - for (int i = 0; i < 10; i++) { - if (! notify.errors.containsKey(requestId)){ - Thread.sleep(200); - }else { - break; - } - } - Assert.assertTrue(notify.errors.containsKey(requestId)); - Assert.assertTrue(notify.errors.get(requestId) instanceof Throwable); - destroyService(); - } - - @Test - public void test_Sync_NoFuture() throws Exception { - initOrResetUrl(false); - initImplicitCallBackURL_onlyOnreturn(); - destroyService(); - exportService(); - referService(); - - int requestId = 2; - Person ret = demoProxy.get(requestId); - Assert.assertEquals(requestId, ret.getId()); - Future pFuture = RpcContext.getContext().getFuture(); - Assert.assertEquals(null, pFuture); - destroyService(); - } - - @Test - public void test_Async_Future() throws Exception { - initOrResetUrl(true); - destroyService(); - exportService(); - referService(); - - int requestId = 2; - Person ret = demoProxy.get(requestId); - Assert.assertEquals(null, ret); - Future pFuture = RpcContext.getContext().getFuture(); - ret = pFuture.get(1000, TimeUnit.MICROSECONDS); - Assert.assertEquals(requestId, ret.getId()); - destroyService(); - } - - @Test - public void test_Async_Future_Multi() throws Exception { - initOrResetUrl(true); - destroyService(); - exportService(); - referService(); - - int requestId1 = 1; - Person ret = demoProxy.get(requestId1); - Assert.assertEquals(null, ret); - Future p1Future = RpcContext.getContext().getFuture(); - - int requestId2 = 1; - Person ret2 = demoProxy.get(requestId2); - Assert.assertEquals(null, ret2); - Future p2Future = RpcContext.getContext().getFuture(); - - ret = p1Future.get(1000, TimeUnit.MICROSECONDS); - ret2 = p2Future.get(1000, TimeUnit.MICROSECONDS); - Assert.assertEquals(requestId1, ret.getId()); - Assert.assertEquals(requestId2, ret.getId()); - destroyService(); - } - - @Test(expected = RuntimeException.class) - public void test_Async_Future_Ex() throws Exception { - try{ - initOrResetUrl(true); - destroyService(); - exportExService(); - referService(); - - int requestId = 2; - Person ret = demoProxy.get(requestId); - Assert.assertEquals(null, ret); - Future pFuture = RpcContext.getContext().getFuture(); - ret = pFuture.get(1000, TimeUnit.MICROSECONDS); - Assert.assertEquals(requestId, ret.getId()); - }finally{ - destroyService(); - } - } - - @Test(expected = RuntimeException.class) - public void test_Normal_Ex() throws Exception { - initOrResetUrl(false); - destroyService(); - exportExService(); - referService(); - - int requestId = 2; - Person ret = demoProxy.get(requestId); - Assert.assertEquals(requestId, ret.getId()); - } -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ChangeTelnetHandlerTest.java b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ChangeTelnetHandlerTest.java index 1e0a0abc871..7ac896f070f 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ChangeTelnetHandlerTest.java +++ b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ChangeTelnetHandlerTest.java @@ -24,8 +24,8 @@ import org.junit.Test; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.rpc.Invoker; import com.alibaba.dubbo.rpc.protocol.dubbo.DubboProtocol; diff --git a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CurrentTelnetHandlerTest.java b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CurrentTelnetHandlerTest.java index 531db0086da..97c053d3fa2 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CurrentTelnetHandlerTest.java +++ b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/CurrentTelnetHandlerTest.java @@ -21,8 +21,8 @@ import org.junit.After; import org.junit.Test; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; /** diff --git a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/InvokerTelnetHandlerTest.java b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/InvokerTelnetHandlerTest.java index e26d1ae9166..834e59d3fc2 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/InvokerTelnetHandlerTest.java +++ b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/InvokerTelnetHandlerTest.java @@ -24,8 +24,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.utils.NetUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.rpc.Invocation; import com.alibaba.dubbo.rpc.Invoker; diff --git a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ListTelnetHandlerTest.java b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ListTelnetHandlerTest.java index 0904894a78a..1f76595e5a7 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ListTelnetHandlerTest.java +++ b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/ListTelnetHandlerTest.java @@ -27,8 +27,8 @@ import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.utils.NetUtils; import com.alibaba.dubbo.common.utils.ReflectUtils; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; import com.alibaba.dubbo.rpc.Invocation; import com.alibaba.dubbo.rpc.Invoker; diff --git a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/LogTelnetHandlerTest.java b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/LogTelnetHandlerTest.java index 5822c728dfe..4b7b7df1526 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/LogTelnetHandlerTest.java +++ b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/LogTelnetHandlerTest.java @@ -20,8 +20,8 @@ import org.easymock.EasyMock; import org.junit.Test; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; /** diff --git a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/PortTelnetHandlerTest.java b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/PortTelnetHandlerTest.java index c9eeaf81d60..9cc52735982 100644 --- a/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/PortTelnetHandlerTest.java +++ b/dubbo-rpc/dubbo-rpc-default/src/test/java/com/alibaba/dubbo/rpc/protocol/dubbo/telnet/PortTelnetHandlerTest.java @@ -19,15 +19,12 @@ import static org.junit.Assert.assertTrue; import org.easymock.EasyMock; -import org.easymock.IAnswer; import org.junit.After; import org.junit.Before; import org.junit.Test; import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeClient; import com.alibaba.dubbo.remoting.exchange.Exchangers; import com.alibaba.dubbo.remoting.telnet.TelnetHandler; diff --git a/dubbo-rpc/dubbo-rpc-hessian/pom.xml b/dubbo-rpc/dubbo-rpc-hessian/pom.xml index bf5e50cb4c6..13e77c3e30f 100644 --- a/dubbo-rpc/dubbo-rpc-hessian/pom.xml +++ b/dubbo-rpc/dubbo-rpc-hessian/pom.xml @@ -14,40 +14,49 @@ - limitations under the License. --> - 4.0.0 - - com.alibaba - dubbo-rpc - 2.8.4 - - dubbo-rpc-hessian - jar - ${project.artifactId} - The hessian rpc module of dubbo project - - true - - - - com.alibaba - dubbo-rpc-api - ${project.parent.version} - - - com.alibaba - dubbo-remoting-http - ${project.parent.version} - - - com.caucho - hessian - - - org.apache.httpcomponents - httpclient - provided - true - - + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> + 4.0.0 + + com.alibaba + dubbo-rpc + 3.0.1 + + dubbo-rpc-hessian + jar + ${project.artifactId} + The hessian rpc module of dubbo project + + true + + + + com.alibaba + dubbo-rpc-api + ${project.parent.version} + + + com.alibaba + dubbo-remoting-http + ${project.parent.version} + + + com.caucho + hessian + + + org.apache.httpcomponents + httpclient + provided + true + + + com.squareup.okhttp3 + okhttp + + + com.alibaba + dubbo-tracker-api + ${project.parent.version} + + \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/AbstractHessianConnection.java b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/AbstractHessianConnection.java new file mode 100644 index 00000000000..e2c2515b295 --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/AbstractHessianConnection.java @@ -0,0 +1,33 @@ +package com.alibaba.dubbo.rpc.protocol.hessian; + +import com.caucho.hessian.client.HessianConnection; + +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.OutputStream; + +/** + * @author Xs + */ +public abstract class AbstractHessianConnection implements HessianConnection { + + protected final ByteArrayOutputStream output; + + AbstractHessianConnection() { + this.output = new ByteArrayOutputStream(); + } + + @Override + public OutputStream getOutputStream() throws IOException { + return output; + } + + + @Override + public void destroy() throws IOException { + } + + @Override + public void close() throws IOException { + } +} diff --git a/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/HessianProtocol.java b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/HessianProtocol.java index 6a9f7c75c3f..b089cf8e8d4 100644 --- a/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/HessianProtocol.java +++ b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/HessianProtocol.java @@ -13,17 +13,7 @@ * See the License for the specific language governing permissions and * limitations under the License. */ -package com.alibaba.dubbo.rpc.protocol.hessian; - -import java.io.IOException; -import java.net.SocketTimeoutException; -import java.util.ArrayList; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; - -import javax.servlet.ServletException; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; +package com.alibaba.dubbo.rpc.protocol.hessian; import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; @@ -33,44 +23,59 @@ import com.alibaba.dubbo.rpc.RpcContext; import com.alibaba.dubbo.rpc.RpcException; import com.alibaba.dubbo.rpc.protocol.AbstractProxyProtocol; +import com.alibaba.dubbo.tracker.http.HttpRequestResponseInterceptorBuilder; import com.caucho.hessian.HessianException; import com.caucho.hessian.client.HessianConnectionException; import com.caucho.hessian.client.HessianProxyFactory; import com.caucho.hessian.io.HessianMethodSerializationException; import com.caucho.hessian.server.HessianSkeleton; - -/** - * http rpc support. - * - * @author qianlei - */ -public class HessianProtocol extends AbstractProxyProtocol { - - private final Map serverMap = new ConcurrentHashMap(); + +import javax.servlet.ServletException; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.net.SocketTimeoutException; +import java.util.ArrayList; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; + +/** + * http rpc support. + * + * @author qianlei + */ +public class HessianProtocol extends AbstractProxyProtocol { + + private final Map serverMap = new ConcurrentHashMap(); private final Map skeletonMap = new ConcurrentHashMap(); - + private HttpBinder httpBinder; - + + private HttpRequestResponseInterceptorBuilder httpRequestResponseInterceptorBuilder; + public HessianProtocol() { super(HessianException.class); - } + } public void setHttpBinder(HttpBinder httpBinder) { this.httpBinder = httpBinder; } - - public int getDefaultPort() { - return 80; + + public void setHttpRequestResponseInterceptorBuilder(HttpRequestResponseInterceptorBuilder httpRequestResponseInterceptorBuilder) { + this.httpRequestResponseInterceptorBuilder = httpRequestResponseInterceptorBuilder; + } + + public int getDefaultPort() { + return 80; } private class HessianHandler implements HttpHandler { - public void handle(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { String uri = request.getRequestURI(); HessianSkeleton skeleton = skeletonMap.get(uri); - if (! request.getMethod().equalsIgnoreCase("POST")) { + if (!request.getMethod().equalsIgnoreCase("POST")) { response.setStatus(500); } else { RpcContext.getContext().setRemoteAddress(request.getRemoteAddr(), request.getRemotePort()); @@ -81,40 +86,41 @@ public void handle(HttpServletRequest request, HttpServletResponse response) } } } - - } - - protected Runnable doExport(T impl, Class type, URL url) throws RpcException { - String addr = url.getIp() + ":" + url.getPort(); - HttpServer server = serverMap.get(addr); - if (server == null) { - server = httpBinder.bind(url, new HessianHandler()); - serverMap.put(addr, server); + } + + protected Runnable doExport(T impl, Class type, URL url) throws RpcException { + String addr = url.getIp() + ":" + url.getPort(); + HttpServer server = serverMap.get(addr); + if (server == null) { + server = httpBinder.bind(url, new HessianHandler()); + serverMap.put(addr, server); } final String path = url.getAbsolutePath(); HessianSkeleton skeleton = new HessianSkeleton(impl, type); - skeletonMap.put(path, skeleton); - return new Runnable() { + skeletonMap.put(path, skeleton); + return new Runnable() { public void run() { - skeletonMap.remove(path); - } - }; - } + skeletonMap.remove(path); + } + }; + } @SuppressWarnings("unchecked") protected T doRefer(Class serviceType, URL url) throws RpcException { HessianProxyFactory hessianProxyFactory = new HessianProxyFactory(); String client = url.getParameter(Constants.CLIENT_KEY, Constants.DEFAULT_HTTP_CLIENT); - if ("httpclient".equals(client)) { + if ("httpclient".equalsIgnoreCase(client)) { hessianProxyFactory.setConnectionFactory(new HttpClientConnectionFactory()); - } else if (client != null && client.length() > 0 && ! Constants.DEFAULT_HTTP_CLIENT.equals(client)) { + } else if ("okHttpClient".equalsIgnoreCase(client)) { + hessianProxyFactory.setConnectionFactory(new OkHttpConnectionFactory(url, httpRequestResponseInterceptorBuilder)); + } else if (client != null && client.length() > 0 && !Constants.DEFAULT_HTTP_CLIENT.equals(client)) { throw new IllegalStateException("Unsupported http protocol client=\"" + client + "\"!"); } int timeout = url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT); hessianProxyFactory.setConnectTimeout(timeout); - hessianProxyFactory.setReadTimeout(timeout); - return (T) hessianProxyFactory.create(serviceType, url.setProtocol("http").toJavaURL(), Thread.currentThread().getContextClassLoader()); - } + hessianProxyFactory.setReadTimeout(timeout); + return (T) hessianProxyFactory.create(serviceType, url.setProtocol("http").toJavaURL(), Thread.currentThread().getContextClassLoader()); + } protected int getErrorCode(Throwable e) { if (e instanceof HessianConnectionException) { @@ -130,22 +136,22 @@ protected int getErrorCode(Throwable e) { } return super.getErrorCode(e); } - - public void destroy() { - super.destroy(); - for (String key : new ArrayList(serverMap.keySet())) { - HttpServer server = serverMap.remove(key); - if (server != null) { - try { - if (logger.isInfoEnabled()) { - logger.info("Close hessian server " + server.getUrl()); - } - server.close(); - } catch (Throwable t) { - logger.warn(t.getMessage(), t); - } - } - } - } - + + public void destroy() { + super.destroy(); + for (String key : new ArrayList(serverMap.keySet())) { + HttpServer server = serverMap.remove(key); + if (server != null) { + try { + if (logger.isInfoEnabled()) { + logger.info("Close hessian server " + server.getUrl()); + } + server.close(); + } catch (Throwable t) { + logger.warn(t.getMessage(), t); + } + } + } + } + } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/HttpClientConnection.java b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/HttpClientConnection.java index e8cf9f19ad0..9bb315aa6d6 100644 --- a/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/HttpClientConnection.java +++ b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/HttpClientConnection.java @@ -15,38 +15,32 @@ */ package com.alibaba.dubbo.rpc.protocol.hessian; -import java.io.ByteArrayOutputStream; -import java.io.IOException; -import java.io.InputStream; -import java.io.OutputStream; -import java.net.URL; - import org.apache.http.HttpResponse; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpPost; import org.apache.http.entity.ByteArrayEntity; import org.apache.http.message.BasicHeader; -import com.caucho.hessian.client.HessianConnection; +import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStream; +import java.net.URL; /** * HttpClientConnection - * + * * @author william.liangf */ -public class HttpClientConnection implements HessianConnection { - +public class HttpClientConnection extends AbstractHessianConnection { + private final HttpClient httpClient; - private final ByteArrayOutputStream output; - private final HttpPost request; - + private volatile HttpResponse response; public HttpClientConnection(HttpClient httpClient, URL url) { this.httpClient = httpClient; - this.output = new ByteArrayOutputStream(); this.request = new HttpPost(url.toString()); } @@ -68,7 +62,7 @@ public int getStatusCode() { } public String getStatusMessage() { - return response == null || response.getStatusLine() == null ? null : response.getStatusLine().getReasonPhrase(); + return response == null || response.getStatusLine() == null ? null : response.getStatusLine().getReasonPhrase(); } public InputStream getInputStream() throws IOException { @@ -77,12 +71,6 @@ public InputStream getInputStream() throws IOException { public void close() throws IOException { HttpPost request = this.request; - if (request != null) { - request.abort(); - } + request.abort(); } - - public void destroy() throws IOException { - } - } \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/OkHttpConnection.java b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/OkHttpConnection.java new file mode 100644 index 00000000000..0247a848291 --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/OkHttpConnection.java @@ -0,0 +1,53 @@ +package com.alibaba.dubbo.rpc.protocol.hessian; + +import okhttp3.OkHttpClient; +import okhttp3.Request; +import okhttp3.RequestBody; +import okhttp3.Response; + +import java.io.IOException; +import java.io.InputStream; +import java.net.URL; + +/** + * @author Xs + */ +public class OkHttpConnection extends AbstractHessianConnection { + + private final OkHttpClient okHttpClient; + + private final Request.Builder builder; + + private volatile Response response; + + public OkHttpConnection(OkHttpClient client, URL url) { + this.okHttpClient = client; + this.builder = new Request.Builder().url(url); + } + + @Override + public void addHeader(String key, String value) { + builder.addHeader(key, value); + } + + @Override + public void sendRequest() throws IOException { + Request request = builder.post(RequestBody.create(null, output.toByteArray())).build(); + this.response = okHttpClient.newCall(request).execute(); + } + + @Override + public int getStatusCode() { + return response == null ? 0 : response.code(); + } + + @Override + public String getStatusMessage() { + return response == null ? null : response.message(); + } + + @Override + public InputStream getInputStream() throws IOException { + return response == null || response.body() == null ? null : response.body().byteStream(); + } +} diff --git a/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/OkHttpConnectionFactory.java b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/OkHttpConnectionFactory.java new file mode 100644 index 00000000000..db56e12e85d --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-hessian/src/main/java/com/alibaba/dubbo/rpc/protocol/hessian/OkHttpConnectionFactory.java @@ -0,0 +1,44 @@ +package com.alibaba.dubbo.rpc.protocol.hessian; + +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.tracker.http.HttpRequestResponseInterceptorBuilder; +import com.caucho.hessian.client.HessianConnection; +import com.caucho.hessian.client.HessianConnectionFactory; +import com.caucho.hessian.client.HessianProxyFactory; +import okhttp3.Interceptor; +import okhttp3.OkHttpClient; + +import java.io.IOException; +import java.net.URL; +import java.util.concurrent.TimeUnit; + +/** + * @author Xs + */ +public class OkHttpConnectionFactory implements HessianConnectionFactory { + + private final OkHttpClient client; + + public OkHttpConnectionFactory(com.alibaba.dubbo.common.URL url, HttpRequestResponseInterceptorBuilder requestResponseInterceptorBuilder) { + OkHttpClient.Builder builder = new OkHttpClient.Builder(); + builder.readTimeout(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT), TimeUnit.MILLISECONDS); + builder.connectTimeout(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT), TimeUnit.MILLISECONDS); + if (requestResponseInterceptorBuilder != null) { + Interceptor interceptor = requestResponseInterceptorBuilder.build(url); + if (interceptor != null) { + builder.addInterceptor(interceptor); + } + } + client = builder.build(); + } + + @Override + public void setHessianProxyFactory(HessianProxyFactory hessianProxyFactory) { + // NOP + } + + @Override + public HessianConnection open(URL url) throws IOException { + return new OkHttpConnection(client, url); + } +} diff --git a/dubbo-rpc/dubbo-rpc-hessian/src/test/java/com/alibaba/dubbo/rpc/protocol/hessian/HessianProtocolTest.java b/dubbo-rpc/dubbo-rpc-hessian/src/test/java/com/alibaba/dubbo/rpc/protocol/hessian/HessianProtocolTest.java index 5939f036474..9ef84c0efe9 100644 --- a/dubbo-rpc/dubbo-rpc-hessian/src/test/java/com/alibaba/dubbo/rpc/protocol/hessian/HessianProtocolTest.java +++ b/dubbo-rpc/dubbo-rpc-hessian/src/test/java/com/alibaba/dubbo/rpc/protocol/hessian/HessianProtocolTest.java @@ -69,7 +69,24 @@ public void testHttpClient() { invoker.destroy(); exporter.unexport(); } - + + @Test + public void testOkHttpClient() { + HessianServiceImpl server = new HessianServiceImpl(); + Assert.assertFalse(server.isCalled()); + ProxyFactory proxyFactory = ExtensionLoader.getExtensionLoader(ProxyFactory.class).getAdaptiveExtension(); + Protocol protocol = ExtensionLoader.getExtensionLoader(Protocol.class).getAdaptiveExtension(); + URL url = URL.valueOf("hessian://127.0.0.1:5342/" + HessianService.class.getName() + "?version=1.0.0&client=okHttpClient"); + Exporter exporter = protocol.export(proxyFactory.getInvoker(server, HessianService.class, url)); + Invoker invoker = protocol.refer(HessianService.class, url); + HessianService client = proxyFactory.getProxy(invoker); + String result = client.sayHello("haha"); + Assert.assertTrue(server.isCalled()); + Assert.assertEquals("Hello, haha", result); + invoker.destroy(); + exporter.unexport(); + } + @Test public void testTimeOut() { HessianServiceImpl server = new HessianServiceImpl(); diff --git a/dubbo-rpc/dubbo-rpc-http/pom.xml b/dubbo-rpc/dubbo-rpc-http/pom.xml index a2ad7c134f3..dad5b540eff 100644 --- a/dubbo-rpc/dubbo-rpc-http/pom.xml +++ b/dubbo-rpc/dubbo-rpc-http/pom.xml @@ -14,38 +14,47 @@ - limitations under the License. --> - 4.0.0 - - com.alibaba - dubbo-rpc - 2.8.4 - - dubbo-rpc-http - jar - ${project.artifactId} - The http rpc module of dubbo project - - true - - - - com.alibaba - dubbo-rpc-api - ${project.parent.version} - - - com.alibaba - dubbo-remoting-http - ${project.parent.version} - - - org.springframework - spring-context - - - org.springframework - spring-web - - + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> + 4.0.0 + + com.alibaba + dubbo-rpc + 3.0.1 + + dubbo-rpc-http + jar + ${project.artifactId} + The http rpc module of dubbo project + + true + + + + com.alibaba + dubbo-rpc-api + ${project.parent.version} + + + com.alibaba + dubbo-remoting-http + ${project.parent.version} + + + org.springframework + spring-context + + + org.springframework + spring-web + + + com.squareup.okhttp3 + okhttp + + + com.alibaba + dubbo-tracker-api + ${project.parent.version} + + \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-http/src/main/java/com/alibaba/dubbo/rpc/protocol/http/HttpProtocol.java b/dubbo-rpc/dubbo-rpc-http/src/main/java/com/alibaba/dubbo/rpc/protocol/http/HttpProtocol.java index 84bc398a3fb..debb8342eb5 100644 --- a/dubbo-rpc/dubbo-rpc-http/src/main/java/com/alibaba/dubbo/rpc/protocol/http/HttpProtocol.java +++ b/dubbo-rpc/dubbo-rpc-http/src/main/java/com/alibaba/dubbo/rpc/protocol/http/HttpProtocol.java @@ -15,46 +15,48 @@ */ package com.alibaba.dubbo.rpc.protocol.http; -import java.io.IOException; -import java.net.HttpURLConnection; -import java.net.SocketTimeoutException; -import java.util.Map; -import java.util.concurrent.ConcurrentHashMap; - -import javax.servlet.ServletException; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; - -import org.springframework.remoting.RemoteAccessException; -import org.springframework.remoting.httpinvoker.CommonsHttpInvokerRequestExecutor; -import org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean; -import org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter; -import org.springframework.remoting.httpinvoker.SimpleHttpInvokerRequestExecutor; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.utils.StringUtils; import com.alibaba.dubbo.remoting.http.HttpBinder; import com.alibaba.dubbo.remoting.http.HttpHandler; import com.alibaba.dubbo.remoting.http.HttpServer; import com.alibaba.dubbo.rpc.RpcContext; import com.alibaba.dubbo.rpc.RpcException; import com.alibaba.dubbo.rpc.protocol.AbstractProxyProtocol; +import com.alibaba.dubbo.tracker.http.HttpRequestResponseInterceptorBuilder; +import org.springframework.remoting.RemoteAccessException; +import org.springframework.remoting.httpinvoker.CommonsHttpInvokerRequestExecutor; +import org.springframework.remoting.httpinvoker.HttpInvokerProxyFactoryBean; +import org.springframework.remoting.httpinvoker.HttpInvokerServiceExporter; +import org.springframework.remoting.httpinvoker.SimpleHttpInvokerRequestExecutor; + +import javax.servlet.ServletException; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.net.HttpURLConnection; +import java.net.SocketTimeoutException; +import java.util.Map; +import java.util.concurrent.ConcurrentHashMap; /** * HttpProtocol - * + * * @author william.liangf */ public class HttpProtocol extends AbstractProxyProtocol { - public static final int DEFAULT_PORT = 80; + public static final int DEFAULT_PORT = 80; private final Map serverMap = new ConcurrentHashMap(); private final Map skeletonMap = new ConcurrentHashMap(); private HttpBinder httpBinder; - + + private HttpRequestResponseInterceptorBuilder httpRequestResponseInterceptorBuilder; + public HttpProtocol() { super(RemoteAccessException.class); } @@ -63,17 +65,20 @@ public void setHttpBinder(HttpBinder httpBinder) { this.httpBinder = httpBinder; } + public void setHttpRequestResponseInterceptorBuilder(HttpRequestResponseInterceptorBuilder httpRequestResponseInterceptorBuilder) { + this.httpRequestResponseInterceptorBuilder = httpRequestResponseInterceptorBuilder; + } + public int getDefaultPort() { return DEFAULT_PORT; } private class InternalHandler implements HttpHandler { - public void handle(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { String uri = request.getRequestURI(); HttpInvokerServiceExporter skeleton = skeletonMap.get(uri); - if (! request.getMethod().equalsIgnoreCase("POST")) { + if (!request.getMethod().equalsIgnoreCase("POST")) { response.setStatus(500); } else { RpcContext.getContext().setRemoteAddress(request.getRemoteAddr(), request.getRemotePort()); @@ -84,7 +89,6 @@ public void handle(HttpServletRequest request, HttpServletResponse response) } } } - } protected Runnable doExport(final T impl, Class type, URL url) throws RpcException { @@ -117,22 +121,24 @@ protected T doRefer(final Class serviceType, final URL url) throws RpcExc httpProxyFactoryBean.setServiceUrl(url.toIdentityString()); httpProxyFactoryBean.setServiceInterface(serviceType); String client = url.getParameter(Constants.CLIENT_KEY); - if (client == null || client.length() == 0 || "simple".equals(client)) { - SimpleHttpInvokerRequestExecutor httpInvokerRequestExecutor = new SimpleHttpInvokerRequestExecutor() { - protected void prepareConnection(HttpURLConnection con, - int contentLength) throws IOException { - super.prepareConnection(con, contentLength); - con.setReadTimeout(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT)); - con.setConnectTimeout(url.getParameter(Constants.CONNECT_TIMEOUT_KEY, Constants.DEFAULT_CONNECT_TIMEOUT)); - } - }; - httpProxyFactoryBean.setHttpInvokerRequestExecutor(httpInvokerRequestExecutor); + if (StringUtils.isEmpty(client) || "okHttpClient".equals(client)) { + httpProxyFactoryBean.setHttpInvokerRequestExecutor(new OkHttpInvokerRequestExecutor(url, httpRequestResponseInterceptorBuilder)); + } else if ("simple".equals(client)) { + SimpleHttpInvokerRequestExecutor httpInvokerRequestExecutor = new SimpleHttpInvokerRequestExecutor() { + protected void prepareConnection(HttpURLConnection con, + int contentLength) throws IOException { + super.prepareConnection(con, contentLength); + con.setReadTimeout(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT)); + con.setConnectTimeout(url.getParameter(Constants.CONNECT_TIMEOUT_KEY, Constants.DEFAULT_CONNECT_TIMEOUT)); + } + }; + httpProxyFactoryBean.setHttpInvokerRequestExecutor(httpInvokerRequestExecutor); } else if ("commons".equals(client)) { - CommonsHttpInvokerRequestExecutor httpInvokerRequestExecutor = new CommonsHttpInvokerRequestExecutor(); - httpInvokerRequestExecutor.setReadTimeout(url.getParameter(Constants.CONNECT_TIMEOUT_KEY, Constants.DEFAULT_CONNECT_TIMEOUT)); - httpProxyFactoryBean.setHttpInvokerRequestExecutor(httpInvokerRequestExecutor); - } else if (client != null && client.length() > 0) { - throw new IllegalStateException("Unsupported http protocol client " + client + ", only supported: simple, commons"); + CommonsHttpInvokerRequestExecutor httpInvokerRequestExecutor = new CommonsHttpInvokerRequestExecutor(); + httpInvokerRequestExecutor.setReadTimeout(url.getParameter(Constants.CONNECT_TIMEOUT_KEY, Constants.DEFAULT_CONNECT_TIMEOUT)); + httpProxyFactoryBean.setHttpInvokerRequestExecutor(httpInvokerRequestExecutor); + } else if (client.length() > 0) { + throw new IllegalStateException("Unsupported http protocol client " + client + ", only supported: simple, commons"); } httpProxyFactoryBean.afterPropertiesSet(); return (T) httpProxyFactoryBean.getObject(); diff --git a/dubbo-rpc/dubbo-rpc-http/src/main/java/com/alibaba/dubbo/rpc/protocol/http/OkHttpInvokerRequestExecutor.java b/dubbo-rpc/dubbo-rpc-http/src/main/java/com/alibaba/dubbo/rpc/protocol/http/OkHttpInvokerRequestExecutor.java new file mode 100644 index 00000000000..13ca3b53469 --- /dev/null +++ b/dubbo-rpc/dubbo-rpc-http/src/main/java/com/alibaba/dubbo/rpc/protocol/http/OkHttpInvokerRequestExecutor.java @@ -0,0 +1,53 @@ +package com.alibaba.dubbo.rpc.protocol.http; + +import com.alibaba.dubbo.common.Constants; +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.tracker.http.HttpRequestResponseInterceptorBuilder; +import okhttp3.*; +import org.springframework.context.i18n.LocaleContext; +import org.springframework.context.i18n.LocaleContextHolder; +import org.springframework.remoting.httpinvoker.AbstractHttpInvokerRequestExecutor; +import org.springframework.remoting.httpinvoker.HttpInvokerClientConfiguration; +import org.springframework.remoting.support.RemoteInvocationResult; +import org.springframework.util.StringUtils; + +import java.io.ByteArrayOutputStream; +import java.util.concurrent.TimeUnit; + +public class OkHttpInvokerRequestExecutor extends AbstractHttpInvokerRequestExecutor { + + private final OkHttpClient client; + + public OkHttpInvokerRequestExecutor(URL url, HttpRequestResponseInterceptorBuilder requestResponseInterceptorBuilder) { + OkHttpClient.Builder builder = new OkHttpClient.Builder(); + builder.readTimeout(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT), TimeUnit.MILLISECONDS); + builder.connectTimeout(url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT), TimeUnit.MILLISECONDS); + if (requestResponseInterceptorBuilder != null) { + Interceptor interceptor = requestResponseInterceptorBuilder.build(url); + if (interceptor != null) { + builder.addInterceptor(interceptor); + } + } + client = builder.build(); + } + + @Override + protected RemoteInvocationResult doExecuteRequest(HttpInvokerClientConfiguration config, ByteArrayOutputStream baos) throws Exception { + Request request = createPostRequest(config, baos); + Response response = client.newCall(request).execute(); + return readRemoteInvocationResult(response.body().byteStream(), config.getCodebaseUrl()); + } + + private Request createPostRequest(HttpInvokerClientConfiguration config, ByteArrayOutputStream baos) { + Request.Builder builder = new Request.Builder().url(config.getServiceUrl()); + LocaleContext locale = LocaleContextHolder.getLocaleContext(); + if (locale != null) { + builder.addHeader(HTTP_HEADER_ACCEPT_LANGUAGE, StringUtils.toLanguageTag(locale.getLocale())); + } + if (isAcceptGzipEncoding()) { + builder.addHeader(HTTP_HEADER_ACCEPT_ENCODING, ENCODING_GZIP); + } + RequestBody requestBody = RequestBody.create(MediaType.parse(getContentType()), baos.toByteArray()); + return builder.post(requestBody).build(); + } +} diff --git a/dubbo-rpc/dubbo-rpc-injvm/pom.xml b/dubbo-rpc/dubbo-rpc-injvm/pom.xml index dcdda8d5345..74a42ce5996 100644 --- a/dubbo-rpc/dubbo-rpc-injvm/pom.xml +++ b/dubbo-rpc/dubbo-rpc-injvm/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-rpc - 2.8.4 + 3.0.1 dubbo-rpc-injvm jar diff --git a/dubbo-rpc/dubbo-rpc-memcached/pom.xml b/dubbo-rpc/dubbo-rpc-memcached/pom.xml index 6a2af14c3c6..0c3158df347 100644 --- a/dubbo-rpc/dubbo-rpc-memcached/pom.xml +++ b/dubbo-rpc/dubbo-rpc-memcached/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-rpc - 2.8.4 + 3.0.1 dubbo-rpc-memcached jar diff --git a/dubbo-rpc/dubbo-rpc-memcached/src/main/java/com/alibaba/dubbo/rpc/protocol/memcached/MemcachedProtocol.java b/dubbo-rpc/dubbo-rpc-memcached/src/main/java/com/alibaba/dubbo/rpc/protocol/memcached/MemcachedProtocol.java index 9439129dafc..d996d0892d0 100644 --- a/dubbo-rpc/dubbo-rpc-memcached/src/main/java/com/alibaba/dubbo/rpc/protocol/memcached/MemcachedProtocol.java +++ b/dubbo-rpc/dubbo-rpc-memcached/src/main/java/com/alibaba/dubbo/rpc/protocol/memcached/MemcachedProtocol.java @@ -92,9 +92,9 @@ protected Result doInvoke(Invocation invocation) throws Throwable { } } catch (Throwable t) { RpcException re = new RpcException("Failed to invoke memecached service method. interface: " + type.getName() + ", method: " + invocation.getMethodName() + ", url: " + url + ", cause: " + t.getMessage(), t); - if (t instanceof TimeoutException || t instanceof SocketTimeoutException) { + if (t instanceof TimeoutException) { re.setCode(RpcException.TIMEOUT_EXCEPTION); - } else if (t instanceof MemcachedException || t instanceof IOException) { + } else if (t instanceof MemcachedException) { re.setCode(RpcException.NETWORK_EXCEPTION); } throw re; diff --git a/dubbo-rpc/dubbo-rpc-redis/pom.xml b/dubbo-rpc/dubbo-rpc-redis/pom.xml index 9e39b9fa31f..b72b6c864cf 100644 --- a/dubbo-rpc/dubbo-rpc-redis/pom.xml +++ b/dubbo-rpc/dubbo-rpc-redis/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-rpc - 2.8.4 + 3.0.1 dubbo-rpc-redis jar diff --git a/dubbo-rpc/dubbo-rpc-redis/src/main/java/com/alibaba/dubbo/rpc/protocol/redis/RedisProtocol.java b/dubbo-rpc/dubbo-rpc-redis/src/main/java/com/alibaba/dubbo/rpc/protocol/redis/RedisProtocol.java index bcb9e2f25a0..924af3189c5 100644 --- a/dubbo-rpc/dubbo-rpc-redis/src/main/java/com/alibaba/dubbo/rpc/protocol/redis/RedisProtocol.java +++ b/dubbo-rpc/dubbo-rpc-redis/src/main/java/com/alibaba/dubbo/rpc/protocol/redis/RedisProtocol.java @@ -15,39 +15,32 @@ */ package com.alibaba.dubbo.rpc.protocol.redis; -import java.io.ByteArrayInputStream; -import java.io.ByteArrayOutputStream; -import java.io.IOException; -import java.net.SocketTimeoutException; -import java.util.Map; -import java.util.concurrent.TimeoutException; - -import org.apache.commons.pool.impl.GenericObjectPool; - -import redis.clients.jedis.Jedis; -import redis.clients.jedis.JedisPool; -import redis.clients.jedis.exceptions.JedisConnectionException; -import redis.clients.jedis.exceptions.JedisDataException; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.extension.ExtensionLoader; import com.alibaba.dubbo.common.serialize.ObjectInput; import com.alibaba.dubbo.common.serialize.ObjectOutput; import com.alibaba.dubbo.common.serialize.Serialization; -import com.alibaba.dubbo.rpc.Exporter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcResult; +import com.alibaba.dubbo.rpc.*; import com.alibaba.dubbo.rpc.protocol.AbstractInvoker; import com.alibaba.dubbo.rpc.protocol.AbstractProtocol; +import org.apache.commons.pool.impl.GenericObjectPool; +import redis.clients.jedis.Jedis; +import redis.clients.jedis.JedisPool; +import redis.clients.jedis.exceptions.JedisConnectionException; +import redis.clients.jedis.exceptions.JedisDataException; + +import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.net.SocketTimeoutException; +import java.util.Map; +import java.util.concurrent.TimeoutException; /** * RedisProtocol - * + * * @author william.liangf */ public class RedisProtocol extends AbstractProtocol { @@ -61,7 +54,7 @@ public int getDefaultPort() { public Exporter export(final Invoker invoker) throws RpcException { throw new UnsupportedOperationException("Unsupported export redis service. url: " + invoker.getUrl()); } - + private Serialization getSerialization(URL url) { return ExtensionLoader.getExtensionLoader(Serialization.class).getExtension(url.getParameter(Constants.SERIALIZATION_KEY, "java")); } @@ -86,8 +79,8 @@ public Invoker refer(final Class type, final URL url) throws RpcExcept config.timeBetweenEvictionRunsMillis = url.getParameter("time.between.eviction.runs.millis", 0); if (url.getParameter("min.evictable.idle.time.millis", 0) > 0) config.minEvictableIdleTimeMillis = url.getParameter("min.evictable.idle.time.millis", 0); - final JedisPool jedisPool = new JedisPool(config, url.getHost(), url.getPort(DEFAULT_PORT), - url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT)); + final JedisPool jedisPool = new JedisPool(config, url.getHost(), url.getPort(DEFAULT_PORT), + url.getParameter(Constants.TIMEOUT_KEY, Constants.DEFAULT_TIMEOUT)); final int expiry = url.getParameter("expiry", 0); final String get = url.getParameter("get", "get"); final String set = url.getParameter("set", Map.class.equals(type) ? "put" : "set"); @@ -130,10 +123,9 @@ protected Result doInvoke(Invocation invocation) throws Throwable { } else { throw new UnsupportedOperationException("Unsupported method " + invocation.getMethodName() + " in redis service."); } - } - catch (Throwable t) { + } catch (Throwable t) { RpcException re = new RpcException("Failed to invoke memecached service method. interface: " + type.getName() + ", method: " + invocation.getMethodName() + ", url: " + url + ", cause: " + t.getMessage(), t); - if (t instanceof TimeoutException || t instanceof SocketTimeoutException) { + if (t instanceof SocketTimeoutException) { re.setCode(RpcException.TIMEOUT_EXCEPTION); } else if (t instanceof JedisConnectionException || t instanceof IOException) { re.setCode(RpcException.NETWORK_EXCEPTION); @@ -141,13 +133,11 @@ protected Result doInvoke(Invocation invocation) throws Throwable { re.setCode(RpcException.SERIALIZATION_EXCEPTION); } throw re; - } - finally { - if(resource != null) { + } finally { + if (resource != null) { try { jedisPool.returnResource(resource); - } - catch (Throwable t) { + } catch (Throwable t) { logger.warn("returnResource error: " + t.getMessage(), t); } } diff --git a/dubbo-rpc/dubbo-rpc-rest/pom.xml b/dubbo-rpc/dubbo-rpc-rest/pom.xml index 11edf84ca91..1611c3672dc 100644 --- a/dubbo-rpc/dubbo-rpc-rest/pom.xml +++ b/dubbo-rpc/dubbo-rpc-rest/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-rpc - 2.8.4 + 3.0.1 dubbo-rpc-rest jar diff --git a/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/DubboHttpServer.java b/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/DubboHttpServer.java index 92d259907db..26826922bfd 100644 --- a/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/DubboHttpServer.java +++ b/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/DubboHttpServer.java @@ -1,12 +1,12 @@ /** * Copyright 1999-2014 dangdang.com. - * + *

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -43,7 +43,6 @@ public class DubboHttpServer extends BaseRestServer { private final ResteasyDeployment deployment = new ResteasyDeployment(); private HttpBinder httpBinder; private HttpServer httpServer; -// private boolean isExternalServer; public DubboHttpServer(HttpBinder httpBinder) { this.httpBinder = httpBinder; diff --git a/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/RestProtocol.java b/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/RestProtocol.java index 918f28f91a1..df0d3ed25d1 100644 --- a/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/RestProtocol.java +++ b/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/RestProtocol.java @@ -1,12 +1,12 @@ /** * Copyright 1999-2014 dangdang.com. - * + *

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -22,8 +22,8 @@ import com.alibaba.dubbo.remoting.http.servlet.BootstrapListener; import com.alibaba.dubbo.remoting.http.servlet.ServletManager; import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.protocol.AbstractProxyProtocol; import com.alibaba.dubbo.rpc.ServiceClassHolder; +import com.alibaba.dubbo.rpc.protocol.AbstractProxyProtocol; import org.apache.http.HeaderElement; import org.apache.http.HeaderElementIterator; import org.apache.http.HttpResponse; diff --git a/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/RestServerFactory.java b/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/RestServerFactory.java index 0b7c9b38732..03f8634c62f 100644 --- a/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/RestServerFactory.java +++ b/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/RestServerFactory.java @@ -1,12 +1,12 @@ /** * Copyright 1999-2014 dangdang.com. - * + *

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -35,8 +35,6 @@ public RestServer createServer(String name) { // TODO move names to Constants if ("servlet".equalsIgnoreCase(name) || "jetty".equalsIgnoreCase(name) || "tomcat".equalsIgnoreCase(name)) { return new DubboHttpServer(httpBinder); -// } else if ("tjws".equalsIgnoreCase(name)) { -// return new TjwsServer(); } else if ("netty".equalsIgnoreCase(name)) { return new NettyServer(); } else if ("sunhttp".equalsIgnoreCase(name)) { diff --git a/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/support/LoggingFilter.java b/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/support/LoggingFilter.java index 92b1b440531..800c67c9c0b 100644 --- a/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/support/LoggingFilter.java +++ b/dubbo-rpc/dubbo-rpc-rest/src/main/java/com/alibaba/dubbo/rpc/protocol/rest/support/LoggingFilter.java @@ -1,12 +1,12 @@ /** * Copyright 1999-2014 dangdang.com. - * + *

* Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * + *

+ * http://www.apache.org/licenses/LICENSE-2.0 + *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -20,7 +20,6 @@ import org.apache.commons.io.IOUtils; import javax.annotation.Priority; -import javax.ws.rs.Priorities; import javax.ws.rs.WebApplicationException; import javax.ws.rs.client.ClientRequestContext; import javax.ws.rs.client.ClientRequestFilter; diff --git a/dubbo-rpc/dubbo-rpc-rmi/pom.xml b/dubbo-rpc/dubbo-rpc-rmi/pom.xml index 84b76b9a059..ae890999834 100644 --- a/dubbo-rpc/dubbo-rpc-rmi/pom.xml +++ b/dubbo-rpc/dubbo-rpc-rmi/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-rpc - 2.8.4 + 3.0.1 dubbo-rpc-rmi jar diff --git a/dubbo-rpc/dubbo-rpc-rmi/src/main/java/com/alibaba/dubbo/rpc/protocol/rmi/RmiProtocol.java b/dubbo-rpc/dubbo-rpc-rmi/src/main/java/com/alibaba/dubbo/rpc/protocol/rmi/RmiProtocol.java index 79c8a834172..ef4aa893aa8 100644 --- a/dubbo-rpc/dubbo-rpc-rmi/src/main/java/com/alibaba/dubbo/rpc/protocol/rmi/RmiProtocol.java +++ b/dubbo-rpc/dubbo-rpc-rmi/src/main/java/com/alibaba/dubbo/rpc/protocol/rmi/RmiProtocol.java @@ -15,26 +15,25 @@ */ package com.alibaba.dubbo.rpc.protocol.rmi; -import java.io.IOException; -import java.net.SocketTimeoutException; -import java.rmi.RemoteException; - +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.rpc.RpcException; +import com.alibaba.dubbo.rpc.protocol.AbstractProxyProtocol; import org.springframework.remoting.RemoteAccessException; import org.springframework.remoting.rmi.RmiProxyFactoryBean; import org.springframework.remoting.rmi.RmiServiceExporter; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.protocol.AbstractProxyProtocol; +import java.io.IOException; +import java.net.SocketTimeoutException; +import java.rmi.RemoteException; /** * RmiProtocol. - * + * * @author qian.lei */ public class RmiProtocol extends AbstractProxyProtocol { - public static final int DEFAULT_PORT = 1099; + public static final int DEFAULT_PORT = 1099; public RmiProtocol() { super(RemoteAccessException.class, RemoteException.class); diff --git a/dubbo-rpc/dubbo-rpc-thrift/pom.xml b/dubbo-rpc/dubbo-rpc-thrift/pom.xml deleted file mode 100644 index 4b5d5d075ec..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/pom.xml +++ /dev/null @@ -1,79 +0,0 @@ - - - 4.0.0 - - com.alibaba - dubbo-rpc - 2.8.4 - - dubbo-rpc-thrift - jar - ${project.artifactId} - The thrift rpc module of dubbo project - - true - - - - com.alibaba - dubbo-rpc-api - ${project.parent.version} - - - com.alibaba - dubbo-rpc-default - ${project.parent.version} - - - com.alibaba - dubbo-remoting-api - ${project.parent.version} - - - com.alibaba - dubbo-remoting-netty - ${project.parent.version} - - - org.apache.thrift - libthrift - - - org.apache.httpcomponents - httpcore - - - - - org.apache.httpcomponents - httpclient - - - com.alibaba - dubbo-config-spring - ${project.parent.version} - test - - - com.alibaba - dubbo-registry-multicast - ${project.parent.version} - test - - - \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ClassNameGenerator.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ClassNameGenerator.java deleted file mode 100644 index 36e5eda2821..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ClassNameGenerator.java +++ /dev/null @@ -1,28 +0,0 @@ -/** - * File Created at 2012-02-02 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.common.extension.SPI; - -/** - * @author kimi - */ -@SPI( DubboClassNameGenerator.NAME ) -public interface ClassNameGenerator { - - public String generateArgsClassName( String serviceName, String methodName ); - - public String generateResultClassName( String serviceName, String methodName ); - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/DubboClassNameGenerator.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/DubboClassNameGenerator.java deleted file mode 100644 index ab9d70832bc..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/DubboClassNameGenerator.java +++ /dev/null @@ -1,31 +0,0 @@ -/** - * File Created at 2012-02-02 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -/** - * @author kimi - */ -public class DubboClassNameGenerator implements ClassNameGenerator { - - public static final String NAME = "dubbo"; - - public String generateArgsClassName( String serviceName, String methodName ) { - return ThriftUtils.generateMethodArgsClassName( serviceName, methodName ); - } - - public String generateResultClassName( String serviceName, String methodName ) { - return ThriftUtils.generateMethodResultClassName( serviceName, methodName ); - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftClassNameGenerator.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftClassNameGenerator.java deleted file mode 100644 index 5c34c222f25..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftClassNameGenerator.java +++ /dev/null @@ -1,31 +0,0 @@ -/** - * File Created at 2012-02-02 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -/** - * @author kimi - */ -public class ThriftClassNameGenerator implements ClassNameGenerator { - - public static final String NAME = "thrift"; - - public String generateArgsClassName( String serviceName, String methodName ) { - return ThriftUtils.generateMethodArgsClassNameThrift( serviceName, methodName ); - } - - public String generateResultClassName( String serviceName, String methodName ) { - return ThriftUtils.generateMethodResultClassNameThrift( serviceName, methodName ); - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftCodec.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftCodec.java deleted file mode 100644 index 6c4dee9837f..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftCodec.java +++ /dev/null @@ -1,719 +0,0 @@ -/** - * File Created at 2011-12-05 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - - -import java.io.IOException; -import java.lang.reflect.Field; -import java.lang.reflect.InvocationTargetException; -import java.lang.reflect.Method; -import java.util.ArrayList; -import java.util.List; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; -import java.util.concurrent.atomic.AtomicInteger; - -import org.apache.commons.lang.StringUtils; -import org.apache.thrift.TApplicationException; -import org.apache.thrift.TBase; -import org.apache.thrift.TException; -import org.apache.thrift.TFieldIdEnum; -import org.apache.thrift.protocol.TBinaryProtocol; -import org.apache.thrift.protocol.TMessage; -import org.apache.thrift.protocol.TMessageType; -import org.apache.thrift.protocol.TProtocol; -import org.apache.thrift.transport.TFramedTransport; -import org.apache.thrift.transport.TIOStreamTransport; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.common.utils.ClassHelper; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.Codec2; -import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; -import com.alibaba.dubbo.remoting.buffer.ChannelBufferInputStream; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.RpcResult; -import com.alibaba.dubbo.rpc.protocol.thrift.io.RandomAccessByteArrayOutputStream; - -/** - * Thrift framed protocol codec. - * - *

- * |<-                                  message header                                  ->|<- message body ->|
- * +----------------+----------------------+------------------+---------------------------+------------------+
- * | magic (2 bytes)|message size (4 bytes)|head size(2 bytes)| version (1 byte) | header |   message body   |
- * +----------------+----------------------+------------------+---------------------------+------------------+
- * |<-                                               message size                                          ->|
- * 
- * - *

- * header fields in version 1 - *

    - *
  1. string - service name
  2. - *
  3. long - dubbo request id
  4. - *
- *

- * - * @author gang.lvg - */ -public class ThriftCodec implements Codec2 { - - private static final AtomicInteger THRIFT_SEQ_ID = new AtomicInteger( 0 ); - - private static final ConcurrentMap> cachedClass = - new ConcurrentHashMap>(); - - static final ConcurrentMap cachedRequest = - new ConcurrentHashMap(); - - public static final int MESSAGE_LENGTH_INDEX = 2; - - public static final int MESSAGE_HEADER_LENGTH_INDEX = 6; - - public static final int MESSAGE_SHORTEST_LENGTH = 10; - - public static final String NAME = "thrift"; - - public static final String PARAMETER_CLASS_NAME_GENERATOR = "class.name.generator"; - - public static final byte VERSION = (byte)1; - - public static final short MAGIC = (short) 0xdabc; - - public void encode( Channel channel, ChannelBuffer buffer, Object message ) - throws IOException { - - if ( message instanceof Request ) { - encodeRequest( channel, buffer, ( Request ) message ); - } - else if ( message instanceof Response ) { - encodeResponse( channel, buffer, ( Response ) message ); - } else { - throw new UnsupportedOperationException( - new StringBuilder( 32 ) - .append( "Thrift codec only support encode " ) - .append( Request.class.getName() ) - .append( " and " ) - .append( Response.class.getName() ) - .toString() ); - } - - } - - public Object decode( Channel channel, ChannelBuffer buffer ) throws IOException { - - int available = buffer.readableBytes(); - - if ( available < MESSAGE_SHORTEST_LENGTH ) { - - return DecodeResult.NEED_MORE_INPUT; - - } else { - - TIOStreamTransport transport = new TIOStreamTransport( new ChannelBufferInputStream(buffer)); - - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - short magic; - int messageLength; - - try{ -// protocol.readI32(); // skip the first message length - byte[] bytes = new byte[4]; - transport.read( bytes, 0, 4 ); - magic = protocol.readI16(); - messageLength = protocol.readI32(); - - } catch ( TException e ) { - throw new IOException( e.getMessage(), e ); - } - - if ( MAGIC != magic ) { - throw new IOException( - new StringBuilder( 32 ) - .append( "Unknown magic code " ) - .append( magic ) - .toString() ); - } - - if ( available < messageLength ) { return DecodeResult.NEED_MORE_INPUT; } - - return decode( protocol ); - - } - - } - - private Object decode( TProtocol protocol ) - throws IOException { - - // version - String serviceName; - long id; - - TMessage message; - - try { - protocol.readI16(); - protocol.readByte(); - serviceName = protocol.readString(); - id = protocol.readI64(); - message = protocol.readMessageBegin(); - } catch ( TException e ) { - throw new IOException( e.getMessage(), e ); - } - - if ( message.type == TMessageType.CALL ) { - - RpcInvocation result = new RpcInvocation(); - result.setAttachment(Constants.INTERFACE_KEY, serviceName ); - result.setMethodName( message.name ); - - String argsClassName = ExtensionLoader.getExtensionLoader(ClassNameGenerator.class) - .getExtension(ThriftClassNameGenerator.NAME).generateArgsClassName( serviceName, message.name ); - - if ( StringUtils.isEmpty( argsClassName ) ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, - "The specified interface name incorrect." ); - } - - Class clazz = cachedClass.get( argsClassName ); - - if ( clazz == null ) { - try { - - clazz = ClassHelper.forNameWithThreadContextClassLoader( argsClassName ); - - cachedClass.putIfAbsent( argsClassName, clazz ); - - } catch ( ClassNotFoundException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - } - - TBase args; - - try { - args = ( TBase ) clazz.newInstance(); - } catch ( InstantiationException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( IllegalAccessException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - try{ - args.read( protocol ); - protocol.readMessageEnd(); - } catch ( TException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - List parameters = new ArrayList(); - List> parameterTypes =new ArrayList>(); - int index = 1; - - while ( true ) { - - TFieldIdEnum fieldIdEnum = args.fieldForId( index++ ); - - if ( fieldIdEnum == null ) { break; } - - String fieldName = fieldIdEnum.getFieldName(); - - String getMethodName = ThriftUtils.generateGetMethodName( fieldName ); - - Method getMethod; - - try { - getMethod = clazz.getMethod( getMethodName ); - } catch ( NoSuchMethodException e ) { - throw new RpcException( - RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - parameterTypes.add( getMethod.getReturnType() ); - try { - parameters.add( getMethod.invoke( args ) ); - } catch ( IllegalAccessException e ) { - throw new RpcException( - RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( InvocationTargetException e ) { - throw new RpcException( - RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - } - - result.setArguments( parameters.toArray() ); - result.setParameterTypes(parameterTypes.toArray(new Class[parameterTypes.size()])); - - Request request = new Request( id ); - request.setData( result ); - - cachedRequest.putIfAbsent( id, - RequestData.create( message.seqid, serviceName, message.name ) ); - - return request; - - } else if ( message.type == TMessageType.EXCEPTION ) { - - TApplicationException exception; - - try { - exception = TApplicationException.read( protocol ); - protocol.readMessageEnd(); - } catch ( TException e ) { - throw new IOException( e.getMessage(), e ); - } - - RpcResult result = new RpcResult(); - - result.setException( new RpcException( exception.getMessage() ) ); - - Response response = new Response(); - - response.setResult( result ); - - response.setId( id ); - - return response; - - } else if ( message.type == TMessageType.REPLY ) { - - String resultClassName = ExtensionLoader.getExtensionLoader( ClassNameGenerator.class ) - .getExtension(ThriftClassNameGenerator.NAME).generateResultClassName( serviceName, message.name ); - - if ( StringUtils.isEmpty( resultClassName ) ) { - throw new IllegalArgumentException( - new StringBuilder( 32 ) - .append( "Could not infer service result class name from service name " ) - .append( serviceName ) - .append( ", the service name you specified may not generated by thrift idl compiler" ) - .toString() ); - } - - Class clazz = cachedClass.get( resultClassName ); - - if ( clazz == null ) { - - try { - - clazz = ClassHelper.forNameWithThreadContextClassLoader( resultClassName ); - - cachedClass.putIfAbsent( resultClassName, clazz ); - - } catch ( ClassNotFoundException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - } - - TBase result; - try { - result = ( TBase ) clazz.newInstance(); - } catch ( InstantiationException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( IllegalAccessException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - try { - result.read( protocol ); - protocol.readMessageEnd(); - } catch ( TException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - Object realResult = null; - - int index = 0; - - while ( true ) { - - TFieldIdEnum fieldIdEnum = result.fieldForId( index++ ); - - if ( fieldIdEnum == null ) { break ; } - - Field field; - - try { - field = clazz.getDeclaredField( fieldIdEnum.getFieldName() ); - field.setAccessible( true ); - } catch ( NoSuchFieldException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - try { - realResult = field.get( result ); - } catch ( IllegalAccessException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - if ( realResult != null ) { break ; } - - } - - Response response = new Response(); - - response.setId( id ); - - RpcResult rpcResult = new RpcResult(); - - if ( realResult instanceof Throwable ) { - rpcResult.setException( ( Throwable ) realResult ); - } else { - rpcResult.setValue(realResult); - } - - response.setResult( rpcResult ); - - return response; - - } else { - // Impossible - throw new IOException( ); - } - - } - - private void encodeRequest( Channel channel, ChannelBuffer buffer, Request request ) - throws IOException { - - RpcInvocation inv = ( RpcInvocation ) request.getData(); - - int seqId = nextSeqId(); - - String serviceName = inv.getAttachment(Constants.INTERFACE_KEY); - - if ( StringUtils.isEmpty( serviceName ) ) { - throw new IllegalArgumentException( - new StringBuilder( 32 ) - .append( "Could not find service name in attachment with key " ) - .append(Constants.INTERFACE_KEY) - .toString() ); - } - - TMessage message = new TMessage( - inv.getMethodName(), - TMessageType.CALL, - seqId ); - - String methodArgs = ExtensionLoader.getExtensionLoader( ClassNameGenerator.class ) - .getExtension(channel.getUrl().getParameter(ThriftConstants.CLASS_NAME_GENERATOR_KEY, ThriftClassNameGenerator.NAME)) - .generateArgsClassName(serviceName, inv.getMethodName()); - - if ( StringUtils.isEmpty( methodArgs ) ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, - new StringBuilder(32).append( - "Could not encode request, the specified interface may be incorrect." ).toString() ); - } - - Class clazz = cachedClass.get( methodArgs ); - - if ( clazz == null ) { - - try { - - clazz = ClassHelper.forNameWithThreadContextClassLoader( methodArgs ); - - cachedClass.putIfAbsent( methodArgs, clazz ); - - } catch ( ClassNotFoundException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - } - - TBase args; - - try { - args = (TBase) clazz.newInstance(); - } catch ( InstantiationException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( IllegalAccessException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - for( int i = 0; i < inv.getArguments().length; i++ ) { - - Object obj = inv.getArguments()[i]; - - if ( obj == null ) { continue; } - - TFieldIdEnum field = args.fieldForId( i + 1 ); - - String setMethodName = ThriftUtils.generateSetMethodName( field.getFieldName() ); - - Method method; - - try { - method = clazz.getMethod( setMethodName, inv.getParameterTypes()[i] ); - } catch ( NoSuchMethodException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - try { - method.invoke( args, obj ); - } catch ( IllegalAccessException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( InvocationTargetException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - } - - RandomAccessByteArrayOutputStream bos = new RandomAccessByteArrayOutputStream( 1024 ); - - TIOStreamTransport transport = new TIOStreamTransport( bos ); - - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - int headerLength, messageLength; - - byte[] bytes = new byte[4]; - try { - // magic - protocol.writeI16( MAGIC ); - // message length placeholder - protocol.writeI32( Integer.MAX_VALUE ); - // message header length placeholder - protocol.writeI16( Short.MAX_VALUE ); - // version - protocol.writeByte( VERSION ); - // service name - protocol.writeString( serviceName ); - // dubbo request id - protocol.writeI64( request.getId() ); - protocol.getTransport().flush(); - // header size - headerLength = bos.size(); - - // message body - protocol.writeMessageBegin( message ); - args.write( protocol ); - protocol.writeMessageEnd(); - protocol.getTransport().flush(); - int oldIndex = messageLength = bos.size(); - - // fill in message length and header length - try { - TFramedTransport.encodeFrameSize( messageLength, bytes ); - bos.setWriteIndex( MESSAGE_LENGTH_INDEX ); - protocol.writeI32( messageLength ); - bos.setWriteIndex( MESSAGE_HEADER_LENGTH_INDEX ); - protocol.writeI16( ( short )( 0xffff & headerLength ) ); - } finally { - bos.setWriteIndex( oldIndex ); - } - - } catch ( TException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - buffer.writeBytes(bytes); - buffer.writeBytes(bos.toByteArray()); - - } - - private void encodeResponse( Channel channel, ChannelBuffer buffer, Response response ) - throws IOException { - - RpcResult result = ( RpcResult ) response.getResult(); - - RequestData rd = cachedRequest.get( response.getId() ); - - String resultClassName = ExtensionLoader.getExtensionLoader( ClassNameGenerator.class ).getExtension( - channel.getUrl().getParameter(ThriftConstants.CLASS_NAME_GENERATOR_KEY, ThriftClassNameGenerator.NAME)) - .generateResultClassName(rd.serviceName, rd.methodName); - - if ( StringUtils.isEmpty( resultClassName ) ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, - new StringBuilder( 32 ).append( - "Could not encode response, the specified interface may be incorrect." ).toString() ); - } - - Class clazz = cachedClass.get( resultClassName ); - - if ( clazz == null ) { - - try { - clazz = ClassHelper.forNameWithThreadContextClassLoader(resultClassName); - cachedClass.putIfAbsent( resultClassName, clazz ); - } catch ( ClassNotFoundException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - } - - TBase resultObj; - - try { - resultObj = ( TBase ) clazz.newInstance(); - } catch ( InstantiationException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( IllegalAccessException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - TApplicationException applicationException = null; - TMessage message; - - if ( result.hasException() ) { - Throwable throwable = result.getException(); - int index = 1; - boolean found = false; - while ( true ) { - TFieldIdEnum fieldIdEnum = resultObj.fieldForId( index++ ); - if ( fieldIdEnum == null ) { break; } - String fieldName = fieldIdEnum.getFieldName(); - String getMethodName = ThriftUtils.generateGetMethodName( fieldName ); - String setMethodName = ThriftUtils.generateSetMethodName( fieldName ); - Method getMethod; - Method setMethod; - try { - getMethod = clazz.getMethod( getMethodName ); - if ( getMethod.getReturnType().equals( throwable.getClass() ) ) { - found = true; - setMethod = clazz.getMethod( setMethodName, throwable.getClass() ); - setMethod.invoke( resultObj, throwable ); - } - } catch ( NoSuchMethodException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( InvocationTargetException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( IllegalAccessException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - } - - if ( !found ) { - applicationException = new TApplicationException( throwable.getMessage() ); - } - - } else { - Object realResult = result.getResult(); - // result field id is 0 - String fieldName = resultObj.fieldForId( 0 ).getFieldName(); - String setMethodName = ThriftUtils.generateSetMethodName( fieldName ); - String getMethodName = ThriftUtils.generateGetMethodName( fieldName ); - Method getMethod; - Method setMethod; - try { - getMethod = clazz.getMethod( getMethodName ); - setMethod = clazz.getMethod( setMethodName, getMethod.getReturnType() ); - setMethod.invoke( resultObj, realResult ); - } catch ( NoSuchMethodException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( InvocationTargetException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } catch ( IllegalAccessException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - } - - if ( applicationException != null ) { - message = new TMessage( rd.methodName, TMessageType.EXCEPTION, rd.id ); - } else { - message = new TMessage( rd.methodName, TMessageType.REPLY, rd.id ); - } - - RandomAccessByteArrayOutputStream bos = new RandomAccessByteArrayOutputStream( 1024 ); - - TIOStreamTransport transport = new TIOStreamTransport( bos ); - - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - int messageLength; - int headerLength; - - byte[] bytes = new byte[4]; - try { - // magic - protocol.writeI16( MAGIC ); - // message length - protocol.writeI32( Integer.MAX_VALUE ); - // message header length - protocol.writeI16( Short.MAX_VALUE ); - // version - protocol.writeByte( VERSION ); - // service name - protocol.writeString( rd.serviceName ); - // id - protocol.writeI64( response.getId() ); - protocol.getTransport().flush(); - headerLength = bos.size(); - - // message - protocol.writeMessageBegin( message ); - switch ( message.type ) { - case TMessageType.EXCEPTION: - applicationException.write( protocol ); - break; - case TMessageType.REPLY: - resultObj.write( protocol ); - break; - } - protocol.writeMessageEnd(); - protocol.getTransport().flush(); - int oldIndex = messageLength = bos.size(); - - try{ - TFramedTransport.encodeFrameSize( messageLength, bytes ); - bos.setWriteIndex( MESSAGE_LENGTH_INDEX ); - protocol.writeI32( messageLength ); - bos.setWriteIndex( MESSAGE_HEADER_LENGTH_INDEX ); - protocol.writeI16( ( short ) ( 0xffff & headerLength ) ); - } finally { - bos.setWriteIndex( oldIndex ); - } - - } catch ( TException e ) { - throw new RpcException( RpcException.SERIALIZATION_EXCEPTION, e.getMessage(), e ); - } - - buffer.writeBytes(bytes); - buffer.writeBytes(bos.toByteArray()); - - } - - private static int nextSeqId() { - return THRIFT_SEQ_ID.incrementAndGet(); - } - - // just for test - static int getSeqId() { - return THRIFT_SEQ_ID.get(); - } - - static class RequestData { - int id; - String serviceName; - String methodName; - - static RequestData create( int id, String sn, String mn ) { - RequestData result = new RequestData(); - result.id = id; - result.serviceName = sn; - result.methodName = mn; - return result; - } - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftConstants.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftConstants.java deleted file mode 100644 index 7bf67ad04ae..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftConstants.java +++ /dev/null @@ -1,15 +0,0 @@ -package com.alibaba.dubbo.rpc.protocol.thrift; - -/** - * @author kimi - */ -public final class ThriftConstants { - - public static final String THRIFT_PROTOCOL_KEY = "thrift.protocol"; - public static final String BINARY_THRIFT_PROTOCOL = "binary"; - public static final String CLASS_NAME_GENERATOR_KEY = "class.name.generator"; - public static final String DEFAULT_PROTOCOL = BINARY_THRIFT_PROTOCOL; - - private ThriftConstants() {} - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftInvoker.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftInvoker.java deleted file mode 100644 index d893fcdb106..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftInvoker.java +++ /dev/null @@ -1,153 +0,0 @@ -/** - * File Created at 2011-12-06 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.utils.AtomicPositiveInteger; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.TimeoutException; -import com.alibaba.dubbo.remoting.exchange.ExchangeClient; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.protocol.AbstractInvoker; - -import java.util.Set; -import java.util.concurrent.locks.ReentrantLock; - - -/** - * @author gang.lvg - */ -public class ThriftInvoker extends AbstractInvoker { - - private final ExchangeClient[] clients; - - private final AtomicPositiveInteger index = new AtomicPositiveInteger(); - - private final ReentrantLock destroyLock = new ReentrantLock(); - - private final Set> invokers; - - public ThriftInvoker( Class service, URL url, ExchangeClient[] clients ) { - this(service, url, clients, null); - } - - public ThriftInvoker(Class type, URL url, ExchangeClient[] clients, Set> invokers) { - super(type, url, - new String[]{Constants.INTERFACE_KEY, Constants.GROUP_KEY, - Constants.TOKEN_KEY, Constants.TIMEOUT_KEY}); - this.clients = clients; - this.invokers = invokers; - } - - @Override - protected Result doInvoke( Invocation invocation ) throws Throwable { - - RpcInvocation inv = (RpcInvocation) invocation; - - final String methodName; - - methodName = invocation.getMethodName(); - - inv.setAttachment( Constants.PATH_KEY, getUrl().getPath() ); - - // for thrift codec - inv.setAttachment( ThriftCodec.PARAMETER_CLASS_NAME_GENERATOR, getUrl().getParameter( - ThriftCodec.PARAMETER_CLASS_NAME_GENERATOR, DubboClassNameGenerator.NAME ) ); - - ExchangeClient currentClient; - - if (clients.length == 1) { - currentClient = clients[0]; - } else { - currentClient = clients[index.getAndIncrement() % clients.length]; - } - - try { - int timeout = getUrl().getMethodParameter( - methodName, Constants.TIMEOUT_KEY,Constants.DEFAULT_TIMEOUT); - - RpcContext.getContext().setFuture(null); - - return (Result) currentClient.request(inv, timeout).get(); - - } catch (TimeoutException e) { - throw new RpcException(RpcException.TIMEOUT_EXCEPTION, e.getMessage(), e); - } catch (RemotingException e) { - throw new RpcException(RpcException.NETWORK_EXCEPTION, e.getMessage(), e); - } - - } - - @Override - public boolean isAvailable() { - - if (!super.isAvailable()) { - return false; - } - - for (ExchangeClient client : clients){ - if (client.isConnected() - && !client.hasAttribute(Constants.CHANNEL_ATTRIBUTE_READONLY_KEY)){ - //cannot write == not Available ? - return true ; - } - } - return false; - } - - public void destroy() { - //防止client被关闭多次.在connect per jvm的情况下,client.close方法会调用计数器-1,当计数器小于等于0的情况下,才真正关闭 - if (super.isDestroyed()){ - return ; - } else { - //dubbo check ,避免多次关闭 - destroyLock.lock(); - - try{ - - if (super.isDestroyed()){ - return ; - } - - super.destroy(); - - if(invokers != null) { - invokers.remove(this); - } - - for (ExchangeClient client : clients) { - - try { - client.close(); - } catch (Throwable t) { - logger.warn(t.getMessage(), t); - } - - } - - }finally { - destroyLock.unlock(); - } - - } - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftNativeCodec.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftNativeCodec.java deleted file mode 100644 index a02180e09f5..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftNativeCodec.java +++ /dev/null @@ -1,79 +0,0 @@ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import java.io.IOException; -import java.util.concurrent.atomic.AtomicInteger; - -import org.apache.thrift.TException; -import org.apache.thrift.protocol.TBinaryProtocol; -import org.apache.thrift.protocol.TMessage; -import org.apache.thrift.protocol.TMessageType; -import org.apache.thrift.protocol.TProtocol; -import org.apache.thrift.protocol.TStruct; -import org.apache.thrift.transport.TIOStreamTransport; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.Codec2; -import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; -import com.alibaba.dubbo.remoting.buffer.ChannelBufferOutputStream; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.rpc.Invocation; - -/** - * @author kimi - */ -public class ThriftNativeCodec implements Codec2 { - - private final AtomicInteger thriftSeq = new AtomicInteger(0); - - public void encode(Channel channel, ChannelBuffer buffer, Object message) - throws IOException { - if (message instanceof Request) { - encodeRequest(channel, buffer, (Request)message); - } else if (message instanceof Response) { - encodeResponse(channel, buffer, (Response)message); - } else { - throw new IOException("Unsupported message type " - + message.getClass().getName()); - } - } - - protected void encodeRequest(Channel channel, ChannelBuffer buffer, Request request) - throws IOException { - Invocation invocation = (Invocation) request.getData(); - TProtocol protocol = newProtocol(channel.getUrl(), buffer); - try { - protocol.writeMessageBegin(new TMessage( - invocation.getMethodName(), TMessageType.CALL, - thriftSeq.getAndIncrement())); - protocol.writeStructBegin(new TStruct(invocation.getMethodName() + "_args")); - for(int i = 0; i < invocation.getParameterTypes().length; i++) { - Class type = invocation.getParameterTypes()[i]; - - } - } catch (TException e) { - throw new IOException(e.getMessage(), e); - } - - } - - protected void encodeResponse(Channel channel, ChannelBuffer buffer, Response response) - throws IOException { - - } - - public Object decode(Channel channel, ChannelBuffer buffer) throws IOException { - return null; - } - - protected static TProtocol newProtocol(URL url, ChannelBuffer buffer) throws IOException { - String protocol = url.getParameter(ThriftConstants.THRIFT_PROTOCOL_KEY, - ThriftConstants.DEFAULT_PROTOCOL); - if (ThriftConstants.BINARY_THRIFT_PROTOCOL.equals(protocol)) { - return new TBinaryProtocol(new TIOStreamTransport(new ChannelBufferOutputStream(buffer))); - } - throw new IOException("Unsupported protocol type " + protocol); - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftProtocol.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftProtocol.java deleted file mode 100644 index e5ce6205c42..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftProtocol.java +++ /dev/null @@ -1,213 +0,0 @@ -/** - * File Created at 2011-12-06 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import java.util.ArrayList; -import java.util.Set; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; -import com.alibaba.dubbo.remoting.Transporter; -import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; -import com.alibaba.dubbo.remoting.exchange.ExchangeClient; -import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.ExchangeServer; -import com.alibaba.dubbo.remoting.exchange.Exchangers; -import com.alibaba.dubbo.remoting.exchange.support.ExchangeHandlerAdapter; -import com.alibaba.dubbo.rpc.Exporter; -import com.alibaba.dubbo.rpc.Invocation; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.RpcContext; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.protocol.AbstractProtocol; -import com.alibaba.dubbo.rpc.protocol.dubbo.DubboExporter; - -/** - * @author gang.lvg - */ -public class ThriftProtocol extends AbstractProtocol { - - public static final int DEFAULT_PORT = 40880; - - public static final String NAME = "thrift"; - - // ip:port -> ExchangeServer - private final ConcurrentMap serverMap = - new ConcurrentHashMap(); - - private ExchangeHandler handler = new ExchangeHandlerAdapter() { - - @Override - public Object reply( ExchangeChannel channel, Object msg ) throws RemotingException { - - if ( msg instanceof Invocation ) { - Invocation inv = ( Invocation ) msg; - String serviceName = inv.getAttachments().get(Constants.INTERFACE_KEY); - String serviceKey = serviceKey( channel.getLocalAddress().getPort(), - serviceName, null, null ); - DubboExporter exporter = (DubboExporter) exporterMap.get( serviceKey ); - if (exporter == null) { - throw new RemotingException(channel, - "Not found exported service: " - + serviceKey - + " in " - + exporterMap.keySet() - + ", may be version or group mismatch " - + ", channel: consumer: " - + channel.getRemoteAddress() - + " --> provider: " - + channel.getLocalAddress() - + ", message:"+ msg); - } - - RpcContext.getContext().setRemoteAddress(channel.getRemoteAddress()); - return exporter.getInvoker().invoke( inv ); - - } - - throw new RemotingException(channel, - "Unsupported request: " - + (msg.getClass().getName() + ": " + msg) - + ", channel: consumer: " - + channel.getRemoteAddress() - + " --> provider: " - + channel.getLocalAddress()); - } - - @Override - public void received( Channel channel, Object message ) throws RemotingException { - if ( message instanceof Invocation ) { - reply( ( ExchangeChannel ) channel, message ); - } else { - super.received( channel, message ); - } - } - - }; - - public int getDefaultPort() { - return DEFAULT_PORT; - } - - public Exporter export( Invoker invoker ) throws RpcException { - - // 只能使用 thrift codec - URL url = invoker.getUrl().addParameter(Constants.CODEC_KEY, ThriftCodec.NAME); - // find server. - String key = url.getAddress(); - //client 也可以暴露一个只有server可以调用的服务。 - boolean isServer = url.getParameter(Constants.IS_SERVER_KEY,true); - if (isServer && ! serverMap.containsKey(key)) { - serverMap.put(key, getServer(url)); - } - // export service. - key = serviceKey(url); - DubboExporter exporter = new DubboExporter(invoker, key, exporterMap); - exporterMap.put(key, exporter); - - return exporter; - } - - public void destroy() { - - super.destroy(); - - for (String key : new ArrayList(serverMap.keySet())) { - - ExchangeServer server = serverMap.remove(key); - - if (server != null) { - try { - if (logger.isInfoEnabled()) { - logger.info("Close dubbo server: " + server.getLocalAddress()); - } - server.close(getServerShutdownTimeout()); - } catch (Throwable t) { - logger.warn(t.getMessage(), t); - } - } // ~ end of if ( server != null ) - - } // ~ end of loop serverMap - - } // ~ end of method destroy - - public Invoker refer( Class type, URL url ) throws RpcException { - - ThriftInvoker invoker = new ThriftInvoker(type, url, getClients(url), invokers); - - invokers.add(invoker); - - return invoker; - - } - - private ExchangeClient[] getClients(URL url){ - - int connections = url.getParameter(Constants.CONNECTIONS_KEY, 1); - - ExchangeClient[] clients = new ExchangeClient[connections]; - - for (int i = 0; i < clients.length; i++) { - clients[i] = initClient(url); - } - return clients; - } - - private ExchangeClient initClient(URL url) { - - ExchangeClient client ; - - url = url.addParameter( Constants.CODEC_KEY, ThriftCodec.NAME ); - - try { - client = Exchangers.connect( url ); - } catch ( RemotingException e ) { - throw new RpcException( "Fail to create remoting client for service(" + url - + "): " + e.getMessage(), e ); - } - - return client; - - } - - private ExchangeServer getServer(URL url) { - //默认开启server关闭时发送readonly事件 - url = url.addParameterIfAbsent(Constants.CHANNEL_READONLYEVENT_SENT_KEY, Boolean.TRUE.toString()); - String str = url.getParameter(Constants.SERVER_KEY, Constants.DEFAULT_REMOTING_SERVER); - - if (str != null && str.length() > 0 && ! ExtensionLoader.getExtensionLoader(Transporter.class).hasExtension(str)) - throw new RpcException("Unsupported server type: " + str + ", url: " + url); - - ExchangeServer server; - try { - server = Exchangers.bind(url, handler); - } catch (RemotingException e) { - throw new RpcException("Fail to start server(url: " + url + ") " + e.getMessage(), e); - } - str = url.getParameter(Constants.CLIENT_KEY); - if (str != null && str.length() > 0) { - Set supportedTypes = ExtensionLoader.getExtensionLoader(Transporter.class).getSupportedExtensions(); - if (!supportedTypes.contains(str)) { - throw new RpcException("Unsupported client type: " + str); - } - } - return server; - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftType.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftType.java deleted file mode 100644 index f8a44e04794..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftType.java +++ /dev/null @@ -1,34 +0,0 @@ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import java.util.HashMap; -import java.util.Map; - -/** - * @author kimi - */ -public enum ThriftType { - - BOOL, BYTE, I16, I32, I64, DOUBLE, STRING; - - public static ThriftType get(Class key) { - if (key != null) { - return types.get(key); - } - throw new NullPointerException("key == null"); - } - - private static final Map, ThriftType> types = - new HashMap, ThriftType>(); - - private static void put(Class key, ThriftType value) { - types.put(key, value); - } - static { - put(boolean.class, BOOL); - put(Boolean.class, BOOL); - put(byte.class, BYTE); - put(Byte.class, BYTE); - put(short.class, I16); - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftUtils.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftUtils.java deleted file mode 100644 index 15f3f622ca0..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftUtils.java +++ /dev/null @@ -1,132 +0,0 @@ -/** - * File Created at 2011-12-05 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -/** - * @author gang.lvg - */ -public class ThriftUtils { - - /** - * Generate class name which represents service arguments. - * - * @param serviceName service name - * @param methodName method name - * @return method args class name or null - */ - public static String generateMethodArgsClassName( String serviceName, String methodName ) { - - int index = serviceName.lastIndexOf( "." ); - - if ( index > 0 ) { - - return new StringBuilder( 32 ) - .append( serviceName.substring( 0, index + 1 ) ) - .append( "$__" ) - .append( serviceName.substring( index + 1 ) ) - .append( "Stub$" ) - .append( methodName ) - .append( "_args" ) - .toString(); - - } else { - return new StringBuffer( 32 ) - .append( "$__" ) - .append( serviceName ) - .append( "Stub$" ) - .append( methodName ) - .append( "_args" ) - .toString(); - } - - } - - public static String generateMethodResultClassName( String serviceName, String method ) { - - int index = serviceName.lastIndexOf( "." ); - - if ( index > 0 ) { - - return new StringBuilder( 32 ) - .append( serviceName.substring( 0, index + 1 ) ) - .append( "$__" ) - .append( serviceName.substring( index + 1 ) ) - .append( "Stub$" ) - .append( method ) - .append( "_result" ) - .toString(); - - } else { - return new StringBuilder( 32 ) - .append( "$__" ) - .append( serviceName ) - .append( "Stub$" ) - .append( method ) - .append( "_result" ) - .toString(); - } - - } - - public static String generateSetMethodName( String fieldName ) { - - return new StringBuilder( 16 ) - .append( "set" ) - .append( Character.toUpperCase( fieldName.charAt( 0 ) ) ) - .append( fieldName.substring( 1 ) ) - .toString(); - - } - - public static String generateGetMethodName( String fieldName ) { - return new StringBuffer( 16 ) - .append( "get" ) - .append( Character.toUpperCase( fieldName.charAt( 0 ) ) ) - .append( fieldName.substring( 1 ) ) - .toString(); - } - - public static String generateMethodArgsClassNameThrift( String serviceName, String methodName ) { - - int index = serviceName.indexOf( "$" ); - - if ( index > 0 ) { - return new StringBuilder( 32 ) - .append( serviceName.substring( 0, index + 1 ) ) - .append( methodName ) - .append( "_args" ) - .toString(); - } - - return null; - - } - - public static String generateMethodResultClassNameThrift( String serviceName, String methodName ) { - - int index = serviceName.indexOf( "$" ); - - if ( index > 0 ) { - return new StringBuilder( 32 ) - .append( serviceName.substring( 0, index + 1 ) ) - .append( methodName ) - .append( "_result" ) - .toString(); - } - - return null; - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ext/MultiServiceProcessor.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ext/MultiServiceProcessor.java deleted file mode 100644 index c4ef07b8b03..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/ext/MultiServiceProcessor.java +++ /dev/null @@ -1,122 +0,0 @@ -/** - * File Created at 2011-12-26 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift.ext; - -import com.alibaba.dubbo.common.logger.Logger; -import com.alibaba.dubbo.common.logger.LoggerFactory; -import com.alibaba.dubbo.rpc.protocol.thrift.ThriftCodec; -import org.apache.thrift.TException; -import org.apache.thrift.TProcessor; -import org.apache.thrift.protocol.TBinaryProtocol; -import org.apache.thrift.protocol.TProtocol; -import org.apache.thrift.protocol.TProtocolFactory; -import org.apache.thrift.transport.TIOStreamTransport; - -import java.io.ByteArrayOutputStream; -import java.util.concurrent.ConcurrentHashMap; -import java.util.concurrent.ConcurrentMap; - -/** - * @author kimi - */ -public class MultiServiceProcessor implements TProcessor { - - private static final Logger logger = LoggerFactory.getLogger( MultiServiceProcessor.class ); - - private ConcurrentMap processorMap = new ConcurrentHashMap(); - - private TProtocolFactory protocolFactory = new TBinaryProtocol.Factory(); - - public MultiServiceProcessor() {} - - public boolean process( TProtocol in, TProtocol out ) throws TException { - - short magic = in.readI16(); - - if ( magic != ThriftCodec.MAGIC ) { - logger.error( - new StringBuilder( 24 ) - .append( "Unsupported magic " ) - .append( magic ).toString() ); - return false; - } - - in.readI32(); - in.readI16(); - byte version = in.readByte(); - String serviceName = in.readString(); - long id = in.readI64(); - - ByteArrayOutputStream bos = new ByteArrayOutputStream( 1024 ); - - TIOStreamTransport transport = new TIOStreamTransport( bos ); - - TProtocol protocol = protocolFactory.getProtocol( transport ); - - TProcessor processor = processorMap.get( serviceName ); - - if ( processor == null ) { - logger.error( - new StringBuilder( 32 ) - .append( "Could not find processor for service " ) - .append( serviceName ) - .toString() ); - return false; - } - - // todo if exception - boolean result = processor.process( in, protocol ); - - ByteArrayOutputStream header = new ByteArrayOutputStream( 512 ); - - TIOStreamTransport headerTransport = new TIOStreamTransport( header ); - - TProtocol headerProtocol = protocolFactory.getProtocol( headerTransport ); - - headerProtocol.writeI16( magic ); - headerProtocol.writeI32( Integer.MAX_VALUE ); - headerProtocol.writeI16( Short.MAX_VALUE ); - headerProtocol.writeByte( version ); - headerProtocol.writeString( serviceName ); - headerProtocol.writeI64( id ); - headerProtocol.getTransport().flush(); - - out.writeI16( magic ); - out.writeI32( bos.size() + header.size() ); - out.writeI16( ( short ) ( 0xffff & header.size() ) ); - out.writeByte( version ); - out.writeString( serviceName ); - out.writeI64( id ); - - out.getTransport().write( bos.toByteArray() ); - out.getTransport().flush(); - - return result; - - } - - public TProcessor addProcessor( Class service, TProcessor processor ) { - if ( service != null && processor != null ) { - return processorMap.putIfAbsent( service.getName(), processor ); - } - return processor; - } - - public void setProtocolFactory( TProtocolFactory factory ) { - if ( factory != null ) { - this.protocolFactory = factory; - } - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/io/InputStreamWrapper.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/io/InputStreamWrapper.java deleted file mode 100644 index 9cdfdc372c4..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/io/InputStreamWrapper.java +++ /dev/null @@ -1,75 +0,0 @@ -package com.alibaba.dubbo.rpc.protocol.thrift.io; - -import java.io.IOException; -import java.io.InputStream; - -/** - * @author kimi - */ -public class InputStreamWrapper extends InputStream { - - private InputStream is; - - public InputStreamWrapper(InputStream is) { - if (is == null) { - throw new NullPointerException("is == null"); - } - this.is = is; - } - - @Override - public int read(byte[] b) throws IOException { - if (is.available() >= b.length) { - return is.read(b); - } else { - return -1; - } - } - - @Override - public int read(byte[] b, int off, int len) throws IOException { - if (is.available() >= len) { - return is.read(b, off, len); - } else { - return -1; - } - } - - @Override - public long skip(long n) throws IOException { - return is.skip(n); - } - - @Override - public int available() throws IOException { - return is.available(); - } - - @Override - public void close() throws IOException { - is.close(); - } - - @Override - public void mark(int readlimit) { - is.mark(readlimit); - } - - @Override - public void reset() throws IOException { - is.reset(); - } - - @Override - public boolean markSupported() { - return is.markSupported(); - } - - @Override - public int read() throws IOException { - if (is.available() >= 1) { - return is.read(); - } - return -1; - } -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/io/RandomAccessByteArrayOutputStream.java b/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/io/RandomAccessByteArrayOutputStream.java deleted file mode 100644 index 4902b4d59cb..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/java/com/alibaba/dubbo/rpc/protocol/thrift/io/RandomAccessByteArrayOutputStream.java +++ /dev/null @@ -1,107 +0,0 @@ -/** - * File Created at 2011-12-22 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift.io; - -import com.alibaba.dubbo.common.io.Bytes; - -import java.io.IOException; -import java.io.OutputStream; -import java.io.UnsupportedEncodingException; -import java.nio.ByteBuffer; - -/** - * @author kimi - */ -public class RandomAccessByteArrayOutputStream extends OutputStream { - - protected byte buffer[]; - - protected int count; - - public RandomAccessByteArrayOutputStream() { - - this( 32 ); - } - - public RandomAccessByteArrayOutputStream( int size ) { - - if ( size < 0 ) - throw new IllegalArgumentException( "Negative initial size: " + size ); - buffer = new byte[size]; - } - - public void write( int b ) { - - int newcount = count + 1; - if ( newcount > buffer.length ) - buffer = Bytes.copyOf( buffer, Math.max( buffer.length << 1, newcount ) ); - buffer[count] = ( byte ) b; - count = newcount; - } - - public void write( byte b[], int off, int len ) { - - if ( ( off < 0 ) || ( off > b.length ) || ( len < 0 ) || ( ( off + len ) > b.length ) || ( ( off + len ) < 0 ) ) - throw new IndexOutOfBoundsException(); - if ( len == 0 ) - return; - int newcount = count + len; - if ( newcount > buffer.length ) - buffer = Bytes.copyOf( buffer, Math.max( buffer.length << 1, newcount ) ); - System.arraycopy( b, off, buffer, count, len ); - count = newcount; - } - - public int size() { - - return count; - } - - public void setWriteIndex( int index ) { - count = index; - } - - public void reset() { - - count = 0; - } - - public byte[] toByteArray() { - - return Bytes.copyOf( buffer, count ); - } - - public ByteBuffer toByteBuffer() { - - return ByteBuffer.wrap( buffer, 0, count ); - } - - public void writeTo( OutputStream out ) throws IOException { - - out.write( buffer, 0, count ); - } - - public String toString() { - - return new String( buffer, 0, count ); - } - - public String toString( String charset ) throws UnsupportedEncodingException { - - return new String( buffer, 0, count, charset ); - } - - public void close() throws IOException {} - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Codec2 b/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Codec2 deleted file mode 100644 index 518ce0ae7a8..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Codec2 +++ /dev/null @@ -1 +0,0 @@ -thrift=com.alibaba.dubbo.rpc.protocol.thrift.ThriftCodec \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.Protocol b/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.Protocol deleted file mode 100644 index 85233b7736a..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.Protocol +++ /dev/null @@ -1 +0,0 @@ -thrift=com.alibaba.dubbo.rpc.protocol.thrift.ThriftProtocol \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.protocol.thrift.ClassNameGenerator b/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.protocol.thrift.ClassNameGenerator deleted file mode 100644 index b2e5598772b..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/main/resources/META-INF/dubbo/internal/com.alibaba.dubbo.rpc.protocol.thrift.ClassNameGenerator +++ /dev/null @@ -1,2 +0,0 @@ -dubbo=com.alibaba.dubbo.rpc.protocol.thrift.DubboClassNameGenerator -thrift=com.alibaba.dubbo.rpc.protocol.thrift.ThriftClassNameGenerator \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/$__ClassNameTestDubboStub.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/$__ClassNameTestDubboStub.java deleted file mode 100644 index b73ee40fc45..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/$__ClassNameTestDubboStub.java +++ /dev/null @@ -1,658 +0,0 @@ -/** - * Autogenerated by Dubbo Compiler (0.1.0) - * - * Thrift (0.7.0) - * - * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING - */ -import java.util.List; -import java.util.ArrayList; -import java.util.Map; -import java.util.HashMap; -import java.util.EnumMap; -import java.util.Set; -import java.util.HashSet; -import java.util.EnumSet; -import java.util.Collections; -import java.util.BitSet; -import java.nio.ByteBuffer; -import java.util.Arrays; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public class $__ClassNameTestDubboStub { - - public interface Iface { - - public String echo(String arg); - - } - - public static class Processor extends org.apache.thrift.TBaseProcessor implements org.apache.thrift.TProcessor { - private static final Logger LOGGER = LoggerFactory.getLogger(Processor.class.getName()); - public Processor(I iface) { - super(iface, getProcessMap(new HashMap>())); - } - - protected Processor(I iface, Map> processMap) { - super(iface, getProcessMap(processMap)); - } - - private static Map> getProcessMap(Map> processMap) { - processMap.put("echo", new echo()); - return processMap; - } - - private static class echo extends org.apache.thrift.ProcessFunction { - public echo() { - super("echo"); - } - - protected echo_args getEmptyArgsInstance() { - return new echo_args(); - } - - protected echo_result getResult(I iface, echo_args args) throws org.apache.thrift.TException { - echo_result result = new echo_result(); - result.success = iface.echo(args.arg); - return result; - } - } - - } - - public static class echo_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echo_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.STRING, (short)1); - - public String arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.STRING))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echo_args.class, metaDataMap); - } - - public echo_args() { - } - - public echo_args( - String arg) - { - this(); - this.arg = arg; - } - - /** - * Performs a deep copy on other. - */ - public echo_args(echo_args other) { - if (other.isSetArg()) { - this.arg = other.arg; - } - } - - public echo_args deepCopy() { - return new echo_args(this); - } - - public void clear() { - this.arg = null; - } - - public String getArg() { - return this.arg; - } - - public echo_args setArg(String arg) { - this.arg = arg; - return this; - } - - public void unsetArg() { - this.arg = null; - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return this.arg != null; - } - - public void setArgIsSet(boolean value) { - if (!value) { - this.arg = null; - } - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((String)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return getArg(); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - @Override - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echo_args) - return this.equals((echo_args)that); - return false; - } - - public boolean equals(echo_args that) { - if (that == null) - return false; - - boolean this_present_arg = true && this.isSetArg(); - boolean that_present_arg = true && that.isSetArg(); - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (!this.arg.equals(that.arg)) - return false; - } - - return true; - } - - @Override - public int hashCode() { - return 0; - } - - public int compareTo(echo_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echo_args typedOther = (echo_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.STRING) { - this.arg = iprot.readString(); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - if (this.arg != null) { - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeString(this.arg); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - @Override - public String toString() { - StringBuilder sb = new StringBuilder("echo_args("); - boolean first = true; - - sb.append("arg:"); - if (this.arg == null) { - sb.append("null"); - } else { - sb.append(this.arg); - } - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - if (arg == null) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not present! Struct: " + toString()); - } - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echo_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echo_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.STRING, (short)0); - - public String success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.STRING))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echo_result.class, metaDataMap); - } - - public echo_result() { - } - - public echo_result( - String success) - { - this(); - this.success = success; - } - - /** - * Performs a deep copy on other. - */ - public echo_result(echo_result other) { - if (other.isSetSuccess()) { - this.success = other.success; - } - } - - public echo_result deepCopy() { - return new echo_result(this); - } - - public void clear() { - this.success = null; - } - - public String getSuccess() { - return this.success; - } - - public echo_result setSuccess(String success) { - this.success = success; - return this; - } - - public void unsetSuccess() { - this.success = null; - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return this.success != null; - } - - public void setSuccessIsSet(boolean value) { - if (!value) { - this.success = null; - } - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((String)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return getSuccess(); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - @Override - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echo_result) - return this.equals((echo_result)that); - return false; - } - - public boolean equals(echo_result that) { - if (that == null) - return false; - - boolean this_present_success = true && this.isSetSuccess(); - boolean that_present_success = true && that.isSetSuccess(); - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (!this.success.equals(that.success)) - return false; - } - - return true; - } - - @Override - public int hashCode() { - return 0; - } - - public int compareTo(echo_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echo_result typedOther = (echo_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.STRING) { - this.success = iprot.readString(); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeString(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - @Override - public String toString() { - StringBuilder sb = new StringBuilder("echo_result("); - boolean first = true; - - sb.append("success:"); - if (this.success == null) { - sb.append("null"); - } else { - sb.append(this.success); - } - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTest.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTest.java deleted file mode 100644 index 45de6d30682..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTest.java +++ /dev/null @@ -1,45 +0,0 @@ -/** - * File Created at 2012-01-09 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ - -import com.alibaba.dubbo.rpc.protocol.thrift.ThriftUtils; -import org.junit.Assert; -import org.junit.Test; - -/** - * @author kimi - */ -public class ClassNameTest { - - @Test - public void testThriftUtils() { - - Assert.assertEquals( $__ClassNameTestDubboStub.echo_args.class.getName(), - ThriftUtils.generateMethodArgsClassName( - ClassNameTestDubbo.class.getName(), "echo" ) ); - - Assert.assertEquals( $__ClassNameTestDubboStub.echo_result.class.getName(), - ThriftUtils.generateMethodResultClassName( - ClassNameTestDubbo.class.getName(), "echo" ) ); - - Assert.assertEquals( ClassNameTestThrift.echo_args.class.getName(), - ThriftUtils.generateMethodArgsClassNameThrift( - ClassNameTestThrift.Iface.class.getName(), "echo" ) ); - - Assert.assertEquals( ClassNameTestThrift.echo_result.class.getName(), - ThriftUtils.generateMethodResultClassNameThrift( - ClassNameTestThrift.Iface.class.getName(), "echo" )); - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTestDubbo.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTestDubbo.java deleted file mode 100644 index 71741e10571..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTestDubbo.java +++ /dev/null @@ -1,27 +0,0 @@ -/** - * Autogenerated by Dubbo Compiler (0.1.0) - * - * Thrift (0.7.0) - * - * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING - */ -import java.util.List; -import java.util.ArrayList; -import java.util.Map; -import java.util.HashMap; -import java.util.EnumMap; -import java.util.Set; -import java.util.HashSet; -import java.util.EnumSet; -import java.util.Collections; -import java.util.BitSet; -import java.nio.ByteBuffer; -import java.util.Arrays; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public interface ClassNameTestDubbo { - - public String echo(String arg); - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTestThrift.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTestThrift.java deleted file mode 100644 index 8d48664d46d..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/ClassNameTestThrift.java +++ /dev/null @@ -1,757 +0,0 @@ -/** - * Autogenerated by Thrift Compiler (0.7.0) - * - * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING - */ -import java.util.List; -import java.util.ArrayList; -import java.util.Map; -import java.util.HashMap; -import java.util.EnumMap; -import java.util.Set; -import java.util.HashSet; -import java.util.EnumSet; -import java.util.Collections; -import java.util.BitSet; -import java.nio.ByteBuffer; -import java.util.Arrays; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public class ClassNameTestThrift { - - public interface Iface { - - public String echo(String arg) throws org.apache.thrift.TException; - - } - - public interface AsyncIface { - - public void echo(String arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException; - - } - - public static class Client extends org.apache.thrift.TServiceClient implements Iface { - public static class Factory implements org.apache.thrift.TServiceClientFactory { - public Factory() {} - public Client getClient(org.apache.thrift.protocol.TProtocol prot) { - return new Client(prot); - } - public Client getClient(org.apache.thrift.protocol.TProtocol iprot, org.apache.thrift.protocol.TProtocol oprot) { - return new Client(iprot, oprot); - } - } - - public Client(org.apache.thrift.protocol.TProtocol prot) - { - super(prot, prot); - } - - public Client(org.apache.thrift.protocol.TProtocol iprot, org.apache.thrift.protocol.TProtocol oprot) { - super(iprot, oprot); - } - - public String echo(String arg) throws org.apache.thrift.TException - { - send_echo(arg); - return recv_echo(); - } - - public void send_echo(String arg) throws org.apache.thrift.TException - { - echo_args args = new echo_args(); - args.setArg(arg); - sendBase("echo", args); - } - - public String recv_echo() throws org.apache.thrift.TException - { - echo_result result = new echo_result(); - receiveBase(result, "echo"); - if (result.isSetSuccess()) { - return result.success; - } - throw new org.apache.thrift.TApplicationException(org.apache.thrift.TApplicationException.MISSING_RESULT, "echo failed: unknown result"); - } - - } - public static class AsyncClient extends org.apache.thrift.async.TAsyncClient implements AsyncIface { - public static class Factory implements org.apache.thrift.async.TAsyncClientFactory { - private org.apache.thrift.async.TAsyncClientManager clientManager; - private org.apache.thrift.protocol.TProtocolFactory protocolFactory; - public Factory(org.apache.thrift.async.TAsyncClientManager clientManager, org.apache.thrift.protocol.TProtocolFactory protocolFactory) { - this.clientManager = clientManager; - this.protocolFactory = protocolFactory; - } - public AsyncClient getAsyncClient(org.apache.thrift.transport.TNonblockingTransport transport) { - return new AsyncClient(protocolFactory, clientManager, transport); - } - } - - public AsyncClient(org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.async.TAsyncClientManager clientManager, org.apache.thrift.transport.TNonblockingTransport transport) { - super(protocolFactory, clientManager, transport); - } - - public void echo(String arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException { - checkReady(); - echo_call method_call = new echo_call(arg, resultHandler, this, ___protocolFactory, ___transport); - this.___currentMethod = method_call; - ___manager.call(method_call); - } - - public static class echo_call extends org.apache.thrift.async.TAsyncMethodCall { - private String arg; - public echo_call(String arg, org.apache.thrift.async.AsyncMethodCallback resultHandler, org.apache.thrift.async.TAsyncClient client, org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.transport.TNonblockingTransport transport) throws org.apache.thrift.TException { - super(client, protocolFactory, transport, resultHandler, false); - this.arg = arg; - } - - public void write_args(org.apache.thrift.protocol.TProtocol prot) throws org.apache.thrift.TException { - prot.writeMessageBegin(new org.apache.thrift.protocol.TMessage("echo", org.apache.thrift.protocol.TMessageType.CALL, 0)); - echo_args args = new echo_args(); - args.setArg(arg); - args.write(prot); - prot.writeMessageEnd(); - } - - public String getResult() throws org.apache.thrift.TException { - if (getState() != org.apache.thrift.async.TAsyncMethodCall.State.RESPONSE_READ) { - throw new IllegalStateException("Method call not finished!"); - } - org.apache.thrift.transport.TMemoryInputTransport memoryTransport = new org.apache.thrift.transport.TMemoryInputTransport(getFrameBuffer().array()); - org.apache.thrift.protocol.TProtocol prot = client.getProtocolFactory().getProtocol(memoryTransport); - return (new Client(prot)).recv_echo(); - } - } - - } - - public static class Processor extends org.apache.thrift.TBaseProcessor implements org.apache.thrift.TProcessor { - private static final Logger LOGGER = LoggerFactory.getLogger(Processor.class.getName()); - public Processor(I iface) { - super(iface, getProcessMap(new HashMap>())); - } - - protected Processor(I iface, Map> processMap) { - super(iface, getProcessMap(processMap)); - } - - private static Map> getProcessMap(Map> processMap) { - processMap.put("echo", new echo()); - return processMap; - } - - private static class echo extends org.apache.thrift.ProcessFunction { - public echo() { - super("echo"); - } - - protected echo_args getEmptyArgsInstance() { - return new echo_args(); - } - - protected echo_result getResult(I iface, echo_args args) throws org.apache.thrift.TException { - echo_result result = new echo_result(); - result.success = iface.echo(args.arg); - return result; - } - } - - } - - public static class echo_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echo_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.STRING, (short)1); - - public String arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.STRING))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echo_args.class, metaDataMap); - } - - public echo_args() { - } - - public echo_args( - String arg) - { - this(); - this.arg = arg; - } - - /** - * Performs a deep copy on other. - */ - public echo_args(echo_args other) { - if (other.isSetArg()) { - this.arg = other.arg; - } - } - - public echo_args deepCopy() { - return new echo_args(this); - } - - public void clear() { - this.arg = null; - } - - public String getArg() { - return this.arg; - } - - public echo_args setArg(String arg) { - this.arg = arg; - return this; - } - - public void unsetArg() { - this.arg = null; - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return this.arg != null; - } - - public void setArgIsSet(boolean value) { - if (!value) { - this.arg = null; - } - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((String)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return getArg(); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - @Override - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echo_args) - return this.equals((echo_args)that); - return false; - } - - public boolean equals(echo_args that) { - if (that == null) - return false; - - boolean this_present_arg = true && this.isSetArg(); - boolean that_present_arg = true && that.isSetArg(); - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (!this.arg.equals(that.arg)) - return false; - } - - return true; - } - - @Override - public int hashCode() { - return 0; - } - - public int compareTo(echo_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echo_args typedOther = (echo_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.STRING) { - this.arg = iprot.readString(); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - if (this.arg != null) { - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeString(this.arg); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - @Override - public String toString() { - StringBuilder sb = new StringBuilder("echo_args("); - boolean first = true; - - sb.append("arg:"); - if (this.arg == null) { - sb.append("null"); - } else { - sb.append(this.arg); - } - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - if (arg == null) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not present! Struct: " + toString()); - } - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echo_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echo_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.STRING, (short)0); - - public String success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.STRING))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echo_result.class, metaDataMap); - } - - public echo_result() { - } - - public echo_result( - String success) - { - this(); - this.success = success; - } - - /** - * Performs a deep copy on other. - */ - public echo_result(echo_result other) { - if (other.isSetSuccess()) { - this.success = other.success; - } - } - - public echo_result deepCopy() { - return new echo_result(this); - } - - public void clear() { - this.success = null; - } - - public String getSuccess() { - return this.success; - } - - public echo_result setSuccess(String success) { - this.success = success; - return this; - } - - public void unsetSuccess() { - this.success = null; - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return this.success != null; - } - - public void setSuccessIsSet(boolean value) { - if (!value) { - this.success = null; - } - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((String)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return getSuccess(); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - @Override - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echo_result) - return this.equals((echo_result)that); - return false; - } - - public boolean equals(echo_result that) { - if (that == null) - return false; - - boolean this_present_success = true && this.isSetSuccess(); - boolean that_present_success = true && that.isSetSuccess(); - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (!this.success.equals(that.success)) - return false; - } - - return true; - } - - @Override - public int hashCode() { - return 0; - } - - public int compareTo(echo_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echo_result typedOther = (echo_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.STRING) { - this.success = iprot.readString(); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeString(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - @Override - public String toString() { - StringBuilder sb = new StringBuilder("echo_result("); - boolean first = true; - - sb.append("success:"); - if (this.success == null) { - sb.append("null"); - } else { - sb.append(this.success); - } - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/dubbo/$__DemoStub.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/dubbo/$__DemoStub.java deleted file mode 100644 index f29d6b74934..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/dubbo/$__DemoStub.java +++ /dev/null @@ -1,4376 +0,0 @@ -/** - * Autogenerated by Dubbo Compiler (0.1.0) - * - * Thrift (0.7.0) - * - * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING - */ -package com.alibaba.dubbo.rpc.gen.dubbo; - -import java.util.List; -import java.util.ArrayList; -import java.util.Map; -import java.util.HashMap; -import java.util.EnumMap; -import java.util.Set; -import java.util.HashSet; -import java.util.EnumSet; -import java.util.Collections; -import java.util.BitSet; -import java.nio.ByteBuffer; -import java.util.Arrays; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public class $__DemoStub { - - public interface Iface { - - public boolean echoBool(boolean arg); - - public byte echoByte(byte arg); - - public short echoI16(short arg); - - public int echoI32(int arg); - - public long echoI64(long arg); - - public double echoDouble(double arg); - - public String echoString(String arg); - - } - - public static class Processor extends org.apache.thrift.TBaseProcessor implements org.apache.thrift.TProcessor { - private static final Logger LOGGER = LoggerFactory.getLogger(Processor.class.getName()); - public Processor(I iface) { - super(iface, getProcessMap(new HashMap>())); - } - - protected Processor(I iface, Map> processMap) { - super(iface, getProcessMap(processMap)); - } - - private static Map> getProcessMap(Map> processMap) { - processMap.put("echoBool", new echoBool()); - processMap.put("echoByte", new echoByte()); - processMap.put("echoI16", new echoI16()); - processMap.put("echoI32", new echoI32()); - processMap.put("echoI64", new echoI64()); - processMap.put("echoDouble", new echoDouble()); - processMap.put("echoString", new echoString()); - return processMap; - } - - private static class echoBool extends org.apache.thrift.ProcessFunction { - public echoBool() { - super("echoBool"); - } - - protected echoBool_args getEmptyArgsInstance() { - return new echoBool_args(); - } - - protected echoBool_result getResult(I iface, echoBool_args args) throws org.apache.thrift.TException { - echoBool_result result = new echoBool_result(); - result.success = iface.echoBool(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoByte extends org.apache.thrift.ProcessFunction { - public echoByte() { - super("echoByte"); - } - - protected echoByte_args getEmptyArgsInstance() { - return new echoByte_args(); - } - - protected echoByte_result getResult(I iface, echoByte_args args) throws org.apache.thrift.TException { - echoByte_result result = new echoByte_result(); - result.success = iface.echoByte(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoI16 extends org.apache.thrift.ProcessFunction { - public echoI16() { - super("echoI16"); - } - - protected echoI16_args getEmptyArgsInstance() { - return new echoI16_args(); - } - - protected echoI16_result getResult(I iface, echoI16_args args) throws org.apache.thrift.TException { - echoI16_result result = new echoI16_result(); - result.success = iface.echoI16(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoI32 extends org.apache.thrift.ProcessFunction { - public echoI32() { - super("echoI32"); - } - - protected echoI32_args getEmptyArgsInstance() { - return new echoI32_args(); - } - - protected echoI32_result getResult(I iface, echoI32_args args) throws org.apache.thrift.TException { - echoI32_result result = new echoI32_result(); - result.success = iface.echoI32(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoI64 extends org.apache.thrift.ProcessFunction { - public echoI64() { - super("echoI64"); - } - - protected echoI64_args getEmptyArgsInstance() { - return new echoI64_args(); - } - - protected echoI64_result getResult(I iface, echoI64_args args) throws org.apache.thrift.TException { - echoI64_result result = new echoI64_result(); - result.success = iface.echoI64(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoDouble extends org.apache.thrift.ProcessFunction { - public echoDouble() { - super("echoDouble"); - } - - protected echoDouble_args getEmptyArgsInstance() { - return new echoDouble_args(); - } - - protected echoDouble_result getResult(I iface, echoDouble_args args) throws org.apache.thrift.TException { - echoDouble_result result = new echoDouble_result(); - result.success = iface.echoDouble(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoString extends org.apache.thrift.ProcessFunction { - public echoString() { - super("echoString"); - } - - protected echoString_args getEmptyArgsInstance() { - return new echoString_args(); - } - - protected echoString_result getResult(I iface, echoString_args args) throws org.apache.thrift.TException { - echoString_result result = new echoString_result(); - result.success = iface.echoString(args.arg); - return result; - } - } - - } - - public static class echoBool_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoBool_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.BOOL, (short)1); - - public boolean arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.BOOL))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoBool_args.class, metaDataMap); - } - - public echoBool_args() { - } - - public echoBool_args( - boolean arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoBool_args(echoBool_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoBool_args deepCopy() { - return new echoBool_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = false; - } - - public boolean isArg() { - return this.arg; - } - - public echoBool_args setArg(boolean arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Boolean)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Boolean.valueOf(isArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoBool_args) - return this.equals((echoBool_args)that); - return false; - } - - public boolean equals(echoBool_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoBool_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoBool_args typedOther = (echoBool_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.BOOL) { - this.arg = iprot.readBool(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeBool(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoBool_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoBool_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoBool_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.BOOL, (short)0); - - public boolean success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.BOOL))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoBool_result.class, metaDataMap); - } - - public echoBool_result() { - } - - public echoBool_result( - boolean success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoBool_result(echoBool_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoBool_result deepCopy() { - return new echoBool_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = false; - } - - public boolean isSuccess() { - return this.success; - } - - public echoBool_result setSuccess(boolean success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Boolean)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Boolean.valueOf(isSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoBool_result) - return this.equals((echoBool_result)that); - return false; - } - - public boolean equals(echoBool_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoBool_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoBool_result typedOther = (echoBool_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.BOOL) { - this.success = iprot.readBool(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeBool(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoBool_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoByte_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoByte_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.BYTE, (short)1); - - public byte arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.BYTE))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoByte_args.class, metaDataMap); - } - - public echoByte_args() { - } - - public echoByte_args( - byte arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoByte_args(echoByte_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoByte_args deepCopy() { - return new echoByte_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0; - } - - public byte getArg() { - return this.arg; - } - - public echoByte_args setArg(byte arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Byte)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Byte.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoByte_args) - return this.equals((echoByte_args)that); - return false; - } - - public boolean equals(echoByte_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoByte_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoByte_args typedOther = (echoByte_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.BYTE) { - this.arg = iprot.readByte(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeByte(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoByte_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoByte_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoByte_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.BYTE, (short)0); - - public byte success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.BYTE))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoByte_result.class, metaDataMap); - } - - public echoByte_result() { - } - - public echoByte_result( - byte success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoByte_result(echoByte_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoByte_result deepCopy() { - return new echoByte_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0; - } - - public byte getSuccess() { - return this.success; - } - - public echoByte_result setSuccess(byte success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Byte)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Byte.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoByte_result) - return this.equals((echoByte_result)that); - return false; - } - - public boolean equals(echoByte_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoByte_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoByte_result typedOther = (echoByte_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.BYTE) { - this.success = iprot.readByte(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeByte(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoByte_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI16_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI16_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.I16, (short)1); - - public short arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I16))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI16_args.class, metaDataMap); - } - - public echoI16_args() { - } - - public echoI16_args( - short arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI16_args(echoI16_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoI16_args deepCopy() { - return new echoI16_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0; - } - - public short getArg() { - return this.arg; - } - - public echoI16_args setArg(short arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Short)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Short.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI16_args) - return this.equals((echoI16_args)that); - return false; - } - - public boolean equals(echoI16_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI16_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI16_args typedOther = (echoI16_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.I16) { - this.arg = iprot.readI16(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeI16(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI16_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI16_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI16_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.I16, (short)0); - - public short success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I16))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI16_result.class, metaDataMap); - } - - public echoI16_result() { - } - - public echoI16_result( - short success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI16_result(echoI16_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoI16_result deepCopy() { - return new echoI16_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0; - } - - public short getSuccess() { - return this.success; - } - - public echoI16_result setSuccess(short success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Short)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Short.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI16_result) - return this.equals((echoI16_result)that); - return false; - } - - public boolean equals(echoI16_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI16_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI16_result typedOther = (echoI16_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.I16) { - this.success = iprot.readI16(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeI16(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI16_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI32_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI32_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.I32, (short)1); - - public int arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I32))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI32_args.class, metaDataMap); - } - - public echoI32_args() { - } - - public echoI32_args( - int arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI32_args(echoI32_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoI32_args deepCopy() { - return new echoI32_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0; - } - - public int getArg() { - return this.arg; - } - - public echoI32_args setArg(int arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Integer)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Integer.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI32_args) - return this.equals((echoI32_args)that); - return false; - } - - public boolean equals(echoI32_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI32_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI32_args typedOther = (echoI32_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.I32) { - this.arg = iprot.readI32(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeI32(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI32_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI32_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI32_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.I32, (short)0); - - public int success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I32))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI32_result.class, metaDataMap); - } - - public echoI32_result() { - } - - public echoI32_result( - int success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI32_result(echoI32_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoI32_result deepCopy() { - return new echoI32_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0; - } - - public int getSuccess() { - return this.success; - } - - public echoI32_result setSuccess(int success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Integer)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Integer.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI32_result) - return this.equals((echoI32_result)that); - return false; - } - - public boolean equals(echoI32_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI32_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI32_result typedOther = (echoI32_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.I32) { - this.success = iprot.readI32(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeI32(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI32_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI64_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI64_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.I64, (short)1); - - public long arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I64))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI64_args.class, metaDataMap); - } - - public echoI64_args() { - } - - public echoI64_args( - long arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI64_args(echoI64_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoI64_args deepCopy() { - return new echoI64_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0; - } - - public long getArg() { - return this.arg; - } - - public echoI64_args setArg(long arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Long)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Long.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI64_args) - return this.equals((echoI64_args)that); - return false; - } - - public boolean equals(echoI64_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI64_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI64_args typedOther = (echoI64_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.I64) { - this.arg = iprot.readI64(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeI64(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI64_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI64_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI64_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.I64, (short)0); - - public long success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I64))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI64_result.class, metaDataMap); - } - - public echoI64_result() { - } - - public echoI64_result( - long success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI64_result(echoI64_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoI64_result deepCopy() { - return new echoI64_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0; - } - - public long getSuccess() { - return this.success; - } - - public echoI64_result setSuccess(long success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Long)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Long.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI64_result) - return this.equals((echoI64_result)that); - return false; - } - - public boolean equals(echoI64_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI64_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI64_result typedOther = (echoI64_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.I64) { - this.success = iprot.readI64(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeI64(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI64_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoDouble_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoDouble_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.DOUBLE, (short)1); - - public double arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.DOUBLE))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoDouble_args.class, metaDataMap); - } - - public echoDouble_args() { - } - - public echoDouble_args( - double arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoDouble_args(echoDouble_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoDouble_args deepCopy() { - return new echoDouble_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0.0; - } - - public double getArg() { - return this.arg; - } - - public echoDouble_args setArg(double arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Double)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Double.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoDouble_args) - return this.equals((echoDouble_args)that); - return false; - } - - public boolean equals(echoDouble_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoDouble_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoDouble_args typedOther = (echoDouble_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.DOUBLE) { - this.arg = iprot.readDouble(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeDouble(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoDouble_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoDouble_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoDouble_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.DOUBLE, (short)0); - - public double success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.DOUBLE))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoDouble_result.class, metaDataMap); - } - - public echoDouble_result() { - } - - public echoDouble_result( - double success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoDouble_result(echoDouble_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoDouble_result deepCopy() { - return new echoDouble_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0.0; - } - - public double getSuccess() { - return this.success; - } - - public echoDouble_result setSuccess(double success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Double)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Double.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoDouble_result) - return this.equals((echoDouble_result)that); - return false; - } - - public boolean equals(echoDouble_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoDouble_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoDouble_result typedOther = (echoDouble_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.DOUBLE) { - this.success = iprot.readDouble(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeDouble(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoDouble_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoString_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoString_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.STRING, (short)1); - - public String arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.STRING))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoString_args.class, metaDataMap); - } - - public echoString_args() { - } - - public echoString_args( - String arg) - { - this(); - this.arg = arg; - } - - /** - * Performs a deep copy on other. - */ - public echoString_args(echoString_args other) { - if (other.isSetArg()) { - this.arg = other.arg; - } - } - - public echoString_args deepCopy() { - return new echoString_args(this); - } - - - public void clear() { - this.arg = null; - } - - public String getArg() { - return this.arg; - } - - public echoString_args setArg(String arg) { - this.arg = arg; - return this; - } - - public void unsetArg() { - this.arg = null; - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return this.arg != null; - } - - public void setArgIsSet(boolean value) { - if (!value) { - this.arg = null; - } - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((String)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return getArg(); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoString_args) - return this.equals((echoString_args)that); - return false; - } - - public boolean equals(echoString_args that) { - if (that == null) - return false; - - boolean this_present_arg = true && this.isSetArg(); - boolean that_present_arg = true && that.isSetArg(); - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (!this.arg.equals(that.arg)) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoString_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoString_args typedOther = (echoString_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.STRING) { - this.arg = iprot.readString(); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - if (this.arg != null) { - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeString(this.arg); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoString_args("); - boolean first = true; - - sb.append("arg:"); - if (this.arg == null) { - sb.append("null"); - } else { - sb.append(this.arg); - } - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - if (arg == null) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not present! Struct: " + toString()); - } - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoString_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoString_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.STRING, (short)0); - - public String success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.STRING))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoString_result.class, metaDataMap); - } - - public echoString_result() { - } - - public echoString_result( - String success) - { - this(); - this.success = success; - } - - /** - * Performs a deep copy on other. - */ - public echoString_result(echoString_result other) { - if (other.isSetSuccess()) { - this.success = other.success; - } - } - - public echoString_result deepCopy() { - return new echoString_result(this); - } - - - public void clear() { - this.success = null; - } - - public String getSuccess() { - return this.success; - } - - public echoString_result setSuccess(String success) { - this.success = success; - return this; - } - - public void unsetSuccess() { - this.success = null; - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return this.success != null; - } - - public void setSuccessIsSet(boolean value) { - if (!value) { - this.success = null; - } - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((String)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return getSuccess(); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoString_result) - return this.equals((echoString_result)that); - return false; - } - - public boolean equals(echoString_result that) { - if (that == null) - return false; - - boolean this_present_success = true && this.isSetSuccess(); - boolean that_present_success = true && that.isSetSuccess(); - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (!this.success.equals(that.success)) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoString_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoString_result typedOther = (echoString_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.STRING) { - this.success = iprot.readString(); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeString(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoString_result("); - boolean first = true; - - sb.append("success:"); - if (this.success == null) { - sb.append("null"); - } else { - sb.append(this.success); - } - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/dubbo/Demo.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/dubbo/Demo.java deleted file mode 100644 index 8993ad2cfe2..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/dubbo/Demo.java +++ /dev/null @@ -1,41 +0,0 @@ -/** - * Autogenerated by Dubbo Compiler (0.1.0) - * - * Thrift (0.7.0) - * - * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING - */ -package com.alibaba.dubbo.rpc.gen.dubbo; - -import java.util.List; -import java.util.ArrayList; -import java.util.Map; -import java.util.HashMap; -import java.util.EnumMap; -import java.util.Set; -import java.util.HashSet; -import java.util.EnumSet; -import java.util.Collections; -import java.util.BitSet; -import java.nio.ByteBuffer; -import java.util.Arrays; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public interface Demo { - - public boolean echoBool(boolean arg); - - public byte echoByte(byte arg); - - public short echoI16(short arg); - - public int echoI32(int arg); - - public long echoI64(long arg); - - public double echoDouble(double arg); - - public String echoString(String arg); - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/thrift/Demo.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/thrift/Demo.java deleted file mode 100644 index 2be2cfa99f5..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/gen/thrift/Demo.java +++ /dev/null @@ -1,4805 +0,0 @@ -/** - * Autogenerated by Thrift Compiler (0.7.0) - * - * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING - */ -package com.alibaba.dubbo.rpc.gen.thrift; - -import java.util.List; -import java.util.ArrayList; -import java.util.Map; -import java.util.HashMap; -import java.util.EnumMap; -import java.util.Set; -import java.util.HashSet; -import java.util.EnumSet; -import java.util.Collections; -import java.util.BitSet; -import java.nio.ByteBuffer; -import java.util.Arrays; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - -public class Demo { - - public interface Iface { - - public boolean echoBool(boolean arg) throws org.apache.thrift.TException; - - public byte echoByte(byte arg) throws org.apache.thrift.TException; - - public short echoI16(short arg) throws org.apache.thrift.TException; - - public int echoI32(int arg) throws org.apache.thrift.TException; - - public long echoI64(long arg) throws org.apache.thrift.TException; - - public double echoDouble(double arg) throws org.apache.thrift.TException; - - public String echoString(String arg) throws org.apache.thrift.TException; - - } - - public interface AsyncIface { - - public void echoBool(boolean arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException; - - public void echoByte(byte arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException; - - public void echoI16(short arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException; - - public void echoI32(int arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException; - - public void echoI64(long arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException; - - public void echoDouble(double arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException; - - public void echoString(String arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException; - - } - - public static class Client extends org.apache.thrift.TServiceClient implements Iface { - public static class Factory implements org.apache.thrift.TServiceClientFactory { - public Factory() {} - public Client getClient(org.apache.thrift.protocol.TProtocol prot) { - return new Client(prot); - } - public Client getClient(org.apache.thrift.protocol.TProtocol iprot, org.apache.thrift.protocol.TProtocol oprot) { - return new Client(iprot, oprot); - } - } - - public Client(org.apache.thrift.protocol.TProtocol prot) - { - super(prot, prot); - } - - public Client(org.apache.thrift.protocol.TProtocol iprot, org.apache.thrift.protocol.TProtocol oprot) { - super(iprot, oprot); - } - - public boolean echoBool(boolean arg) throws org.apache.thrift.TException - { - send_echoBool(arg); - return recv_echoBool(); - } - - public void send_echoBool(boolean arg) throws org.apache.thrift.TException - { - echoBool_args args = new echoBool_args(); - args.setArg(arg); - sendBase("echoBool", args); - } - - public boolean recv_echoBool() throws org.apache.thrift.TException - { - echoBool_result result = new echoBool_result(); - receiveBase(result, "echoBool"); - if (result.isSetSuccess()) { - return result.success; - } - throw new org.apache.thrift.TApplicationException(org.apache.thrift.TApplicationException.MISSING_RESULT, "echoBool failed: unknown result"); - } - - public byte echoByte(byte arg) throws org.apache.thrift.TException - { - send_echoByte(arg); - return recv_echoByte(); - } - - public void send_echoByte(byte arg) throws org.apache.thrift.TException - { - echoByte_args args = new echoByte_args(); - args.setArg(arg); - sendBase("echoByte", args); - } - - public byte recv_echoByte() throws org.apache.thrift.TException - { - echoByte_result result = new echoByte_result(); - receiveBase(result, "echoByte"); - if (result.isSetSuccess()) { - return result.success; - } - throw new org.apache.thrift.TApplicationException(org.apache.thrift.TApplicationException.MISSING_RESULT, "echoByte failed: unknown result"); - } - - public short echoI16(short arg) throws org.apache.thrift.TException - { - send_echoI16(arg); - return recv_echoI16(); - } - - public void send_echoI16(short arg) throws org.apache.thrift.TException - { - echoI16_args args = new echoI16_args(); - args.setArg(arg); - sendBase("echoI16", args); - } - - public short recv_echoI16() throws org.apache.thrift.TException - { - echoI16_result result = new echoI16_result(); - receiveBase(result, "echoI16"); - if (result.isSetSuccess()) { - return result.success; - } - throw new org.apache.thrift.TApplicationException(org.apache.thrift.TApplicationException.MISSING_RESULT, "echoI16 failed: unknown result"); - } - - public int echoI32(int arg) throws org.apache.thrift.TException - { - send_echoI32(arg); - return recv_echoI32(); - } - - public void send_echoI32(int arg) throws org.apache.thrift.TException - { - echoI32_args args = new echoI32_args(); - args.setArg(arg); - sendBase("echoI32", args); - } - - public int recv_echoI32() throws org.apache.thrift.TException - { - echoI32_result result = new echoI32_result(); - receiveBase(result, "echoI32"); - if (result.isSetSuccess()) { - return result.success; - } - throw new org.apache.thrift.TApplicationException(org.apache.thrift.TApplicationException.MISSING_RESULT, "echoI32 failed: unknown result"); - } - - public long echoI64(long arg) throws org.apache.thrift.TException - { - send_echoI64(arg); - return recv_echoI64(); - } - - public void send_echoI64(long arg) throws org.apache.thrift.TException - { - echoI64_args args = new echoI64_args(); - args.setArg(arg); - sendBase("echoI64", args); - } - - public long recv_echoI64() throws org.apache.thrift.TException - { - echoI64_result result = new echoI64_result(); - receiveBase(result, "echoI64"); - if (result.isSetSuccess()) { - return result.success; - } - throw new org.apache.thrift.TApplicationException(org.apache.thrift.TApplicationException.MISSING_RESULT, "echoI64 failed: unknown result"); - } - - public double echoDouble(double arg) throws org.apache.thrift.TException - { - send_echoDouble(arg); - return recv_echoDouble(); - } - - public void send_echoDouble(double arg) throws org.apache.thrift.TException - { - echoDouble_args args = new echoDouble_args(); - args.setArg(arg); - sendBase("echoDouble", args); - } - - public double recv_echoDouble() throws org.apache.thrift.TException - { - echoDouble_result result = new echoDouble_result(); - receiveBase(result, "echoDouble"); - if (result.isSetSuccess()) { - return result.success; - } - throw new org.apache.thrift.TApplicationException(org.apache.thrift.TApplicationException.MISSING_RESULT, "echoDouble failed: unknown result"); - } - - public String echoString(String arg) throws org.apache.thrift.TException - { - send_echoString(arg); - return recv_echoString(); - } - - public void send_echoString(String arg) throws org.apache.thrift.TException - { - echoString_args args = new echoString_args(); - args.setArg(arg); - sendBase("echoString", args); - } - - public String recv_echoString() throws org.apache.thrift.TException - { - echoString_result result = new echoString_result(); - receiveBase(result, "echoString"); - if (result.isSetSuccess()) { - return result.success; - } - throw new org.apache.thrift.TApplicationException(org.apache.thrift.TApplicationException.MISSING_RESULT, "echoString failed: unknown result"); - } - - } - public static class AsyncClient extends org.apache.thrift.async.TAsyncClient implements AsyncIface { - public static class Factory implements org.apache.thrift.async.TAsyncClientFactory { - private org.apache.thrift.async.TAsyncClientManager clientManager; - private org.apache.thrift.protocol.TProtocolFactory protocolFactory; - public Factory(org.apache.thrift.async.TAsyncClientManager clientManager, org.apache.thrift.protocol.TProtocolFactory protocolFactory) { - this.clientManager = clientManager; - this.protocolFactory = protocolFactory; - } - public AsyncClient getAsyncClient(org.apache.thrift.transport.TNonblockingTransport transport) { - return new AsyncClient(protocolFactory, clientManager, transport); - } - } - - public AsyncClient(org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.async.TAsyncClientManager clientManager, org.apache.thrift.transport.TNonblockingTransport transport) { - super(protocolFactory, clientManager, transport); - } - - public void echoBool(boolean arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException { - checkReady(); - echoBool_call method_call = new echoBool_call(arg, resultHandler, this, ___protocolFactory, ___transport); - this.___currentMethod = method_call; - ___manager.call(method_call); - } - - public static class echoBool_call extends org.apache.thrift.async.TAsyncMethodCall { - private boolean arg; - public echoBool_call(boolean arg, org.apache.thrift.async.AsyncMethodCallback resultHandler, org.apache.thrift.async.TAsyncClient client, org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.transport.TNonblockingTransport transport) throws org.apache.thrift.TException { - super(client, protocolFactory, transport, resultHandler, false); - this.arg = arg; - } - - public void write_args(org.apache.thrift.protocol.TProtocol prot) throws org.apache.thrift.TException { - prot.writeMessageBegin(new org.apache.thrift.protocol.TMessage("echoBool", org.apache.thrift.protocol.TMessageType.CALL, 0)); - echoBool_args args = new echoBool_args(); - args.setArg(arg); - args.write(prot); - prot.writeMessageEnd(); - } - - public boolean getResult() throws org.apache.thrift.TException { - if (getState() != org.apache.thrift.async.TAsyncMethodCall.State.RESPONSE_READ) { - throw new IllegalStateException("Method call not finished!"); - } - org.apache.thrift.transport.TMemoryInputTransport memoryTransport = new org.apache.thrift.transport.TMemoryInputTransport(getFrameBuffer().array()); - org.apache.thrift.protocol.TProtocol prot = client.getProtocolFactory().getProtocol(memoryTransport); - return (new Client(prot)).recv_echoBool(); - } - } - - public void echoByte(byte arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException { - checkReady(); - echoByte_call method_call = new echoByte_call(arg, resultHandler, this, ___protocolFactory, ___transport); - this.___currentMethod = method_call; - ___manager.call(method_call); - } - - public static class echoByte_call extends org.apache.thrift.async.TAsyncMethodCall { - private byte arg; - public echoByte_call(byte arg, org.apache.thrift.async.AsyncMethodCallback resultHandler, org.apache.thrift.async.TAsyncClient client, org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.transport.TNonblockingTransport transport) throws org.apache.thrift.TException { - super(client, protocolFactory, transport, resultHandler, false); - this.arg = arg; - } - - public void write_args(org.apache.thrift.protocol.TProtocol prot) throws org.apache.thrift.TException { - prot.writeMessageBegin(new org.apache.thrift.protocol.TMessage("echoByte", org.apache.thrift.protocol.TMessageType.CALL, 0)); - echoByte_args args = new echoByte_args(); - args.setArg(arg); - args.write(prot); - prot.writeMessageEnd(); - } - - public byte getResult() throws org.apache.thrift.TException { - if (getState() != org.apache.thrift.async.TAsyncMethodCall.State.RESPONSE_READ) { - throw new IllegalStateException("Method call not finished!"); - } - org.apache.thrift.transport.TMemoryInputTransport memoryTransport = new org.apache.thrift.transport.TMemoryInputTransport(getFrameBuffer().array()); - org.apache.thrift.protocol.TProtocol prot = client.getProtocolFactory().getProtocol(memoryTransport); - return (new Client(prot)).recv_echoByte(); - } - } - - public void echoI16(short arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException { - checkReady(); - echoI16_call method_call = new echoI16_call(arg, resultHandler, this, ___protocolFactory, ___transport); - this.___currentMethod = method_call; - ___manager.call(method_call); - } - - public static class echoI16_call extends org.apache.thrift.async.TAsyncMethodCall { - private short arg; - public echoI16_call(short arg, org.apache.thrift.async.AsyncMethodCallback resultHandler, org.apache.thrift.async.TAsyncClient client, org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.transport.TNonblockingTransport transport) throws org.apache.thrift.TException { - super(client, protocolFactory, transport, resultHandler, false); - this.arg = arg; - } - - public void write_args(org.apache.thrift.protocol.TProtocol prot) throws org.apache.thrift.TException { - prot.writeMessageBegin(new org.apache.thrift.protocol.TMessage("echoI16", org.apache.thrift.protocol.TMessageType.CALL, 0)); - echoI16_args args = new echoI16_args(); - args.setArg(arg); - args.write(prot); - prot.writeMessageEnd(); - } - - public short getResult() throws org.apache.thrift.TException { - if (getState() != org.apache.thrift.async.TAsyncMethodCall.State.RESPONSE_READ) { - throw new IllegalStateException("Method call not finished!"); - } - org.apache.thrift.transport.TMemoryInputTransport memoryTransport = new org.apache.thrift.transport.TMemoryInputTransport(getFrameBuffer().array()); - org.apache.thrift.protocol.TProtocol prot = client.getProtocolFactory().getProtocol(memoryTransport); - return (new Client(prot)).recv_echoI16(); - } - } - - public void echoI32(int arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException { - checkReady(); - echoI32_call method_call = new echoI32_call(arg, resultHandler, this, ___protocolFactory, ___transport); - this.___currentMethod = method_call; - ___manager.call(method_call); - } - - public static class echoI32_call extends org.apache.thrift.async.TAsyncMethodCall { - private int arg; - public echoI32_call(int arg, org.apache.thrift.async.AsyncMethodCallback resultHandler, org.apache.thrift.async.TAsyncClient client, org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.transport.TNonblockingTransport transport) throws org.apache.thrift.TException { - super(client, protocolFactory, transport, resultHandler, false); - this.arg = arg; - } - - public void write_args(org.apache.thrift.protocol.TProtocol prot) throws org.apache.thrift.TException { - prot.writeMessageBegin(new org.apache.thrift.protocol.TMessage("echoI32", org.apache.thrift.protocol.TMessageType.CALL, 0)); - echoI32_args args = new echoI32_args(); - args.setArg(arg); - args.write(prot); - prot.writeMessageEnd(); - } - - public int getResult() throws org.apache.thrift.TException { - if (getState() != org.apache.thrift.async.TAsyncMethodCall.State.RESPONSE_READ) { - throw new IllegalStateException("Method call not finished!"); - } - org.apache.thrift.transport.TMemoryInputTransport memoryTransport = new org.apache.thrift.transport.TMemoryInputTransport(getFrameBuffer().array()); - org.apache.thrift.protocol.TProtocol prot = client.getProtocolFactory().getProtocol(memoryTransport); - return (new Client(prot)).recv_echoI32(); - } - } - - public void echoI64(long arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException { - checkReady(); - echoI64_call method_call = new echoI64_call(arg, resultHandler, this, ___protocolFactory, ___transport); - this.___currentMethod = method_call; - ___manager.call(method_call); - } - - public static class echoI64_call extends org.apache.thrift.async.TAsyncMethodCall { - private long arg; - public echoI64_call(long arg, org.apache.thrift.async.AsyncMethodCallback resultHandler, org.apache.thrift.async.TAsyncClient client, org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.transport.TNonblockingTransport transport) throws org.apache.thrift.TException { - super(client, protocolFactory, transport, resultHandler, false); - this.arg = arg; - } - - public void write_args(org.apache.thrift.protocol.TProtocol prot) throws org.apache.thrift.TException { - prot.writeMessageBegin(new org.apache.thrift.protocol.TMessage("echoI64", org.apache.thrift.protocol.TMessageType.CALL, 0)); - echoI64_args args = new echoI64_args(); - args.setArg(arg); - args.write(prot); - prot.writeMessageEnd(); - } - - public long getResult() throws org.apache.thrift.TException { - if (getState() != org.apache.thrift.async.TAsyncMethodCall.State.RESPONSE_READ) { - throw new IllegalStateException("Method call not finished!"); - } - org.apache.thrift.transport.TMemoryInputTransport memoryTransport = new org.apache.thrift.transport.TMemoryInputTransport(getFrameBuffer().array()); - org.apache.thrift.protocol.TProtocol prot = client.getProtocolFactory().getProtocol(memoryTransport); - return (new Client(prot)).recv_echoI64(); - } - } - - public void echoDouble(double arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException { - checkReady(); - echoDouble_call method_call = new echoDouble_call(arg, resultHandler, this, ___protocolFactory, ___transport); - this.___currentMethod = method_call; - ___manager.call(method_call); - } - - public static class echoDouble_call extends org.apache.thrift.async.TAsyncMethodCall { - private double arg; - public echoDouble_call(double arg, org.apache.thrift.async.AsyncMethodCallback resultHandler, org.apache.thrift.async.TAsyncClient client, org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.transport.TNonblockingTransport transport) throws org.apache.thrift.TException { - super(client, protocolFactory, transport, resultHandler, false); - this.arg = arg; - } - - public void write_args(org.apache.thrift.protocol.TProtocol prot) throws org.apache.thrift.TException { - prot.writeMessageBegin(new org.apache.thrift.protocol.TMessage("echoDouble", org.apache.thrift.protocol.TMessageType.CALL, 0)); - echoDouble_args args = new echoDouble_args(); - args.setArg(arg); - args.write(prot); - prot.writeMessageEnd(); - } - - public double getResult() throws org.apache.thrift.TException { - if (getState() != org.apache.thrift.async.TAsyncMethodCall.State.RESPONSE_READ) { - throw new IllegalStateException("Method call not finished!"); - } - org.apache.thrift.transport.TMemoryInputTransport memoryTransport = new org.apache.thrift.transport.TMemoryInputTransport(getFrameBuffer().array()); - org.apache.thrift.protocol.TProtocol prot = client.getProtocolFactory().getProtocol(memoryTransport); - return (new Client(prot)).recv_echoDouble(); - } - } - - public void echoString(String arg, org.apache.thrift.async.AsyncMethodCallback resultHandler) throws org.apache.thrift.TException { - checkReady(); - echoString_call method_call = new echoString_call(arg, resultHandler, this, ___protocolFactory, ___transport); - this.___currentMethod = method_call; - ___manager.call(method_call); - } - - public static class echoString_call extends org.apache.thrift.async.TAsyncMethodCall { - private String arg; - public echoString_call(String arg, org.apache.thrift.async.AsyncMethodCallback resultHandler, org.apache.thrift.async.TAsyncClient client, org.apache.thrift.protocol.TProtocolFactory protocolFactory, org.apache.thrift.transport.TNonblockingTransport transport) throws org.apache.thrift.TException { - super(client, protocolFactory, transport, resultHandler, false); - this.arg = arg; - } - - public void write_args(org.apache.thrift.protocol.TProtocol prot) throws org.apache.thrift.TException { - prot.writeMessageBegin(new org.apache.thrift.protocol.TMessage("echoString", org.apache.thrift.protocol.TMessageType.CALL, 0)); - echoString_args args = new echoString_args(); - args.setArg(arg); - args.write(prot); - prot.writeMessageEnd(); - } - - public String getResult() throws org.apache.thrift.TException { - if (getState() != org.apache.thrift.async.TAsyncMethodCall.State.RESPONSE_READ) { - throw new IllegalStateException("Method call not finished!"); - } - org.apache.thrift.transport.TMemoryInputTransport memoryTransport = new org.apache.thrift.transport.TMemoryInputTransport(getFrameBuffer().array()); - org.apache.thrift.protocol.TProtocol prot = client.getProtocolFactory().getProtocol(memoryTransport); - return (new Client(prot)).recv_echoString(); - } - } - - } - - public static class Processor extends org.apache.thrift.TBaseProcessor implements org.apache.thrift.TProcessor { - private static final Logger LOGGER = LoggerFactory.getLogger(Processor.class.getName()); - public Processor(I iface) { - super(iface, getProcessMap(new HashMap>())); - } - - protected Processor(I iface, Map> processMap) { - super(iface, getProcessMap(processMap)); - } - - private static Map> getProcessMap(Map> processMap) { - processMap.put("echoBool", new echoBool()); - processMap.put("echoByte", new echoByte()); - processMap.put("echoI16", new echoI16()); - processMap.put("echoI32", new echoI32()); - processMap.put("echoI64", new echoI64()); - processMap.put("echoDouble", new echoDouble()); - processMap.put("echoString", new echoString()); - return processMap; - } - - private static class echoBool extends org.apache.thrift.ProcessFunction { - public echoBool() { - super("echoBool"); - } - - protected echoBool_args getEmptyArgsInstance() { - return new echoBool_args(); - } - - protected echoBool_result getResult(I iface, echoBool_args args) throws org.apache.thrift.TException { - echoBool_result result = new echoBool_result(); - result.success = iface.echoBool(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoByte extends org.apache.thrift.ProcessFunction { - public echoByte() { - super("echoByte"); - } - - protected echoByte_args getEmptyArgsInstance() { - return new echoByte_args(); - } - - protected echoByte_result getResult(I iface, echoByte_args args) throws org.apache.thrift.TException { - echoByte_result result = new echoByte_result(); - result.success = iface.echoByte(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoI16 extends org.apache.thrift.ProcessFunction { - public echoI16() { - super("echoI16"); - } - - protected echoI16_args getEmptyArgsInstance() { - return new echoI16_args(); - } - - protected echoI16_result getResult(I iface, echoI16_args args) throws org.apache.thrift.TException { - echoI16_result result = new echoI16_result(); - result.success = iface.echoI16(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoI32 extends org.apache.thrift.ProcessFunction { - public echoI32() { - super("echoI32"); - } - - protected echoI32_args getEmptyArgsInstance() { - return new echoI32_args(); - } - - protected echoI32_result getResult(I iface, echoI32_args args) throws org.apache.thrift.TException { - echoI32_result result = new echoI32_result(); - result.success = iface.echoI32(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoI64 extends org.apache.thrift.ProcessFunction { - public echoI64() { - super("echoI64"); - } - - protected echoI64_args getEmptyArgsInstance() { - return new echoI64_args(); - } - - protected echoI64_result getResult(I iface, echoI64_args args) throws org.apache.thrift.TException { - echoI64_result result = new echoI64_result(); - result.success = iface.echoI64(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoDouble extends org.apache.thrift.ProcessFunction { - public echoDouble() { - super("echoDouble"); - } - - protected echoDouble_args getEmptyArgsInstance() { - return new echoDouble_args(); - } - - protected echoDouble_result getResult(I iface, echoDouble_args args) throws org.apache.thrift.TException { - echoDouble_result result = new echoDouble_result(); - result.success = iface.echoDouble(args.arg); - result.setSuccessIsSet(true); - return result; - } - } - - private static class echoString extends org.apache.thrift.ProcessFunction { - public echoString() { - super("echoString"); - } - - protected echoString_args getEmptyArgsInstance() { - return new echoString_args(); - } - - protected echoString_result getResult(I iface, echoString_args args) throws org.apache.thrift.TException { - echoString_result result = new echoString_result(); - result.success = iface.echoString(args.arg); - return result; - } - } - - } - - public static class echoBool_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoBool_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.BOOL, (short)1); - - public boolean arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.BOOL))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoBool_args.class, metaDataMap); - } - - public echoBool_args() { - } - - public echoBool_args( - boolean arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoBool_args(echoBool_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoBool_args deepCopy() { - return new echoBool_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = false; - } - - public boolean isArg() { - return this.arg; - } - - public echoBool_args setArg(boolean arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Boolean)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Boolean.valueOf(isArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoBool_args) - return this.equals((echoBool_args)that); - return false; - } - - public boolean equals(echoBool_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoBool_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoBool_args typedOther = (echoBool_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.BOOL) { - this.arg = iprot.readBool(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeBool(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoBool_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoBool_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoBool_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.BOOL, (short)0); - - public boolean success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.BOOL))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoBool_result.class, metaDataMap); - } - - public echoBool_result() { - } - - public echoBool_result( - boolean success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoBool_result(echoBool_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoBool_result deepCopy() { - return new echoBool_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = false; - } - - public boolean isSuccess() { - return this.success; - } - - public echoBool_result setSuccess(boolean success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Boolean)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Boolean.valueOf(isSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoBool_result) - return this.equals((echoBool_result)that); - return false; - } - - public boolean equals(echoBool_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoBool_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoBool_result typedOther = (echoBool_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.BOOL) { - this.success = iprot.readBool(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeBool(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoBool_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoByte_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoByte_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.BYTE, (short)1); - - public byte arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.BYTE))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoByte_args.class, metaDataMap); - } - - public echoByte_args() { - } - - public echoByte_args( - byte arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoByte_args(echoByte_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoByte_args deepCopy() { - return new echoByte_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0; - } - - public byte getArg() { - return this.arg; - } - - public echoByte_args setArg(byte arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Byte)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Byte.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoByte_args) - return this.equals((echoByte_args)that); - return false; - } - - public boolean equals(echoByte_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoByte_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoByte_args typedOther = (echoByte_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.BYTE) { - this.arg = iprot.readByte(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeByte(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoByte_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoByte_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoByte_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.BYTE, (short)0); - - public byte success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.BYTE))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoByte_result.class, metaDataMap); - } - - public echoByte_result() { - } - - public echoByte_result( - byte success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoByte_result(echoByte_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoByte_result deepCopy() { - return new echoByte_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0; - } - - public byte getSuccess() { - return this.success; - } - - public echoByte_result setSuccess(byte success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Byte)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Byte.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoByte_result) - return this.equals((echoByte_result)that); - return false; - } - - public boolean equals(echoByte_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoByte_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoByte_result typedOther = (echoByte_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.BYTE) { - this.success = iprot.readByte(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeByte(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoByte_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI16_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI16_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.I16, (short)1); - - public short arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I16))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI16_args.class, metaDataMap); - } - - public echoI16_args() { - } - - public echoI16_args( - short arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI16_args(echoI16_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoI16_args deepCopy() { - return new echoI16_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0; - } - - public short getArg() { - return this.arg; - } - - public echoI16_args setArg(short arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Short)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Short.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI16_args) - return this.equals((echoI16_args)that); - return false; - } - - public boolean equals(echoI16_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI16_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI16_args typedOther = (echoI16_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.I16) { - this.arg = iprot.readI16(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeI16(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI16_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI16_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI16_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.I16, (short)0); - - public short success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I16))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI16_result.class, metaDataMap); - } - - public echoI16_result() { - } - - public echoI16_result( - short success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI16_result(echoI16_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoI16_result deepCopy() { - return new echoI16_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0; - } - - public short getSuccess() { - return this.success; - } - - public echoI16_result setSuccess(short success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Short)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Short.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI16_result) - return this.equals((echoI16_result)that); - return false; - } - - public boolean equals(echoI16_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI16_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI16_result typedOther = (echoI16_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.I16) { - this.success = iprot.readI16(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeI16(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI16_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI32_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI32_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.I32, (short)1); - - public int arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I32))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI32_args.class, metaDataMap); - } - - public echoI32_args() { - } - - public echoI32_args( - int arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI32_args(echoI32_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoI32_args deepCopy() { - return new echoI32_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0; - } - - public int getArg() { - return this.arg; - } - - public echoI32_args setArg(int arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Integer)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Integer.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI32_args) - return this.equals((echoI32_args)that); - return false; - } - - public boolean equals(echoI32_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI32_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI32_args typedOther = (echoI32_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.I32) { - this.arg = iprot.readI32(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeI32(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI32_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI32_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI32_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.I32, (short)0); - - public int success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I32))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI32_result.class, metaDataMap); - } - - public echoI32_result() { - } - - public echoI32_result( - int success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI32_result(echoI32_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoI32_result deepCopy() { - return new echoI32_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0; - } - - public int getSuccess() { - return this.success; - } - - public echoI32_result setSuccess(int success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Integer)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Integer.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI32_result) - return this.equals((echoI32_result)that); - return false; - } - - public boolean equals(echoI32_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI32_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI32_result typedOther = (echoI32_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.I32) { - this.success = iprot.readI32(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeI32(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI32_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI64_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI64_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.I64, (short)1); - - public long arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I64))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI64_args.class, metaDataMap); - } - - public echoI64_args() { - } - - public echoI64_args( - long arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI64_args(echoI64_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoI64_args deepCopy() { - return new echoI64_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0; - } - - public long getArg() { - return this.arg; - } - - public echoI64_args setArg(long arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Long)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Long.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI64_args) - return this.equals((echoI64_args)that); - return false; - } - - public boolean equals(echoI64_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI64_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI64_args typedOther = (echoI64_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.I64) { - this.arg = iprot.readI64(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeI64(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI64_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoI64_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoI64_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.I64, (short)0); - - public long success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.I64))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoI64_result.class, metaDataMap); - } - - public echoI64_result() { - } - - public echoI64_result( - long success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoI64_result(echoI64_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoI64_result deepCopy() { - return new echoI64_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0; - } - - public long getSuccess() { - return this.success; - } - - public echoI64_result setSuccess(long success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Long)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Long.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoI64_result) - return this.equals((echoI64_result)that); - return false; - } - - public boolean equals(echoI64_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoI64_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoI64_result typedOther = (echoI64_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.I64) { - this.success = iprot.readI64(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeI64(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoI64_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoDouble_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoDouble_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.DOUBLE, (short)1); - - public double arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __ARG_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.DOUBLE))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoDouble_args.class, metaDataMap); - } - - public echoDouble_args() { - } - - public echoDouble_args( - double arg) - { - this(); - this.arg = arg; - setArgIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoDouble_args(echoDouble_args other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.arg = other.arg; - } - - public echoDouble_args deepCopy() { - return new echoDouble_args(this); - } - - - public void clear() { - setArgIsSet(false); - this.arg = 0.0; - } - - public double getArg() { - return this.arg; - } - - public echoDouble_args setArg(double arg) { - this.arg = arg; - setArgIsSet(true); - return this; - } - - public void unsetArg() { - __isset_bit_vector.clear(__ARG_ISSET_ID); - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return __isset_bit_vector.get(__ARG_ISSET_ID); - } - - public void setArgIsSet(boolean value) { - __isset_bit_vector.set(__ARG_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((Double)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return Double.valueOf(getArg()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoDouble_args) - return this.equals((echoDouble_args)that); - return false; - } - - public boolean equals(echoDouble_args that) { - if (that == null) - return false; - - boolean this_present_arg = true; - boolean that_present_arg = true; - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (this.arg != that.arg) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoDouble_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoDouble_args typedOther = (echoDouble_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.DOUBLE) { - this.arg = iprot.readDouble(); - setArgIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - if (!isSetArg()) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not found in serialized data! Struct: " + toString()); - } - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeDouble(this.arg); - oprot.writeFieldEnd(); - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoDouble_args("); - boolean first = true; - - sb.append("arg:"); - sb.append(this.arg); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - // alas, we cannot check 'arg' because it's a primitive and you chose the non-beans generator. - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - // it doesn't seem like you should have to do this, but java serialization is wacky, and doesn't call the default constructor. - __isset_bit_vector = new BitSet(1); - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoDouble_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoDouble_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.DOUBLE, (short)0); - - public double success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - private static final int __SUCCESS_ISSET_ID = 0; - private BitSet __isset_bit_vector = new BitSet(1); - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.DOUBLE))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoDouble_result.class, metaDataMap); - } - - public echoDouble_result() { - } - - public echoDouble_result( - double success) - { - this(); - this.success = success; - setSuccessIsSet(true); - } - - /** - * Performs a deep copy on other. - */ - public echoDouble_result(echoDouble_result other) { - __isset_bit_vector.clear(); - __isset_bit_vector.or(other.__isset_bit_vector); - this.success = other.success; - } - - public echoDouble_result deepCopy() { - return new echoDouble_result(this); - } - - - public void clear() { - setSuccessIsSet(false); - this.success = 0.0; - } - - public double getSuccess() { - return this.success; - } - - public echoDouble_result setSuccess(double success) { - this.success = success; - setSuccessIsSet(true); - return this; - } - - public void unsetSuccess() { - __isset_bit_vector.clear(__SUCCESS_ISSET_ID); - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return __isset_bit_vector.get(__SUCCESS_ISSET_ID); - } - - public void setSuccessIsSet(boolean value) { - __isset_bit_vector.set(__SUCCESS_ISSET_ID, value); - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((Double)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return Double.valueOf(getSuccess()); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoDouble_result) - return this.equals((echoDouble_result)that); - return false; - } - - public boolean equals(echoDouble_result that) { - if (that == null) - return false; - - boolean this_present_success = true; - boolean that_present_success = true; - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (this.success != that.success) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoDouble_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoDouble_result typedOther = (echoDouble_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.DOUBLE) { - this.success = iprot.readDouble(); - setSuccessIsSet(true); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeDouble(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoDouble_result("); - boolean first = true; - - sb.append("success:"); - sb.append(this.success); - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoString_args implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoString_args"); - - private static final org.apache.thrift.protocol.TField ARG_FIELD_DESC = new org.apache.thrift.protocol.TField("arg", org.apache.thrift.protocol.TType.STRING, (short)1); - - public String arg; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - ARG((short)1, "arg"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 1: // ARG - return ARG; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.ARG, new org.apache.thrift.meta_data.FieldMetaData("arg", org.apache.thrift.TFieldRequirementType.REQUIRED, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.STRING))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoString_args.class, metaDataMap); - } - - public echoString_args() { - } - - public echoString_args( - String arg) - { - this(); - this.arg = arg; - } - - /** - * Performs a deep copy on other. - */ - public echoString_args(echoString_args other) { - if (other.isSetArg()) { - this.arg = other.arg; - } - } - - public echoString_args deepCopy() { - return new echoString_args(this); - } - - - public void clear() { - this.arg = null; - } - - public String getArg() { - return this.arg; - } - - public echoString_args setArg(String arg) { - this.arg = arg; - return this; - } - - public void unsetArg() { - this.arg = null; - } - - /** Returns true if field arg is set (has been assigned a value) and false otherwise */ - public boolean isSetArg() { - return this.arg != null; - } - - public void setArgIsSet(boolean value) { - if (!value) { - this.arg = null; - } - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case ARG: - if (value == null) { - unsetArg(); - } else { - setArg((String)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case ARG: - return getArg(); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case ARG: - return isSetArg(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoString_args) - return this.equals((echoString_args)that); - return false; - } - - public boolean equals(echoString_args that) { - if (that == null) - return false; - - boolean this_present_arg = true && this.isSetArg(); - boolean that_present_arg = true && that.isSetArg(); - if (this_present_arg || that_present_arg) { - if (!(this_present_arg && that_present_arg)) - return false; - if (!this.arg.equals(that.arg)) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoString_args other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoString_args typedOther = (echoString_args)other; - - lastComparison = Boolean.valueOf(isSetArg()).compareTo(typedOther.isSetArg()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetArg()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.arg, typedOther.arg); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 1: // ARG - if (field.type == org.apache.thrift.protocol.TType.STRING) { - this.arg = iprot.readString(); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - validate(); - - oprot.writeStructBegin(STRUCT_DESC); - if (this.arg != null) { - oprot.writeFieldBegin(ARG_FIELD_DESC); - oprot.writeString(this.arg); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoString_args("); - boolean first = true; - - sb.append("arg:"); - if (this.arg == null) { - sb.append("null"); - } else { - sb.append(this.arg); - } - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - if (arg == null) { - throw new org.apache.thrift.protocol.TProtocolException("Required field 'arg' was not present! Struct: " + toString()); - } - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - - public static class echoString_result implements org.apache.thrift.TBase, java.io.Serializable, Cloneable { - private static final org.apache.thrift.protocol.TStruct STRUCT_DESC = new org.apache.thrift.protocol.TStruct("echoString_result"); - - private static final org.apache.thrift.protocol.TField SUCCESS_FIELD_DESC = new org.apache.thrift.protocol.TField("success", org.apache.thrift.protocol.TType.STRING, (short)0); - - public String success; // required - - /** The set of fields this struct contains, along with convenience methods for finding and manipulating them. */ - public enum _Fields implements org.apache.thrift.TFieldIdEnum { - SUCCESS((short)0, "success"); - - private static final Map byName = new HashMap(); - - static { - for (_Fields field : EnumSet.allOf(_Fields.class)) { - byName.put(field.getFieldName(), field); - } - } - - /** - * Find the _Fields constant that matches fieldId, or null if its not found. - */ - public static _Fields findByThriftId(int fieldId) { - switch(fieldId) { - case 0: // SUCCESS - return SUCCESS; - default: - return null; - } - } - - /** - * Find the _Fields constant that matches fieldId, throwing an exception - * if it is not found. - */ - public static _Fields findByThriftIdOrThrow(int fieldId) { - _Fields fields = findByThriftId(fieldId); - if (fields == null) throw new IllegalArgumentException("Field " + fieldId + " doesn't exist!"); - return fields; - } - - /** - * Find the _Fields constant that matches name, or null if its not found. - */ - public static _Fields findByName(String name) { - return byName.get(name); - } - - private final short _thriftId; - private final String _fieldName; - - _Fields(short thriftId, String fieldName) { - _thriftId = thriftId; - _fieldName = fieldName; - } - - public short getThriftFieldId() { - return _thriftId; - } - - public String getFieldName() { - return _fieldName; - } - } - - // isset id assignments - - public static final Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> metaDataMap; - static { - Map<_Fields, org.apache.thrift.meta_data.FieldMetaData> tmpMap = new EnumMap<_Fields, org.apache.thrift.meta_data.FieldMetaData>(_Fields.class); - tmpMap.put(_Fields.SUCCESS, new org.apache.thrift.meta_data.FieldMetaData("success", org.apache.thrift.TFieldRequirementType.DEFAULT, - new org.apache.thrift.meta_data.FieldValueMetaData(org.apache.thrift.protocol.TType.STRING))); - metaDataMap = Collections.unmodifiableMap(tmpMap); - org.apache.thrift.meta_data.FieldMetaData.addStructMetaDataMap(echoString_result.class, metaDataMap); - } - - public echoString_result() { - } - - public echoString_result( - String success) - { - this(); - this.success = success; - } - - /** - * Performs a deep copy on other. - */ - public echoString_result(echoString_result other) { - if (other.isSetSuccess()) { - this.success = other.success; - } - } - - public echoString_result deepCopy() { - return new echoString_result(this); - } - - - public void clear() { - this.success = null; - } - - public String getSuccess() { - return this.success; - } - - public echoString_result setSuccess(String success) { - this.success = success; - return this; - } - - public void unsetSuccess() { - this.success = null; - } - - /** Returns true if field success is set (has been assigned a value) and false otherwise */ - public boolean isSetSuccess() { - return this.success != null; - } - - public void setSuccessIsSet(boolean value) { - if (!value) { - this.success = null; - } - } - - public void setFieldValue(_Fields field, Object value) { - switch (field) { - case SUCCESS: - if (value == null) { - unsetSuccess(); - } else { - setSuccess((String)value); - } - break; - - } - } - - public Object getFieldValue(_Fields field) { - switch (field) { - case SUCCESS: - return getSuccess(); - - } - throw new IllegalStateException(); - } - - /** Returns true if field corresponding to fieldID is set (has been assigned a value) and false otherwise */ - public boolean isSet(_Fields field) { - if (field == null) { - throw new IllegalArgumentException(); - } - - switch (field) { - case SUCCESS: - return isSetSuccess(); - } - throw new IllegalStateException(); - } - - - public boolean equals(Object that) { - if (that == null) - return false; - if (that instanceof echoString_result) - return this.equals((echoString_result)that); - return false; - } - - public boolean equals(echoString_result that) { - if (that == null) - return false; - - boolean this_present_success = true && this.isSetSuccess(); - boolean that_present_success = true && that.isSetSuccess(); - if (this_present_success || that_present_success) { - if (!(this_present_success && that_present_success)) - return false; - if (!this.success.equals(that.success)) - return false; - } - - return true; - } - - - public int hashCode() { - return 0; - } - - public int compareTo(echoString_result other) { - if (!getClass().equals(other.getClass())) { - return getClass().getName().compareTo(other.getClass().getName()); - } - - int lastComparison = 0; - echoString_result typedOther = (echoString_result)other; - - lastComparison = Boolean.valueOf(isSetSuccess()).compareTo(typedOther.isSetSuccess()); - if (lastComparison != 0) { - return lastComparison; - } - if (isSetSuccess()) { - lastComparison = org.apache.thrift.TBaseHelper.compareTo(this.success, typedOther.success); - if (lastComparison != 0) { - return lastComparison; - } - } - return 0; - } - - public _Fields fieldForId(int fieldId) { - return _Fields.findByThriftId(fieldId); - } - - public void read(org.apache.thrift.protocol.TProtocol iprot) throws org.apache.thrift.TException { - org.apache.thrift.protocol.TField field; - iprot.readStructBegin(); - while (true) - { - field = iprot.readFieldBegin(); - if (field.type == org.apache.thrift.protocol.TType.STOP) { - break; - } - switch (field.id) { - case 0: // SUCCESS - if (field.type == org.apache.thrift.protocol.TType.STRING) { - this.success = iprot.readString(); - } else { - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - break; - default: - org.apache.thrift.protocol.TProtocolUtil.skip(iprot, field.type); - } - iprot.readFieldEnd(); - } - iprot.readStructEnd(); - - // check for required fields of primitive type, which can't be checked in the validate method - validate(); - } - - public void write(org.apache.thrift.protocol.TProtocol oprot) throws org.apache.thrift.TException { - oprot.writeStructBegin(STRUCT_DESC); - - if (this.isSetSuccess()) { - oprot.writeFieldBegin(SUCCESS_FIELD_DESC); - oprot.writeString(this.success); - oprot.writeFieldEnd(); - } - oprot.writeFieldStop(); - oprot.writeStructEnd(); - } - - - public String toString() { - StringBuilder sb = new StringBuilder("echoString_result("); - boolean first = true; - - sb.append("success:"); - if (this.success == null) { - sb.append("null"); - } else { - sb.append(this.success); - } - first = false; - sb.append(")"); - return sb.toString(); - } - - public void validate() throws org.apache.thrift.TException { - // check for required fields - } - - private void writeObject(java.io.ObjectOutputStream out) throws java.io.IOException { - try { - write(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(out))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - private void readObject(java.io.ObjectInputStream in) throws java.io.IOException, ClassNotFoundException { - try { - read(new org.apache.thrift.protocol.TCompactProtocol(new org.apache.thrift.transport.TIOStreamTransport(in))); - } catch (org.apache.thrift.TException te) { - throw new java.io.IOException(te); - } - } - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/AbstractTest.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/AbstractTest.java deleted file mode 100644 index 6b68d331b29..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/AbstractTest.java +++ /dev/null @@ -1,137 +0,0 @@ -/** - * File Created at 2011-11-25 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Protocol; -import com.alibaba.dubbo.rpc.gen.dubbo.$__DemoStub; -import com.alibaba.dubbo.rpc.gen.dubbo.Demo; -import com.alibaba.dubbo.rpc.protocol.thrift.ext.MultiServiceProcessor; -import org.apache.thrift.TProcessor; -import org.apache.thrift.protocol.TBinaryProtocol; -import org.apache.thrift.server.TServer; -import org.apache.thrift.server.TThreadPoolServer; -import org.apache.thrift.transport.TServerSocket; -import org.apache.thrift.transport.TServerTransport; -import org.apache.thrift.transport.TTransportFactory; -import org.junit.After; -import org.junit.Before; - -/** - * @author gang.lvg 2011-11-25 13:05 - */ -public abstract class AbstractTest { - - static final int PORT = 30660; - - protected TServer server; - - protected Protocol protocol; - - protected Invoker invoker; - - protected void init() throws Exception { - TServerTransport serverTransport = new TServerSocket( PORT ); - - TBinaryProtocol.Factory bFactory = new TBinaryProtocol.Factory(); - - server = new TThreadPoolServer( - new TThreadPoolServer.Args( serverTransport ) - .inputProtocolFactory( bFactory ) - .outputProtocolFactory( bFactory ) - .inputTransportFactory( getTransportFactory() ) - .outputTransportFactory( getTransportFactory() ) - .processor( getProcessor() ) ); - - Thread startTread = new Thread() { - - @Override - public void run() { - server.serve(); - } - - }; - - startTread.setName( "thrift-server" ); - - startTread.start(); - - while( !server.isServing() ) { - Thread.sleep( 100 ); - } - - protocol = ExtensionLoader.getExtensionLoader(Protocol.class) - .getExtension( ThriftProtocol.NAME ); - - invoker = protocol.refer( getInterface(), getUrl() ); - - } - - protected void destroy() throws Exception { - - if ( server != null ) { - server.stop(); - server = null; - } - - if ( protocol != null ) { - protocol.destroy(); - protocol = null; - } - - if ( invoker != null ) { - invoker.destroy(); - invoker = null; - } - - } - - protected TTransportFactory getTransportFactory() { - return new FramedTransportFactory(); - } - - protected $__DemoStub.Iface getServiceImpl() { - return new DubboDemoImpl(); - } - - protected TProcessor getProcessor() { - MultiServiceProcessor result = new MultiServiceProcessor(); - result.addProcessor( - com.alibaba.dubbo.rpc.gen.dubbo.Demo.class, - new $__DemoStub.Processor( getServiceImpl() ) ); - return result; - } - - protected Class getInterface() { - return Demo.class; - } - - protected URL getUrl() { - return URL.valueOf( - "thrift://127.0.0.1:" + PORT + "/" + getInterface().getName() ); - } - - @After - public void tearDown() throws Exception{ - destroy(); - } - - @Before - public void setUp() throws Exception { - init(); - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/DemoImpl.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/DemoImpl.java deleted file mode 100644 index 983e5799d92..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/DemoImpl.java +++ /dev/null @@ -1,56 +0,0 @@ -/** - * File Created at 2011-11-23 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -/** - * @author gang.lvg 2011-11-23 14:17 - */ -public class DemoImpl { - - public boolean echoBool( boolean arg ) { - - return arg; - } - - public byte echoByte( byte arg ) { - - return arg; - } - - public short echoI16( short arg ) { - - return arg; - } - - public int echoI32( int arg ) { - - return arg; - } - - public long echoI64( long arg ) { - - return arg; - } - - public double echoDouble( double arg ) { - - return arg; - } - - public String echoString( String arg ) { - - return arg; - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/DubboDemoImpl.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/DubboDemoImpl.java deleted file mode 100644 index 37c7a056d76..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/DubboDemoImpl.java +++ /dev/null @@ -1,22 +0,0 @@ -/** - * File Created at 2011-12-31 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.rpc.gen.dubbo.$__DemoStub; -import com.alibaba.dubbo.rpc.gen.dubbo.Demo; - -/** - * @author kimi - */ -public class DubboDemoImpl extends DemoImpl implements Demo, $__DemoStub.Iface {} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/FramedTransportFactory.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/FramedTransportFactory.java deleted file mode 100644 index 2ca4a5b54f6..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/FramedTransportFactory.java +++ /dev/null @@ -1,30 +0,0 @@ -/** - * File Created at 2011-12-09 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import org.apache.thrift.transport.TFramedTransport; -import org.apache.thrift.transport.TTransport; -import org.apache.thrift.transport.TTransportFactory; - -/** - * @author kimi - */ -public class FramedTransportFactory extends TTransportFactory { - - @Override - public TTransport getTransport( TTransport trans ) { - - return new TFramedTransport( trans ); - } -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/MockedChannel.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/MockedChannel.java deleted file mode 100644 index 062dc67b6d7..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/MockedChannel.java +++ /dev/null @@ -1,97 +0,0 @@ -/** - * File Created at 2011-12-06 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.ChannelHandler; -import com.alibaba.dubbo.remoting.RemotingException; - -import java.net.InetSocketAddress; - -/** - * @author gang.lvg - */ -public class MockedChannel implements Channel { - - private URL url; - - public MockedChannel( URL url ) { - this.url = url; - } - - public InetSocketAddress getRemoteAddress() { - - return null; - } - - public boolean isConnected() { - - return false; - } - - public boolean hasAttribute( String key ) { - - return false; - } - - public Object getAttribute( String key ) { - - return null; - } - - public void setAttribute( String key, Object value ) { - - } - - public void removeAttribute( String key ) { - - } - - public URL getUrl() { - return url; - } - - public ChannelHandler getChannelHandler() { - - return null; - } - - public InetSocketAddress getLocalAddress() { - - return null; - } - - public void send( Object message ) throws RemotingException { - - } - - public void send( Object message, boolean sent ) throws RemotingException { - - } - - public void close() { - - } - - public void close( int timeout ) { - - } - - public boolean isClosed() { - - return false; - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ServerExceptionTest.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ServerExceptionTest.java deleted file mode 100644 index 58ecbe1520b..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ServerExceptionTest.java +++ /dev/null @@ -1,99 +0,0 @@ -/** - * File Created at 2011-12-09 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.gen.dubbo.$__DemoStub; -import org.junit.Assert; -import org.junit.Test; - -/** - * @author kimi - */ -public class ServerExceptionTest extends AbstractTest { - - @Override - protected $__DemoStub.Iface getServiceImpl() { - - return new $__DemoStub.Iface () { - - public boolean echoBool( boolean arg ) { - - return false; - } - - public byte echoByte( byte arg ) { - - return 0; - } - - public short echoI16( short arg ) { - - return 0; - } - - public int echoI32( int arg ) { - - return 0; - } - - public long echoI64( long arg ) { - - return 0; - } - - public double echoDouble( double arg ) { - return 0; - } - - public String echoString( String arg ) { - // 在 server 端,thrift 无法处理 idl 中没有声明的异常 - throw new RuntimeException( "just for test" ); - } - }; - - } - - @Test( expected = RpcException.class ) - public void testServerException() throws Exception { - - Assert.assertNotNull( invoker ); - - RpcInvocation invocation = new RpcInvocation(); - - invocation.setMethodName( "echoString" ); - - invocation.setParameterTypes( new Class[]{ String.class } ); - - String arg = "Hello, World!"; - - invocation.setArguments( new Object[] { arg } ); - - Result result = invoker.invoke( invocation ); - - System.out.println( result ); - - } - - @Override - protected URL getUrl() { - URL url = super.getUrl(); -// url = url.addParameter( Constants.TIMEOUT_KEY, Integer.MAX_VALUE ); - return url; - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ServiceMethodNotFoundTest.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ServiceMethodNotFoundTest.java deleted file mode 100644 index 224e1c8a93c..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ServiceMethodNotFoundTest.java +++ /dev/null @@ -1,151 +0,0 @@ -/** - * File Created at 2011-12-09 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.gen.dubbo.$__DemoStub; -import com.alibaba.dubbo.rpc.gen.dubbo.Demo; -import com.alibaba.dubbo.rpc.protocol.thrift.ext.MultiServiceProcessor; -import org.apache.thrift.protocol.TBinaryProtocol; -import org.apache.thrift.server.TThreadPoolServer; -import org.apache.thrift.transport.TServerSocket; -import org.apache.thrift.transport.TServerTransport; -import org.junit.After; -import org.junit.Assert; -import org.junit.Before; -import org.junit.Test; - -import java.lang.reflect.Field; -import java.util.Map; - -/** - * @author kimi - */ -public class ServiceMethodNotFoundTest extends AbstractTest { - - private URL url; - - protected void init() throws Exception { - - TServerTransport serverTransport = new TServerSocket( PORT ); - - DubboDemoImpl impl = new DubboDemoImpl(); - - $__DemoStub.Processor processor = new $__DemoStub.Processor( impl ); - - // for test - Field field = processor.getClass().getSuperclass().getDeclaredField( "processMap" ); - - field.setAccessible( true ); - - Object obj = field.get( processor ); - - if ( obj instanceof Map ) { - ( ( Map ) obj ).remove( "echoString" ); - } - // ~ - - TBinaryProtocol.Factory bFactory = new TBinaryProtocol.Factory(); - - MultiServiceProcessor wrapper = new MultiServiceProcessor(); - wrapper.addProcessor( Demo.class, processor ); - - server = new TThreadPoolServer( - new TThreadPoolServer.Args( serverTransport ) - .inputProtocolFactory( bFactory ) - .outputProtocolFactory( bFactory ) - .inputTransportFactory( getTransportFactory() ) - .outputTransportFactory( getTransportFactory() ) - .processor( wrapper ) ); - - Thread startTread = new Thread() { - - @Override - public void run() { - - server.serve(); - } - - }; - - startTread.start(); - - while ( !server.isServing() ) { - Thread.sleep( 100 ); - } - - } - - @Before - public void setUp() throws Exception { - - init(); - - protocol = new ThriftProtocol(); - - url = URL.valueOf( ThriftProtocol.NAME + "://127.0.0.1:" + PORT + "/" + Demo.class.getName() ); - - } - - @After - public void tearDown() throws Exception { - - destroy(); - - if ( protocol != null ) { - protocol.destroy(); - protocol = null; - } - - if ( invoker != null ) { - invoker.destroy(); - invoker = null; - } - - } - - @Test - public void testServiceMethodNotFound() throws Exception { - // FIXME - /*url = url.addParameter( "echoString." + Constants.TIMEOUT_KEY, Integer.MAX_VALUE ); - - invoker = protocol.refer( Demo.class, url ); - - org.junit.Assert.assertNotNull( invoker ); - - RpcInvocation invocation = new RpcInvocation(); - - invocation.setMethodName( "echoString" ); - - invocation.setParameterTypes( new Class[]{ String.class } ); - - String arg = "Hello, World!"; - - invocation.setArguments( new Object[] { arg } ); - - invocation.setAttachment(Constants.INTERFACE_KEY, DemoImpl.class.getName()); - - Result result = invoker.invoke( invocation ); - - Assert.assertNull( result.getResult() ); - - Assert.assertTrue( result.getException() instanceof RpcException );*/ - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftCodecTest.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftCodecTest.java deleted file mode 100644 index 4b0ecdaa0d1..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftCodecTest.java +++ /dev/null @@ -1,460 +0,0 @@ -/** - * File Created at 2011-12-05 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import java.io.ByteArrayInputStream; - -import org.apache.thrift.TApplicationException; -import org.apache.thrift.protocol.TBinaryProtocol; -import org.apache.thrift.protocol.TMessage; -import org.apache.thrift.protocol.TMessageType; -import org.apache.thrift.transport.TFramedTransport; -import org.apache.thrift.transport.TIOStreamTransport; -import org.apache.thrift.transport.TTransport; -import org.junit.Assert; -import org.junit.Test; - -import com.alibaba.dubbo.common.Constants; -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.buffer.ChannelBuffer; -import com.alibaba.dubbo.remoting.buffer.ChannelBuffers; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; -import com.alibaba.dubbo.remoting.exchange.support.DefaultFuture; -import com.alibaba.dubbo.rpc.RpcException; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.RpcResult; -import com.alibaba.dubbo.rpc.gen.thrift.Demo; -import com.alibaba.dubbo.rpc.protocol.thrift.io.RandomAccessByteArrayOutputStream; - -/** - * @author gang.lvg - */ -public class ThriftCodecTest { - - private ThriftCodec codec = new ThriftCodec(); - private Channel channel = new MockedChannel(URL.valueOf("thrift://127.0.0.1")); - - @Test - public void testEncodeRequest() throws Exception { - - Request request = createRequest(); - - ChannelBuffer output = ChannelBuffers.dynamicBuffer(1024); - - codec.encode( channel, output, request ); - - byte[] bytes = new byte[output.readableBytes()]; - output.readBytes(bytes); - - ByteArrayInputStream bis = new ByteArrayInputStream( bytes ); - - TTransport transport = new TIOStreamTransport( bis ); - - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - // frame - byte[] length = new byte[4]; - transport.read( length, 0, 4 ); - - if ( bis.markSupported() ) { - bis.mark( 0 ); - } - - // magic - Assert.assertEquals( ThriftCodec.MAGIC, protocol.readI16() ); - - // message length - int messageLength = protocol.readI32(); - Assert.assertEquals( messageLength + 4, bytes.length ); - - // header length - short headerLength = protocol.readI16(); - // version - Assert.assertEquals( ThriftCodec.VERSION, protocol.readByte() ); - // service name - Assert.assertEquals( Demo.Iface.class.getName(), protocol.readString() ); - // dubbo request id - Assert.assertEquals( request.getId(), protocol.readI64() ); - - // test message header length - if ( bis.markSupported() ) { - bis.reset(); - bis.skip( headerLength ); - } - - TMessage message = protocol.readMessageBegin(); - - Demo.echoString_args args = new Demo.echoString_args(); - - args.read( protocol ); - - protocol.readMessageEnd(); - - Assert.assertEquals( "echoString", message.name ); - - Assert.assertEquals( TMessageType.CALL, message.type ); - - Assert.assertEquals( "Hello, World!", args.getArg() ); - - } - - @Test - public void testDecodeReplyResponse() throws Exception { - - URL url = URL.valueOf( ThriftProtocol.NAME + "://127.0.0.1:40880/" + Demo.Iface.class.getName() ); - - Channel channel = new MockedChannel( url ); - - RandomAccessByteArrayOutputStream bos = new RandomAccessByteArrayOutputStream( 128 ); - - Request request = createRequest(); - - DefaultFuture future = new DefaultFuture( channel, request, 10 ); - - TMessage message = new TMessage( "echoString", TMessageType.REPLY, ThriftCodec.getSeqId() ); - - Demo.echoString_result methodResult = new Demo.echoString_result(); - - methodResult.success = "Hello, World!"; - - TTransport transport = new TIOStreamTransport( bos ); - - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - int messageLength, headerLength; - // prepare - protocol.writeI16( ThriftCodec.MAGIC ); - protocol.writeI32( Integer.MAX_VALUE ); - protocol.writeI16( Short.MAX_VALUE ); - protocol.writeByte( ThriftCodec.VERSION ); - protocol.writeString( Demo.Iface.class.getName() ); - protocol.writeI64( request.getId() ); - protocol.getTransport().flush(); - headerLength = bos.size(); - - protocol.writeMessageBegin( message ); - methodResult.write( protocol ); - protocol.writeMessageEnd(); - protocol.getTransport().flush(); - int oldIndex = messageLength = bos.size(); - - try { - bos.setWriteIndex( ThriftCodec.MESSAGE_LENGTH_INDEX ); - protocol.writeI32( messageLength ); - bos.setWriteIndex( ThriftCodec.MESSAGE_HEADER_LENGTH_INDEX ); - protocol.writeI16( ( short ) ( 0xffff & headerLength ) ); - } finally { - bos.setWriteIndex( oldIndex ); - } - // prepare - - byte[] buf = new byte[ 4 + bos.size()]; - System.arraycopy( bos.toByteArray(), 0, buf, 4, bos.size() ); - - ChannelBuffer bis = ChannelBuffers.wrappedBuffer(buf); - - Object obj = codec.decode( ( Channel ) null, bis ); - - Assert.assertNotNull( obj ); - - Assert.assertEquals( true, obj instanceof Response ); - - Response response = ( Response ) obj; - - Assert.assertEquals( request.getId(), response.getId() ); - - Assert.assertTrue( response.getResult() instanceof RpcResult ); - - RpcResult result = ( RpcResult ) response.getResult(); - - Assert.assertTrue( result.getResult() instanceof String ); - - Assert.assertEquals( methodResult.success, result.getResult() ); - - } - - @Test - public void testDecodeExceptionResponse() throws Exception { - - URL url = URL.valueOf( ThriftProtocol.NAME + "://127.0.0.1:40880/" + Demo.class.getName() ); - - Channel channel = new MockedChannel( url ); - - RandomAccessByteArrayOutputStream bos = new RandomAccessByteArrayOutputStream( 128 ); - - Request request = createRequest(); - - DefaultFuture future = new DefaultFuture( channel, request, 10 ); - - TMessage message = new TMessage( "echoString", TMessageType.EXCEPTION, ThriftCodec.getSeqId() ); - - TTransport transport = new TIOStreamTransport( bos ); - - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - TApplicationException exception = new TApplicationException(); - - int messageLength, headerLength; - // prepare - protocol.writeI16( ThriftCodec.MAGIC ); - protocol.writeI32( Integer.MAX_VALUE ); - protocol.writeI16( Short.MAX_VALUE ); - protocol.writeByte( ThriftCodec.VERSION ); - protocol.writeString( Demo.class.getName() ); - protocol.writeI64( request.getId() ); - protocol.getTransport().flush(); - headerLength = bos.size(); - - protocol.writeMessageBegin( message ); - exception.write( protocol ); - protocol.writeMessageEnd(); - protocol.getTransport().flush(); - int oldIndex = messageLength = bos.size(); - - try { - bos.setWriteIndex( ThriftCodec.MESSAGE_LENGTH_INDEX ); - protocol.writeI32( messageLength ); - bos.setWriteIndex( ThriftCodec.MESSAGE_HEADER_LENGTH_INDEX ); - protocol.writeI16( ( short ) ( 0xffff & headerLength ) ); - } finally { - bos.setWriteIndex( oldIndex ); - } - // prepare - - ChannelBuffer bis = ChannelBuffers.wrappedBuffer(encodeFrame(bos.toByteArray())); - - Object obj = codec.decode( ( Channel ) null, bis ); - - Assert.assertNotNull( obj ); - - Assert.assertTrue( obj instanceof Response ); - - Response response = ( Response ) obj; - - Assert.assertTrue( response.getResult() instanceof RpcResult ); - - RpcResult result = ( RpcResult ) response.getResult(); - - Assert.assertTrue( result.hasException() ); - - Assert.assertTrue( result.getException() instanceof RpcException ); - - } - - @Test - public void testEncodeReplyResponse() throws Exception { - - URL url = URL.valueOf( ThriftProtocol.NAME + "://127.0.0.1:40880/" + Demo.Iface.class.getName() ); - - Channel channel = new MockedChannel( url ); - - Request request = createRequest(); - - RpcResult rpcResult = new RpcResult(); - rpcResult.setResult( "Hello, World!" ); - - Response response = new Response(); - response.setResult( rpcResult ); - response.setId( request.getId() ); - ChannelBuffer bos = ChannelBuffers.dynamicBuffer(1024); - - ThriftCodec.RequestData rd = ThriftCodec.RequestData.create( - ThriftCodec.getSeqId(), Demo.Iface.class.getName(), "echoString" ); - ThriftCodec.cachedRequest.putIfAbsent( request.getId(), rd ); - codec.encode( channel, bos, response ); - - byte[] buf = new byte[bos.writerIndex() - 4]; - System.arraycopy( bos.array(), 4, buf, 0, bos.writerIndex() - 4 ); - - ByteArrayInputStream bis = new ByteArrayInputStream( buf ); - - if ( bis.markSupported() ) { - bis.mark( 0 ); - } - - TIOStreamTransport transport = new TIOStreamTransport( bis ); - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - Assert.assertEquals( ThriftCodec.MAGIC, protocol.readI16() ); - Assert.assertEquals( protocol.readI32() + 4, bos.writerIndex() ); - int headerLength = protocol.readI16(); - - Assert.assertEquals( ThriftCodec.VERSION, protocol.readByte() ); - Assert.assertEquals( Demo.Iface.class.getName(), protocol.readString() ); - Assert.assertEquals( request.getId(), protocol.readI64() ); - - if ( bis.markSupported() ) { - bis.reset(); - bis.skip( headerLength ); - } - - TMessage message = protocol.readMessageBegin(); - Assert.assertEquals( "echoString", message.name ); - Assert.assertEquals( TMessageType.REPLY, message.type ); - Assert.assertEquals( ThriftCodec.getSeqId(), message.seqid ); - Demo.echoString_result result = new Demo.echoString_result(); - result.read( protocol ); - protocol.readMessageEnd(); - - Assert.assertEquals( rpcResult.getValue(), result.getSuccess() ); - } - - @Test - public void testEncodeExceptionResponse() throws Exception { - - URL url = URL.valueOf( ThriftProtocol.NAME + "://127.0.0.1:40880/" + Demo.Iface.class.getName() ); - - Channel channel = new MockedChannel( url ); - - Request request = createRequest(); - - RpcResult rpcResult = new RpcResult(); - String exceptionMessage = "failed"; - rpcResult.setException( new RuntimeException( exceptionMessage ) ); - - Response response = new Response(); - response.setResult( rpcResult ); - response.setId( request.getId() ); - ChannelBuffer bos = ChannelBuffers.dynamicBuffer(1024); - - ThriftCodec.RequestData rd = ThriftCodec.RequestData.create( - ThriftCodec.getSeqId(), Demo.Iface.class.getName(), "echoString" ); - ThriftCodec.cachedRequest.put( request.getId(), rd ); - codec.encode( channel, bos, response ); - - byte[] buf = new byte[bos.writerIndex() - 4]; - System.arraycopy( bos.array(), 4, buf, 0, bos.writerIndex() - 4 ); - ByteArrayInputStream bis = new ByteArrayInputStream( buf); - - if ( bis.markSupported() ) { - bis.mark( 0 ); - } - - TIOStreamTransport transport = new TIOStreamTransport( bis ); - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - Assert.assertEquals( ThriftCodec.MAGIC, protocol.readI16() ); - Assert.assertEquals( protocol.readI32() + 4, bos.writerIndex() ); - int headerLength = protocol.readI16(); - - Assert.assertEquals( ThriftCodec.VERSION, protocol.readByte() ); - Assert.assertEquals( Demo.Iface.class.getName(), protocol.readString() ); - Assert.assertEquals( request.getId(), protocol.readI64() ); - - if ( bis.markSupported() ) { - bis.reset(); - bis.skip( headerLength ); - } - - TMessage message = protocol.readMessageBegin(); - Assert.assertEquals( "echoString", message.name ); - Assert.assertEquals( TMessageType.EXCEPTION, message.type ); - Assert.assertEquals( ThriftCodec.getSeqId(), message.seqid ); - TApplicationException exception = TApplicationException.read( protocol ); - protocol.readMessageEnd(); - - Assert.assertEquals( exceptionMessage, exception.getMessage() ); - - } - - @Test - public void testDecodeRequest() throws Exception { - Request request = createRequest(); - // encode - RandomAccessByteArrayOutputStream bos = new RandomAccessByteArrayOutputStream( 1024 ); - - TIOStreamTransport transport = new TIOStreamTransport( bos ); - - TBinaryProtocol protocol = new TBinaryProtocol( transport ); - - int messageLength, headerLength; - - protocol.writeI16( ThriftCodec.MAGIC ); - protocol.writeI32( Integer.MAX_VALUE ); - protocol.writeI16( Short.MAX_VALUE ); - protocol.writeByte( ThriftCodec.VERSION ); - protocol.writeString( - ( ( RpcInvocation ) request.getData() ) - .getAttachment( Constants.INTERFACE_KEY) ); - protocol.writeI64( request.getId() ); - protocol.getTransport().flush(); - headerLength = bos.size(); - - Demo.echoString_args args = new Demo.echoString_args( ); - args.setArg( "Hell, World!" ); - - TMessage message = new TMessage( "echoString", TMessageType.CALL, ThriftCodec.getSeqId() ); - - protocol.writeMessageBegin( message ); - args.write( protocol ); - protocol.writeMessageEnd(); - protocol.getTransport().flush(); - int oldIndex = messageLength = bos.size(); - - try{ - bos.setWriteIndex( ThriftCodec.MESSAGE_HEADER_LENGTH_INDEX ); - protocol.writeI16( ( short ) ( 0xffff & headerLength ) ); - bos.setWriteIndex( ThriftCodec.MESSAGE_LENGTH_INDEX ); - protocol.writeI32( messageLength ); - } finally { - bos.setWriteIndex( oldIndex ); - } - - Object obj = codec.decode( ( Channel ) null, ChannelBuffers.wrappedBuffer( - encodeFrame(bos.toByteArray())) ); - - Assert.assertTrue( obj instanceof Request ); - - obj = ( ( Request ) obj ).getData(); - - Assert.assertTrue( obj instanceof RpcInvocation ); - - RpcInvocation invocation = ( RpcInvocation ) obj; - - Assert.assertEquals( "echoString", invocation.getMethodName() ); - Assert.assertArrayEquals( new Class[] {String .class}, invocation.getParameterTypes() ); - Assert.assertArrayEquals( new Object[] { args.getArg() }, invocation.getArguments() ); - - } - - private Request createRequest() { - - RpcInvocation invocation = new RpcInvocation(); - - invocation.setMethodName( "echoString" ); - - invocation.setArguments( new Object[]{ "Hello, World!" } ); - - invocation.setParameterTypes( new Class[]{ String.class } ); - - invocation.setAttachment( Constants.INTERFACE_KEY, Demo.Iface.class.getName() ); - - Request request = new Request( 1L ); - - request.setData( invocation ); - - return request; - - } - - static byte[] encodeFrame( byte[] content ) { - byte[] result = new byte[4+content.length]; - TFramedTransport.encodeFrameSize( content.length, result ); - System.arraycopy( content, 0, result, 4, content.length ); - return result; - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftDemoImpl.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftDemoImpl.java deleted file mode 100644 index 38bcd4c62d9..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftDemoImpl.java +++ /dev/null @@ -1,22 +0,0 @@ -/** - * File Created at 2011-12-31 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.rpc.gen.thrift.Demo; -import org.apache.thrift.TException; - -/** - * @author kimi - */ -public class ThriftDemoImpl extends DemoImpl implements Demo.Iface {} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftProtocolTest.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftProtocolTest.java deleted file mode 100644 index a233cc18013..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftProtocolTest.java +++ /dev/null @@ -1,90 +0,0 @@ -/** - * File Created at 2011-12-08 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.common.URL; -import com.alibaba.dubbo.rpc.Invoker; -import com.alibaba.dubbo.rpc.Result; -import com.alibaba.dubbo.rpc.RpcInvocation; -import com.alibaba.dubbo.rpc.gen.dubbo.Demo; -import org.junit.After; -import org.junit.Assert; -import org.junit.Before; -import org.junit.Test; - -/** - * @author kimi - */ -public class ThriftProtocolTest extends AbstractTest { - - public static final int DEFAULT_PORT = 30660; - - private ThriftProtocol protocol; - - private Invoker invoker; - - private URL url; - - @Before - public void setUp() throws Exception { - - init(); - - protocol = new ThriftProtocol(); - - url = URL.valueOf( ThriftProtocol.NAME + "://127.0.0.1:" + PORT + "/" + Demo.class.getName() ); - - } - - @After - public void tearDown() throws Exception { - - destroy(); - - if ( protocol != null ) { - protocol.destroy(); - protocol = null; - } - - if ( invoker != null ) { - invoker.destroy(); - invoker = null; - } - - } - - @Test - public void testRefer() throws Exception { - // FIXME - /*invoker = protocol.refer( Demo.class, url ); - - Assert.assertNotNull( invoker ); - - RpcInvocation invocation = new RpcInvocation(); - - invocation.setMethodName( "echoString" ); - - invocation.setParameterTypes( new Class[]{ String.class } ); - - String arg = "Hello, World!"; - - invocation.setArguments( new Object[] { arg } ); - - Result result = invoker.invoke( invocation ); - - Assert.assertEquals( arg, result.getResult() );*/ - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftUtilsTest.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftUtilsTest.java deleted file mode 100644 index 9cd1f5826da..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/ThriftUtilsTest.java +++ /dev/null @@ -1,88 +0,0 @@ -/** - * File Created at 2011-12-05 - * $Id$ - * - * Copyright 2008 Alibaba.com Croporation Limited. - * All rights reserved. - * - * This software is the confidential and proprietary information of - * Alibaba Company. ("Confidential Information"). You shall not - * disclose such Confidential Information and shall use it only in - * accordance with the terms of the license agreement you entered into - * with Alibaba.com. - */ -package com.alibaba.dubbo.rpc.protocol.thrift; - -import com.alibaba.dubbo.common.extension.ExtensionLoader; -import com.alibaba.dubbo.rpc.gen.dubbo.$__DemoStub; -import org.junit.Assert; -import org.junit.Test; - -/** - * @author gang.lvg - */ -public class ThriftUtilsTest { - - @Test - public void testGenerateMethodArgsClassName() { - - Assert.assertEquals( - $__DemoStub.echoString_args.class.getName(), - ThriftUtils.generateMethodArgsClassName( - com.alibaba.dubbo.rpc.gen.dubbo.Demo.class.getName(), - "echoString" ) ); - - Assert.assertEquals( - $__DemoStub.echoString_args.class.getName(), - ExtensionLoader.getExtensionLoader(ClassNameGenerator.class) - .getExtension( DubboClassNameGenerator.NAME ).generateArgsClassName( - com.alibaba.dubbo.rpc.gen.dubbo.Demo.class.getName(), "echoString" ) ); - - } - - @Test - public void testGenerateMethodResultClassName() { - - Assert.assertEquals( $__DemoStub.echoString_result.class.getName(), - ThriftUtils.generateMethodResultClassName( - com.alibaba.dubbo.rpc.gen.dubbo.Demo.class.getName(), - "echoString" )); - - Assert.assertEquals( $__DemoStub.echoString_result.class.getName(), - ExtensionLoader.getExtensionLoader( ClassNameGenerator.class ) - .getExtension( DubboClassNameGenerator.NAME ).generateResultClassName ( - com.alibaba.dubbo.rpc.gen.dubbo.Demo.class.getName(), "echoString" )); - - } - - @Test - public void testGenerateMethodArgsClassNameThrift() { - Assert.assertEquals( com.alibaba.dubbo.rpc.gen.thrift.Demo.echoString_args.class.getName(), - ThriftUtils.generateMethodArgsClassNameThrift( - com.alibaba.dubbo.rpc.gen.thrift.Demo.Iface.class.getName(), - "echoString" ) ); - - Assert.assertEquals( com.alibaba.dubbo.rpc.gen.thrift.Demo.echoString_args.class.getName(), - ExtensionLoader.getExtensionLoader( ClassNameGenerator.class ) - .getExtension( ThriftClassNameGenerator.NAME ).generateArgsClassName( - com.alibaba.dubbo.rpc.gen.thrift.Demo.Iface.class.getName(), - "echoString" ) ); - - } - - @Test - public void testGenerateMethodResultClassNameThrift() { - Assert.assertEquals( com.alibaba.dubbo.rpc.gen.thrift.Demo.echoString_result.class.getName(), - ThriftUtils.generateMethodResultClassNameThrift( - com.alibaba.dubbo.rpc.gen.thrift.Demo.Iface.class.getName(), - "echoString" ) ); - - Assert.assertEquals( com.alibaba.dubbo.rpc.gen.thrift.Demo.echoString_result.class.getName(), - ExtensionLoader.getExtensionLoader( ClassNameGenerator.class ) - .getExtension( ThriftClassNameGenerator.NAME ).generateResultClassName( - com.alibaba.dubbo.rpc.gen.thrift.Demo.Iface.class.getName(), - "echoString" ) ); - - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/examples/DubboDemoConsumer.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/examples/DubboDemoConsumer.java deleted file mode 100644 index 369f61a5c8d..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/examples/DubboDemoConsumer.java +++ /dev/null @@ -1,24 +0,0 @@ -package com.alibaba.dubbo.rpc.protocol.thrift.examples; - -import org.springframework.context.support.ClassPathXmlApplicationContext; - -import com.alibaba.dubbo.rpc.gen.thrift.Demo; - -/** - * @author kimi - */ -public class DubboDemoConsumer { - - public static void main(String[] args) throws Exception { - ClassPathXmlApplicationContext context = - new ClassPathXmlApplicationContext("dubbo-demo-consumer.xml"); - context.start(); - Demo.Iface demo = (Demo.Iface) context.getBean("demoService"); - System.out.println(demo.echoI32(32)); - for (int i = 0; i < 10; i++) { - System.out.println(demo.echoI32(i + 1)); - } - context.close(); - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/examples/DubboDemoProvider.java b/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/examples/DubboDemoProvider.java deleted file mode 100644 index d65d21e69a7..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/java/com/alibaba/dubbo/rpc/protocol/thrift/examples/DubboDemoProvider.java +++ /dev/null @@ -1,18 +0,0 @@ -package com.alibaba.dubbo.rpc.protocol.thrift.examples; - -import org.springframework.context.support.ClassPathXmlApplicationContext; - -/** - * @author kimi - */ -public class DubboDemoProvider { - - public static void main(String[] args) throws Exception { - ClassPathXmlApplicationContext context = - new ClassPathXmlApplicationContext("dubbo-demo-provider.xml"); - context.start(); - System.out.println("context started"); - System.in.read(); - } - -} diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/resources/dubbo-demo-consumer.xml b/dubbo-rpc/dubbo-rpc-thrift/src/test/resources/dubbo-demo-consumer.xml deleted file mode 100644 index 4f1ccc42380..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/resources/dubbo-demo-consumer.xml +++ /dev/null @@ -1,17 +0,0 @@ - - - - - - - - - - - - - \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/resources/dubbo-demo-provider.xml b/dubbo-rpc/dubbo-rpc-thrift/src/test/resources/dubbo-demo-provider.xml deleted file mode 100644 index 8727b7bea1e..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/resources/dubbo-demo-provider.xml +++ /dev/null @@ -1,19 +0,0 @@ - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/ClassNameTestDubbo.thrift b/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/ClassNameTestDubbo.thrift deleted file mode 100644 index 3e2023a9e17..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/ClassNameTestDubbo.thrift +++ /dev/null @@ -1,3 +0,0 @@ -service ClassNameTestDubbo { - string echo(1:required string arg); -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/ClassNameTestThrift.thrift b/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/ClassNameTestThrift.thrift deleted file mode 100644 index ccac7a1e0a4..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/ClassNameTestThrift.thrift +++ /dev/null @@ -1,3 +0,0 @@ -service ClassNameTestThrift { - string echo(1:required string arg); -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/Demo.thrift b/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/Demo.thrift deleted file mode 100644 index 91a264a5251..00000000000 --- a/dubbo-rpc/dubbo-rpc-thrift/src/test/thrift/Demo.thrift +++ /dev/null @@ -1,16 +0,0 @@ -namespace dubbo_java com.alibaba.dubbo.rpc.gen.dubbo -namespace dubbo_cpp com.alibaba.dubbo.rpc.gen.dubbo - -namespace java com.alibaba.dubbo.rpc.gen.thrift -namespace cpp com.alibaba.dubbo.rpc.gen.thrift - -service Demo { - bool echoBool( 1:required bool arg ); - byte echoByte( 1:required byte arg ); - i16 echoI16 ( 1:required i16 arg ); - i32 echoI32 ( 1:required i32 arg ); - i64 echoI64 ( 1:required i64 arg ); - - double echoDouble( 1:required double arg ); - string echoString( 1:required string arg ); -} \ No newline at end of file diff --git a/dubbo-rpc/dubbo-rpc-webservice/pom.xml b/dubbo-rpc/dubbo-rpc-webservice/pom.xml index 069d285b432..6cb9006194c 100644 --- a/dubbo-rpc/dubbo-rpc-webservice/pom.xml +++ b/dubbo-rpc/dubbo-rpc-webservice/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-rpc - 2.8.4 + 3.0.1 dubbo-rpc-webservice jar diff --git a/dubbo-rpc/pom.xml b/dubbo-rpc/pom.xml index 4dd07112ac0..f9c675778bf 100644 --- a/dubbo-rpc/pom.xml +++ b/dubbo-rpc/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-rpc pom @@ -36,7 +36,6 @@ dubbo-rpc-hessian dubbo-rpc-http dubbo-rpc-webservice - dubbo-rpc-thrift dubbo-rpc-memcached dubbo-rpc-redis dubbo-rpc-rest diff --git a/dubbo-simple/dubbo-monitor-simple/pom.xml b/dubbo-simple/dubbo-monitor-simple/pom.xml index 4068dfc52fa..35da15b7128 100644 --- a/dubbo-simple/dubbo-monitor-simple/pom.xml +++ b/dubbo-simple/dubbo-monitor-simple/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-simple - 2.8.4 + 3.0.1 dubbo-monitor-simple jar diff --git a/dubbo-simple/dubbo-monitor-simple/src/main/java/com/alibaba/dubbo/monitor/simple/SimpleMonitorService.java b/dubbo-simple/dubbo-monitor-simple/src/main/java/com/alibaba/dubbo/monitor/simple/SimpleMonitorService.java index 34a45001bf2..875e2839460 100644 --- a/dubbo-simple/dubbo-monitor-simple/src/main/java/com/alibaba/dubbo/monitor/simple/SimpleMonitorService.java +++ b/dubbo-simple/dubbo-monitor-simple/src/main/java/com/alibaba/dubbo/monitor/simple/SimpleMonitorService.java @@ -15,38 +15,6 @@ */ package com.alibaba.dubbo.monitor.simple; -import java.awt.Color; -import java.awt.image.BufferedImage; -import java.io.BufferedReader; -import java.io.File; -import java.io.FileOutputStream; -import java.io.FileReader; -import java.io.FileWriter; -import java.io.IOException; -import java.text.DecimalFormat; -import java.text.ParseException; -import java.text.SimpleDateFormat; -import java.util.Date; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.concurrent.BlockingQueue; -import java.util.concurrent.Executors; -import java.util.concurrent.LinkedBlockingQueue; -import java.util.concurrent.ScheduledExecutorService; -import java.util.concurrent.ScheduledFuture; -import java.util.concurrent.TimeUnit; - -import javax.imageio.ImageIO; - -import org.jfree.chart.ChartFactory; -import org.jfree.chart.JFreeChart; -import org.jfree.chart.axis.DateAxis; -import org.jfree.chart.plot.XYPlot; -import org.jfree.data.time.Minute; -import org.jfree.data.time.TimeSeries; -import org.jfree.data.time.TimeSeriesCollection; - import com.alibaba.dubbo.common.Constants; import com.alibaba.dubbo.common.URL; import com.alibaba.dubbo.common.logger.Logger; @@ -55,10 +23,30 @@ import com.alibaba.dubbo.common.utils.NamedThreadFactory; import com.alibaba.dubbo.common.utils.NetUtils; import com.alibaba.dubbo.monitor.MonitorService; +import org.jfree.chart.ChartFactory; +import org.jfree.chart.JFreeChart; +import org.jfree.chart.axis.DateAxis; +import org.jfree.chart.plot.XYPlot; +import org.jfree.data.time.Minute; +import org.jfree.data.time.TimeSeries; +import org.jfree.data.time.TimeSeriesCollection; + +import javax.imageio.ImageIO; +import java.awt.*; +import java.awt.image.BufferedImage; +import java.io.*; +import java.text.DecimalFormat; +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.util.Date; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.concurrent.*; /** * SimpleMonitorService - * + * * @author william.liangf */ public class SimpleMonitorService implements MonitorService { @@ -66,9 +54,9 @@ public class SimpleMonitorService implements MonitorService { private static final Logger logger = LoggerFactory.getLogger(SimpleMonitorService.class); private static final String[] types = {SUCCESS, FAILURE, ELAPSED, CONCURRENT, MAX_ELAPSED, MAX_CONCURRENT}; - + private static final String POISON_PROTOCOL = "poison"; - + // 定时任务执行器 private final ScheduledExecutorService scheduledExecutorService = Executors.newScheduledThreadPool(1, new NamedThreadFactory("DubboMonitorTimer", true)); @@ -76,15 +64,15 @@ public class SimpleMonitorService implements MonitorService { private final ScheduledFuture chartFuture; private final Thread writeThread; - + private final BlockingQueue queue; - + private String statisticsDirectory = "statistics"; private String chartsDirectory = "charts"; - + private volatile boolean running = true; - + private static SimpleMonitorService INSTANCE = null; public static SimpleMonitorService getInstance() { @@ -94,7 +82,7 @@ public static SimpleMonitorService getInstance() { public String getStatisticsDirectory() { return statisticsDirectory; } - + public void setStatisticsDirectory(String statistics) { if (statistics != null) { this.statisticsDirectory = statistics; @@ -110,7 +98,7 @@ public void setChartsDirectory(String charts) { this.chartsDirectory = charts; } } - + public SimpleMonitorService() { queue = new LinkedBlockingQueue(Integer.parseInt(ConfigUtils.getProperty("dubbo.monitor.queue", "100000"))); writeThread = new Thread(new Runnable() { @@ -156,7 +144,7 @@ public void close() { logger.warn(t.getMessage(), t); } } - + private void write() throws Exception { URL statistics = queue.take(); if (POISON_PROTOCOL.equals(statistics.getProtocol())) { @@ -195,16 +183,16 @@ private void write() throws Exception { } provider = statistics.getHost(); } - String filename = statisticsDirectory - + "/" + day - + "/" + statistics.getServiceInterface() - + "/" + statistics.getParameter(METHOD) - + "/" + consumer - + "/" + provider + String filename = statisticsDirectory + + "/" + day + + "/" + statistics.getServiceInterface() + + "/" + statistics.getParameter(METHOD) + + "/" + consumer + + "/" + provider + "/" + type + "." + key; File file = new File(filename); File dir = file.getParentFile(); - if (dir != null && ! dir.exists()) { + if (dir != null && !dir.exists()) { dir.mkdirs(); } FileWriter writer = new FileWriter(file, true); @@ -222,7 +210,7 @@ private void write() throws Exception { private void draw() { File rootDir = new File(statisticsDirectory); - if (! rootDir.exists()) { + if (!rootDir.exists()) { return; } File[] dateDirs = rootDir.listFiles(); @@ -232,38 +220,38 @@ private void draw() { File[] methodDirs = serviceDir.listFiles(); for (File methodDir : methodDirs) { String methodUri = chartsDirectory + "/" + dateDir.getName() + "/" + serviceDir.getName() + "/" + methodDir.getName(); - + File successFile = new File(methodUri + "/" + SUCCESS + ".png"); long successModified = successFile.lastModified(); boolean successChanged = false; Map successData = new HashMap(); double[] successSummary = new double[4]; - + File elapsedFile = new File(methodUri + "/" + ELAPSED + ".png"); long elapsedModified = elapsedFile.lastModified(); boolean elapsedChanged = false; Map elapsedData = new HashMap(); double[] elapsedSummary = new double[4]; long elapsedMax = 0; - + File[] consumerDirs = methodDir.listFiles(); for (File consumerDir : consumerDirs) { File[] providerDirs = consumerDir.listFiles(); for (File providerDir : providerDirs) { File consumerSuccessFile = new File(providerDir, CONSUMER + "." + SUCCESS); File providerSuccessFile = new File(providerDir, PROVIDER + "." + SUCCESS); - appendData(new File[] {consumerSuccessFile, providerSuccessFile}, successData, successSummary); - if (consumerSuccessFile.lastModified() > successModified + appendData(new File[]{consumerSuccessFile, providerSuccessFile}, successData, successSummary); + if (consumerSuccessFile.lastModified() > successModified || providerSuccessFile.lastModified() > successModified) { successChanged = true; } - + File consumerElapsedFile = new File(providerDir, CONSUMER + "." + ELAPSED); File providerElapsedFile = new File(providerDir, PROVIDER + "." + ELAPSED); - appendData(new File[] {consumerElapsedFile, providerElapsedFile}, elapsedData, elapsedSummary); + appendData(new File[]{consumerElapsedFile, providerElapsedFile}, elapsedData, elapsedSummary); elapsedMax = Math.max(elapsedMax, CountUtils.max(new File(providerDir, CONSUMER + "." + MAX_ELAPSED))); elapsedMax = Math.max(elapsedMax, CountUtils.max(new File(providerDir, PROVIDER + "." + MAX_ELAPSED))); - if (consumerElapsedFile.lastModified() > elapsedModified + if (consumerElapsedFile.lastModified() > elapsedModified || providerElapsedFile.lastModified() > elapsedModified) { elapsedChanged = true; } @@ -275,42 +263,42 @@ private void draw() { elapsedSummary[1] = -1; elapsedSummary[2] = successSummary[3] == 0 ? 0 : elapsedSummary[3] / successSummary[3]; elapsedSummary[3] = -1; - createChart("ms/t", serviceDir.getName(), methodDir.getName(), dateDir.getName(), new String[] {CONSUMER, PROVIDER}, elapsedData, elapsedSummary, elapsedFile.getAbsolutePath()); + createChart("ms/t", serviceDir.getName(), methodDir.getName(), dateDir.getName(), new String[]{CONSUMER, PROVIDER}, elapsedData, elapsedSummary, elapsedFile.getAbsolutePath()); } if (successChanged) { divData(successData, 60); successSummary[0] = successSummary[0] / 60; successSummary[1] = successSummary[1] / 60; successSummary[2] = successSummary[2] / 60; - createChart("t/s", serviceDir.getName(), methodDir.getName(), dateDir.getName(), new String[] {CONSUMER, PROVIDER}, successData, successSummary, successFile.getAbsolutePath()); + createChart("t/s", serviceDir.getName(), methodDir.getName(), dateDir.getName(), new String[]{CONSUMER, PROVIDER}, successData, successSummary, successFile.getAbsolutePath()); } } } } } - + private void divData(Map successMap, long unit) { for (long[] success : successMap.values()) { - for (int i = 0; i < success.length; i ++) { + for (int i = 0; i < success.length; i++) { success[i] = success[i] / unit; } } } - + private void divData(Map elapsedMap, Map successMap) { for (Map.Entry entry : elapsedMap.entrySet()) { long[] elapsed = entry.getValue(); long[] success = successMap.get(entry.getKey()); - for (int i = 0; i < elapsed.length; i ++) { + for (int i = 0; i < elapsed.length; i++) { elapsed[i] = success[i] == 0 ? 0 : elapsed[i] / success[i]; } } } private void appendData(File[] files, Map data, double[] summary) { - for (int i = 0; i < files.length; i ++) { + for (int i = 0; i < files.length; i++) { File file = files[i]; - if (! file.exists()) { + if (!file.exists()) { continue; } try { @@ -333,7 +321,7 @@ private void appendData(File[] files, Map data, double[] summary summary[0] = Math.max(summary[0], values[i]); summary[1] = summary[1] == 0 ? values[i] : Math.min(summary[1], values[i]); sum += value; - cnt ++; + cnt++; } } if (i == 0) { @@ -348,12 +336,12 @@ private void appendData(File[] files, Map data, double[] summary } } } - + private static void createChart(String key, String service, String method, String date, String[] types, Map data, double[] summary, String path) { SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMddHHmm"); DecimalFormat numberFormat = new DecimalFormat("###,##0.##"); TimeSeriesCollection xydataset = new TimeSeriesCollection(); - for (int i = 0; i < types.length; i ++) { + for (int i = 0; i < types.length; i++) { String type = types[i]; TimeSeries timeseries = new TimeSeries(type); for (Map.Entry entry : data.entrySet()) { @@ -366,8 +354,8 @@ private static void createChart(String key, String service, String method, Strin xydataset.addSeries(timeseries); } JFreeChart jfreechart = ChartFactory.createTimeSeriesChart( - "max: " + numberFormat.format(summary[0]) + (summary[1] >=0 ? " min: " + numberFormat.format(summary[1]) : "") - + " avg: " + numberFormat.format(summary[2]) + (summary[3] >=0 ? " sum: " + numberFormat.format(summary[3]) : ""), + "max: " + numberFormat.format(summary[0]) + (summary[1] >= 0 ? " min: " + numberFormat.format(summary[1]) : "") + + " avg: " + numberFormat.format(summary[2]) + (summary[3] >= 0 ? " sum: " + numberFormat.format(summary[3]) : ""), toDisplayService(service) + " " + method + " " + toDisplayDate(date), key, xydataset, true, true, false); jfreechart.setBackgroundPaint(Color.WHITE); XYPlot xyplot = (XYPlot) jfreechart.getPlot(); @@ -385,7 +373,7 @@ private static void createChart(String key, String service, String method, Strin } File methodChartFile = new File(path); File methodChartDir = methodChartFile.getParentFile(); - if (methodChartDir != null && ! methodChartDir.exists()) { + if (methodChartDir != null && !methodChartDir.exists()) { methodChartDir.mkdirs(); } FileOutputStream output = new FileOutputStream(methodChartFile); @@ -399,7 +387,7 @@ private static void createChart(String key, String service, String method, Strin logger.warn(e.getMessage(), e); } } - + private static String toDisplayService(String service) { int i = service.lastIndexOf('.'); if (i >= 0) { @@ -407,7 +395,7 @@ private static String toDisplayService(String service) { } return service; } - + private static String toDisplayDate(String date) { try { return new SimpleDateFormat("yyyy-MM-dd").format(new SimpleDateFormat("yyyyMMdd").parse(date)); @@ -427,9 +415,9 @@ public void collect(URL statistics) { } } - public List lookup(URL query) { - // TODO Auto-generated method stub - return null; - } + public List lookup(URL query) { + // TODO Auto-generated method stub + return null; + } } \ No newline at end of file diff --git a/dubbo-simple/dubbo-registry-simple/pom.xml b/dubbo-simple/dubbo-registry-simple/pom.xml index 6c1912bee66..14de4651a94 100644 --- a/dubbo-simple/dubbo-registry-simple/pom.xml +++ b/dubbo-simple/dubbo-registry-simple/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-simple - 2.8.4 + 3.0.1 dubbo-registry-simple jar diff --git a/dubbo-simple/pom.xml b/dubbo-simple/pom.xml index 5bb270f0179..2cbf2c1a08f 100644 --- a/dubbo-simple/pom.xml +++ b/dubbo-simple/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-simple pom diff --git a/dubbo-test/dubbo-test-benchmark-api/pom.xml b/dubbo-test/dubbo-test-benchmark-api/pom.xml index 79f9a30036c..6b903220082 100644 --- a/dubbo-test/dubbo-test-benchmark-api/pom.xml +++ b/dubbo-test/dubbo-test-benchmark-api/pom.xml @@ -4,7 +4,7 @@ com.alibaba dubbo-test - 2.8.4 + 3.0.1 dubbo-test-benchmark-api jar diff --git a/dubbo-test/dubbo-test-benchmark-client/pom.xml b/dubbo-test/dubbo-test-benchmark-client/pom.xml index 09aded71106..4a51d06796c 100644 --- a/dubbo-test/dubbo-test-benchmark-client/pom.xml +++ b/dubbo-test/dubbo-test-benchmark-client/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-test - 2.8.4 + 3.0.1 dubbo-test-benchmark-client jar diff --git a/dubbo-test/dubbo-test-benchmark-server/pom.xml b/dubbo-test/dubbo-test-benchmark-server/pom.xml index 9a97c7df23f..cb0fc158f46 100644 --- a/dubbo-test/dubbo-test-benchmark-server/pom.xml +++ b/dubbo-test/dubbo-test-benchmark-server/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-test - 2.8.4 + 3.0.1 dubbo-test-benchmark-server jar diff --git a/dubbo-test/dubbo-test-benchmark/pom.xml b/dubbo-test/dubbo-test-benchmark/pom.xml index 2593c9e5054..e9258b8352d 100644 --- a/dubbo-test/dubbo-test-benchmark/pom.xml +++ b/dubbo-test/dubbo-test-benchmark/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-test - 2.8.4 + 3.0.1 dubbo-test-benchmark jar diff --git a/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/AbstractBenchmarkClient.java b/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/AbstractBenchmarkClient.java index 6ac6d95b3f2..066e938d6be 100644 --- a/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/AbstractBenchmarkClient.java +++ b/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/AbstractBenchmarkClient.java @@ -2,79 +2,73 @@ /** * nfs-rpc - * Apache License - * - * http://code.google.com/p/nfs-rpc (c) 2011 + * Apache License + *

+ * http://code.google.com/p/nfs-rpc (c) 2011 */ + +import com.alibaba.dubbo.common.utils.ConfigUtils; + import java.io.BufferedWriter; -import java.io.FileInputStream; import java.io.FileWriter; import java.lang.reflect.InvocationTargetException; import java.text.SimpleDateFormat; -import java.util.ArrayList; -import java.util.Calendar; -import java.util.Date; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.Properties; +import java.util.*; import java.util.concurrent.CountDownLatch; import java.util.concurrent.CyclicBarrier; -import com.alibaba.dubbo.common.utils.ConfigUtils; - /** * Abstract benchmark client,test for difference scenes Usage: -Dwrite.statistics=false BenchmarkClient serverIP * serverPort concurrents timeout codectype requestSize runtime(seconds) clientNums - * + * * @author bluedavy */ public abstract class AbstractBenchmarkClient { private static final SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); - private static long maxTPS = 0; + private static long maxTPS = 0; - private static long minTPS = 0; + private static long minTPS = 0; - private static long allRequestSum; + private static long allRequestSum; - private static long allResponseTimeSum; + private static long allResponseTimeSum; - private static long allErrorRequestSum; + private static long allErrorRequestSum; - private static long allErrorResponseTimeSum; + private static long allErrorResponseTimeSum; - private static int runtime; + private static int runtime; // < 0 - private static long below0sum; + private static long below0sum; // (0,1] - private static long above0sum; + private static long above0sum; // (1,5] - private static long above1sum; + private static long above1sum; // (5,10] - private static long above5sum; + private static long above5sum; // (10,50] - private static long above10sum; + private static long above10sum; // (50,100] - private static long above50sum; + private static long above50sum; // (100,500] - private static long above100sum; + private static long above100sum; // (500,1000] - private static long above500sum; + private static long above500sum; // > 1000 - private static long above1000sum; + private static long above1000sum; - Properties properties = ConfigUtils.getProperties(); + Properties properties = ConfigUtils.getProperties(); public void run(String[] args) throws Exception { @@ -107,7 +101,7 @@ public void run(String[] args) throws Exception { long beginTime = System.nanoTime() / 1000L + 30 * 1000 * 1000L; for (int i = 0; i < concurrents; i++) { ClientRunnable runnable = getClientRunnable(serverIP, serverPort, clientNums, timeout, barrier, latch, - beginTime, endtime); + beginTime, endtime); runnables.add(runnable); } @@ -212,13 +206,13 @@ public void run(String[] args) throws Exception { long benchmarkRequest = allRequestSum + allErrorRequestSum; long allRequest = benchmarkRequest + ignoreRequest + ignoreErrorRequest; System.out.println(" Requests: " + allRequest + " Success: " + (allRequestSum + ignoreRequest) * 100 - / allRequest + "% (" + (allRequestSum + ignoreRequest) + ") Error: " - + (allErrorRequestSum + ignoreErrorRequest) * 100 / allRequest + "% (" - + (allErrorRequestSum + ignoreErrorRequest) + ")"); + / allRequest + "% (" + (allRequestSum + ignoreRequest) + ") Error: " + + (allErrorRequestSum + ignoreErrorRequest) * 100 / allRequest + "% (" + + (allErrorRequestSum + ignoreErrorRequest) + ")"); System.out.println(" Avg TPS: " + benchmarkRequest / times.keySet().size() + " Max TPS: " + maxTPS - + " Min TPS: " + minTPS); + + " Min TPS: " + minTPS); System.out.println(" Avg RT: " + (allErrorResponseTimeSum + allResponseTimeSum) / benchmarkRequest / 1000f - + "ms"); + + "ms"); System.out.println(" RT <= 0: " + (below0sum * 100 / allRequest) + "% " + below0sum + "/" + allRequest); System.out.println(" RT (0,1]: " + (above0sum * 100 / allRequest) + "% " + above0sum + "/" + allRequest); System.out.println(" RT (1,5]: " + (above1sum * 100 / allRequest) + "% " + above1sum + "/" + allRequest); @@ -227,7 +221,7 @@ public void run(String[] args) throws Exception { System.out.println(" RT (50,100]: " + (above50sum * 100 / allRequest) + "% " + above50sum + "/" + allRequest); System.out.println(" RT (100,500]: " + (above100sum * 100 / allRequest) + "% " + above100sum + "/" + allRequest); System.out.println(" RT (500,1000]: " + (above500sum * 100 / allRequest) + "% " + above500sum + "/" - + allRequest); + + allRequest); System.out.println(" RT > 1000: " + (above1000sum * 100 / allRequest) + "% " + above1000sum + "/" + allRequest); System.exit(0); } diff --git a/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/AbstractBenchmarkServer.java b/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/AbstractBenchmarkServer.java index 3fade03740b..cf53c9f16bb 100644 --- a/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/AbstractBenchmarkServer.java +++ b/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/AbstractBenchmarkServer.java @@ -6,7 +6,7 @@ import java.text.SimpleDateFormat; import java.util.Date; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeChannel; import com.alibaba.dubbo.remoting.exchange.Exchangers; import com.alibaba.dubbo.remoting.exchange.support.ExchangeHandlerAdapter; diff --git a/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/SimpleProcessorBenchmarkClientRunnable.java b/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/SimpleProcessorBenchmarkClientRunnable.java index f663a6af097..49506d4ced7 100644 --- a/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/SimpleProcessorBenchmarkClientRunnable.java +++ b/dubbo-test/dubbo-test-benchmark/src/main/java/com/alibaba/dubbo/rpc/benchmark/SimpleProcessorBenchmarkClientRunnable.java @@ -3,67 +3,68 @@ /** * nfs-rpc Apache License http://code.google.com/p/nfs-rpc (c) 2011 */ + +import org.apache.commons.logging.Log; +import org.apache.commons.logging.LogFactory; + import java.util.ArrayList; import java.util.List; import java.util.concurrent.CountDownLatch; import java.util.concurrent.CyclicBarrier; -import org.apache.commons.logging.Log; -import org.apache.commons.logging.LogFactory; - /** * Simple Processor RPC Benchmark Client Thread - * + * * @author bluedavy */ public class SimpleProcessorBenchmarkClientRunnable implements ClientRunnable { - private static final Log LOGGER = LogFactory.getLog(SimpleProcessorBenchmarkClientRunnable.class); + private static final Log LOGGER = LogFactory.getLog(SimpleProcessorBenchmarkClientRunnable.class); - private int requestSize; + private int requestSize; - private CyclicBarrier barrier; + private CyclicBarrier barrier; - private CountDownLatch latch; + private CountDownLatch latch; - private long endTime; + private long endTime; - private boolean running = true; + private boolean running = true; - private ExchangeClientFactory clientFactory = new ExchangeClientFactory(); + private ExchangeClientFactory clientFactory = new ExchangeClientFactory(); - private String targetIP; + private String targetIP; - private int targetPort; + private int targetPort; - private int clientNums; + private int clientNums; - private int rpcTimeout; + private int rpcTimeout; // response time spread - private long[] responseSpreads = new long[9]; + private long[] responseSpreads = new long[9]; // error request per second - private long[] errorTPS = null; + private long[] errorTPS = null; // error response times per second - private long[] errorResponseTimes = null; + private long[] errorResponseTimes = null; // tps per second - private long[] tps = null; + private long[] tps = null; // response times per second - private long[] responseTimes = null; + private long[] responseTimes = null; // benchmark startTime - private long startTime; + private long startTime; // benchmark maxRange - private int maxRange; + private int maxRange; public SimpleProcessorBenchmarkClientRunnable(String targetIP, int targetPort, int clientNums, int rpcTimeout, CyclicBarrier barrier, CountDownLatch latch, long startTime, - long endTime){ + long endTime) { this.targetIP = targetIP; this.targetPort = targetPort; @@ -107,7 +108,6 @@ private void runJavaAndHessian() { } try { Object response = null; - response = clientFactory.get(targetIP, targetPort, rpcTimeout, clientNums).request(requestObject).get(); long currentTime = System.nanoTime(); if (beginTime <= startTime) { continue; @@ -117,7 +117,7 @@ private void runJavaAndHessian() { int range = Integer.parseInt(String.valueOf(beginTime - startTime)) / 1000; if (range >= maxRange) { System.err.println("benchmark range exceeds maxRange,range is: " + range + ",maxRange is: " - + maxRange); + + maxRange); continue; } if (((ResponseObject) response).getBytes() != null) { @@ -139,7 +139,7 @@ private void runJavaAndHessian() { int range = Integer.parseInt(String.valueOf(beginTime - startTime)) / 1000; if (range >= maxRange) { System.err.println("benchmark range exceeds maxRange,range is: " + range + ",maxRange is: " - + maxRange); + + maxRange); continue; } errorTPS[range] = errorTPS[range] + 1; diff --git a/dubbo-test/dubbo-test-compatibility/pom.xml b/dubbo-test/dubbo-test-compatibility/pom.xml index d02370e64cc..b3d9acf48a3 100644 --- a/dubbo-test/dubbo-test-compatibility/pom.xml +++ b/dubbo-test/dubbo-test-compatibility/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-test - 2.8.4 + 3.0.1 dubbo-test-compatibility jar diff --git a/dubbo-test/dubbo-test-examples/pom.xml b/dubbo-test/dubbo-test-examples/pom.xml index 43b4b699291..483cd6c475f 100644 --- a/dubbo-test/dubbo-test-examples/pom.xml +++ b/dubbo-test/dubbo-test-examples/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-test - 2.8.4 + 3.0.1 dubbo-test-examples jar @@ -94,11 +94,6 @@ dubbo-rpc-webservice ${project.parent.version} - - com.alibaba - dubbo-rpc-thrift - ${project.parent.version} - com.alibaba dubbo-rpc-memcached diff --git a/dubbo-test/dubbo-test-examples/src/main/java/com/alibaba/dubbo/examples/async/AsyncConsumer.java b/dubbo-test/dubbo-test-examples/src/main/java/com/alibaba/dubbo/examples/async/AsyncConsumer.java deleted file mode 100644 index 3bb73e0ea88..00000000000 --- a/dubbo-test/dubbo-test-examples/src/main/java/com/alibaba/dubbo/examples/async/AsyncConsumer.java +++ /dev/null @@ -1,58 +0,0 @@ -/* - * Copyright 1999-2012 Alibaba Group. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -package com.alibaba.dubbo.examples.async; - -import java.util.concurrent.Callable; -import java.util.concurrent.Future; - -import org.springframework.context.support.ClassPathXmlApplicationContext; - -import com.alibaba.dubbo.examples.async.api.AsyncService; -import com.alibaba.dubbo.rpc.RpcContext; - -/** - * CallbackConsumer - * - * @author william.liangf - */ -public class AsyncConsumer { - - public static void main(String[] args) throws Exception { - String config = AsyncConsumer.class.getPackage().getName().replace('.', '/') + "/async-consumer.xml"; - ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(config); - context.start(); - - final AsyncService asyncService = (AsyncService)context.getBean("asyncService"); - - Future f = RpcContext.getContext().asyncCall(new Callable() { - public String call() throws Exception { - return asyncService.sayHello("async call request"); - } - }); - - System.out.println("async call ret :" + f.get()); - - RpcContext.getContext().asyncCall(new Runnable() { - public void run() { - asyncService.sayHello("oneway call request1"); - asyncService.sayHello("oneway call request2"); - } - }); - - System.in.read(); - } - -} diff --git a/dubbo-test/dubbo-test-examples/src/main/java/com/alibaba/dubbo/examples/heartbeat/HeartBeatExchangeHandler.java b/dubbo-test/dubbo-test-examples/src/main/java/com/alibaba/dubbo/examples/heartbeat/HeartBeatExchangeHandler.java index 016fc87b29b..faa1db98d86 100644 --- a/dubbo-test/dubbo-test-examples/src/main/java/com/alibaba/dubbo/examples/heartbeat/HeartBeatExchangeHandler.java +++ b/dubbo-test/dubbo-test-examples/src/main/java/com/alibaba/dubbo/examples/heartbeat/HeartBeatExchangeHandler.java @@ -16,44 +16,47 @@ package com.alibaba.dubbo.examples.heartbeat; -import java.util.concurrent.atomic.AtomicInteger; - -import com.alibaba.dubbo.remoting.Channel; -import com.alibaba.dubbo.remoting.RemotingException; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.remoting.transport.Channel; +import com.alibaba.dubbo.remoting.exception.RemotingException; import com.alibaba.dubbo.remoting.exchange.ExchangeHandler; -import com.alibaba.dubbo.remoting.exchange.Request; -import com.alibaba.dubbo.remoting.exchange.Response; import com.alibaba.dubbo.remoting.exchange.support.header.HeaderExchangeHandler; +import java.util.concurrent.atomic.AtomicInteger; + /** * @author kimi */ public class HeartBeatExchangeHandler extends HeaderExchangeHandler { - private AtomicInteger heartBeatCounter = new AtomicInteger( 0 ); - - public HeartBeatExchangeHandler( ExchangeHandler handler ) { - super( handler ); + private AtomicInteger heartBeatCounter = new AtomicInteger(0); + + public HeartBeatExchangeHandler(ExchangeHandler handler) { + super(handler); } @Override - public void received( Channel channel, Object message ) throws RemotingException { - if ( message instanceof Request ) { - Request req = ( Request ) message; - if ( req.isHeartbeat() ) { + public void received(Channel channel, Object message) throws RemotingException { + if (message instanceof Request) { + Request req = (Request) message; + if (req.isHeartbeat()) { heartBeatCounter.incrementAndGet(); channel.setAttribute(KEY_READ_TIMESTAMP, System.currentTimeMillis()); - Response res = new Response( req.getId(), req.getVersion() ); - res.setEvent( req.getData() == null ? null : req.getData().toString() ); - channel.send( res ); + Response res = new Response.Builder(req.getId()). + version(req.getVersion()). + isEvent(true). + result(req.getData() == null ? null : req.getData().toString()). + build(); + channel.send(res); } } else { - super.received( channel, message ); + super.received(channel, message); } } - + public int getHeartBeatCount() { return heartBeatCounter.get(); } - + } diff --git a/dubbo-test/dubbo-test-integration/pom.xml b/dubbo-test/dubbo-test-integration/pom.xml index cbf43a6836a..e29bd3c7f2d 100644 --- a/dubbo-test/dubbo-test-integration/pom.xml +++ b/dubbo-test/dubbo-test-integration/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-test - 2.8.4 + 3.0.1 dubbo-test-integration jar diff --git a/dubbo-test/pom.xml b/dubbo-test/pom.xml index 8ccfec26d31..35d58860c06 100644 --- a/dubbo-test/pom.xml +++ b/dubbo-test/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-test pom diff --git a/dubbo-tool/dubbo-demo-lite-archetype/pom.xml b/dubbo-tool/dubbo-demo-lite-archetype/pom.xml index 844d9844dbd..1f619d3c4e6 100644 --- a/dubbo-tool/dubbo-demo-lite-archetype/pom.xml +++ b/dubbo-tool/dubbo-demo-lite-archetype/pom.xml @@ -4,7 +4,7 @@ com.alibaba dubbo-demo-lite-archetype - 2.8.4 + 3.0.1 maven-archetype dubbo-demo-lite-archetype diff --git a/dubbo-tool/dubbo-demo-lite-archetype/src/main/resources/archetype-resources/pom.xml b/dubbo-tool/dubbo-demo-lite-archetype/src/main/resources/archetype-resources/pom.xml index 561a683e509..964f34e4775 100644 --- a/dubbo-tool/dubbo-demo-lite-archetype/src/main/resources/archetype-resources/pom.xml +++ b/dubbo-tool/dubbo-demo-lite-archetype/src/main/resources/archetype-resources/pom.xml @@ -18,7 +18,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 ${artifactId} ${groupId} @@ -35,7 +35,7 @@ com.alibaba dubbo - 2.8.4 + 3.0.1 diff --git a/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-api/pom.xml b/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-api/pom.xml index fb06b640479..2d550a67c30 100644 --- a/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-api/pom.xml +++ b/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-api/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-demo-lite - 2.8.4 + 3.0.1 dubbo-demo-lite-api jar diff --git a/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-consumer/pom.xml b/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-consumer/pom.xml index e59c2df0903..3a7cf51b014 100644 --- a/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-consumer/pom.xml +++ b/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-consumer/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-demo-lite - 2.8.4 + 3.0.1 dubbo-demo-lite-consumer jar diff --git a/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-provider/pom.xml b/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-provider/pom.xml index ab2cead41cd..ff6731a3965 100644 --- a/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-provider/pom.xml +++ b/dubbo-tool/dubbo-demo-lite/dubbo-demo-lite-provider/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-demo-lite - 2.8.4 + 3.0.1 dubbo-demo-lite-provider war diff --git a/dubbo-tool/dubbo-demo-lite/pom.xml b/dubbo-tool/dubbo-demo-lite/pom.xml index b43142ae691..85fd8030f4e 100644 --- a/dubbo-tool/dubbo-demo-lite/pom.xml +++ b/dubbo-tool/dubbo-demo-lite/pom.xml @@ -19,7 +19,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo-demo-lite pom @@ -39,7 +39,7 @@ com.alibaba dubbo - 2.8.4 + 3.0.1 diff --git a/dubbo-tracker/dubbo-tracker-api/pom.xml b/dubbo-tracker/dubbo-tracker-api/pom.xml new file mode 100644 index 00000000000..4c3bc276c7e --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/pom.xml @@ -0,0 +1,50 @@ + + + + dubbo-tracker + com.alibaba + 3.0.1 + + 4.0.0 + + dubbo-tracker-api + jar + + + + com.alibaba + dubbo-common + ${project.parent.version} + + + + com.alibaba + dubbo-remoting-common + ${project.parent.version} + + + + com.alibaba + dubbo-rpc-api + ${project.parent.version} + + + + javax.servlet + javax.servlet-api + + + + com.squareup.okhttp3 + okhttp + + + + org.apache.commons + commons-lang3 + + + + \ No newline at end of file diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientRequestAdapter.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientRequestAdapter.java new file mode 100644 index 00000000000..7b03a8cf413 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientRequestAdapter.java @@ -0,0 +1,7 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs. + */ +public interface ClientRequestAdapter extends Traceable{ +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientRequestInterceptor.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientRequestInterceptor.java new file mode 100644 index 00000000000..e2c1649ad86 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientRequestInterceptor.java @@ -0,0 +1,9 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs + */ +public interface ClientRequestInterceptor { + + void handle(ClientRequestAdapter clientRequestAdapter); +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientResponseAdapter.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientResponseAdapter.java new file mode 100644 index 00000000000..729c5cb95c7 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientResponseAdapter.java @@ -0,0 +1,7 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs. + */ +public interface ClientResponseAdapter extends Traceable { +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientResponseInterceptor.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientResponseInterceptor.java new file mode 100644 index 00000000000..7e1f72557b7 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ClientResponseInterceptor.java @@ -0,0 +1,10 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs + */ +public interface ClientResponseInterceptor { + + void handle(ClientResponseAdapter clientResponseAdapter); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequest.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequest.java new file mode 100644 index 00000000000..c5c28ddb45c --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequest.java @@ -0,0 +1,85 @@ +package com.alibaba.dubbo.tracker; + + +import com.alibaba.dubbo.common.utils.StringUtils; +import com.alibaba.dubbo.remoting.message.Request; +import com.alibaba.dubbo.rpc.Invoker; +import com.alibaba.dubbo.rpc.RpcInvocation; +import com.alibaba.dubbo.tracker.exceptions.RequestIllegalException; + +/** + * @author Xs. + */ +public class DubboRequest { + + private final Request request; + + private RpcInvocation invocation; + + private boolean isTraceable; + + public enum Type { + IN, OUT + } + + public DubboRequest(Request request, Type type) { + this.request = request; + if (request.getData() instanceof RpcInvocation) { + invocation = (RpcInvocation) request.getData(); + isTraceable = (type == Type.OUT || getAttachment(RpcAttachment.Sampled.getName()) != null); + } + } + + public String getMethodName() { + return invocation.getMethodName(); + } + + public boolean isTraceable() { + return isTraceable; + } + + public void addAttachment(String key, String value) { + invocation.setAttachment(key, value); + } + + public String getAttachment(String key) { + return invocation.getAttachment(key); + } + + public String providerAddress() { + Invoker invoker = invocation.getInvoker(); + if (invoker == null) { + throw new RequestIllegalException("Invoker must not be null, request { " + request + " }"); + } + return invoker.getUrl().getAddress(); + } + + public String remoteMethod() { + String interfaceStr = invocation.getAttachment("interface"); + if (StringUtils.isEmpty(interfaceStr)) { + return invocation.getMethodName(); + } else { + StringBuilder builder = new StringBuilder(); + builder.append(interfaceStr).append("."); + builder.append(invocation.getMethodName()).append("("); + Class[] parameterTypes = invocation.getParameterTypes(); + int len = parameterTypes.length; + for (int i = 0; i < len - 1; i++) { + builder.append(parameterTypes[i].getCanonicalName()).append(" ,"); + } + if (len > 0) { + builder.append(parameterTypes[len - 1].getCanonicalName()); + } + builder.append(")"); + return builder.toString(); + } + } + + public String serviceVersion() { + return invocation.getAttachment("version"); + } + + public Request getRequest() { + return request; + } +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequestInterceptorBuilder.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequestInterceptorBuilder.java new file mode 100644 index 00000000000..185a5620cf5 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequestInterceptorBuilder.java @@ -0,0 +1,17 @@ +package com.alibaba.dubbo.tracker; + +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.extension.Adaptive; +import com.alibaba.dubbo.common.extension.SPI; +import com.alibaba.dubbo.remoting.message.Interceptor; + +/** + * @author Xs. + */ +@SPI("zipkin") +public interface DubboRequestInterceptorBuilder { + + @Adaptive({"tracker"}) + Interceptor build(URL url, DubboRequestSpanNameProvider spanNameProvider); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequestSpanNameProvider.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequestSpanNameProvider.java new file mode 100644 index 00000000000..3fee0b28d71 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboRequestSpanNameProvider.java @@ -0,0 +1,28 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs + */ +public class DubboRequestSpanNameProvider extends RpcContextMethodNameProvider { + + private static final DubboRequestSpanNameProvider instance = new DubboRequestSpanNameProvider(); + + private DubboRequestSpanNameProvider() { + } + + public static DubboRequestSpanNameProvider getInstance() { + return instance; + } + + public String spanName(DubboRequest dubboRequest) { + String spanName = getMethodNameFromContext(); + if (spanName == null) { + spanName = getSpanNameFromAttachment(dubboRequest); + } + return spanName; + } + + private String getSpanNameFromAttachment(DubboRequest dubboRequest) { + return dubboRequest.getAttachment(RpcAttachment.SpanName.getName()); + } +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboResponse.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboResponse.java new file mode 100644 index 00000000000..c6ee631d7f5 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/DubboResponse.java @@ -0,0 +1,38 @@ +package com.alibaba.dubbo.tracker; + +import com.alibaba.dubbo.remoting.message.Response; +import com.alibaba.dubbo.rpc.RpcResult; +import org.apache.commons.lang3.exception.ExceptionUtils; + +/** + * @author Xs. + */ +public class DubboResponse { + + private final Response response; + + private RpcResult result; + + public DubboResponse(Response response) { + this.response = response; + if (response.getResult() instanceof RpcResult) { + result = (RpcResult) response.getResult(); + } + } + + public boolean returnOK() { + return response.getStatus() == Response.OK + && !result.hasException(); + } + + public String exceptionMessage() { + if (returnOK()) { + return "response OK"; + } + Throwable throwable = result.getException(); + if (throwable != null) { + return ExceptionUtils.getStackTrace(throwable); + } + return "response " + response.getStatus(); + } +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcAttachment.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcAttachment.java new file mode 100644 index 00000000000..c58518e0ec9 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcAttachment.java @@ -0,0 +1,27 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs + */ +public enum RpcAttachment { + + TraceId("X-B3-TraceId"), + + SpanId("X-B3-SpanId"), + + ParentSpanId("X-B3-ParentSpanId"), + + Sampled("X-B3-Sampled"), + + SpanName("X-B3-SpanName"); + + private final String name; + + RpcAttachment(final String name) { + this.name = name; + } + + public String getName() { + return name; + } +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcContextMethodNameProvider.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcContextMethodNameProvider.java new file mode 100644 index 00000000000..9760c4ed8ab --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcContextMethodNameProvider.java @@ -0,0 +1,10 @@ +package com.alibaba.dubbo.tracker; + +import com.alibaba.dubbo.rpc.RpcContext; + +public abstract class RpcContextMethodNameProvider { + + public String getMethodNameFromContext() { + return RpcContext.getContext().getMethodName(); + } +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcProtocol.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcProtocol.java new file mode 100644 index 00000000000..ba228655c56 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcProtocol.java @@ -0,0 +1,61 @@ +package com.alibaba.dubbo.tracker; + +import com.alibaba.dubbo.common.utils.StringUtils; + +import java.util.HashMap; +import java.util.Map; + +/** + * @author Xs. + */ +public class RpcProtocol { + + public static final RpcProtocol DUBBO = new RpcProtocol("dubbo"); + public static final RpcProtocol HESSIAN = new RpcProtocol("hessian"); + public static final RpcProtocol HTTP = new RpcProtocol("http"); + + private static final Map PROTOCOL_MAP = new HashMap(); + + static { + PROTOCOL_MAP.put(DUBBO.protocol(), DUBBO); + PROTOCOL_MAP.put(HESSIAN.protocol(), HESSIAN); + PROTOCOL_MAP.put(HTTP.protocol(), HTTP); + } + + private final String protocol; + + public RpcProtocol(String protocol) { + this.protocol = protocol; + } + + public String protocol() { + return protocol; + } + + public static RpcProtocol valueOf(String protocol) { + if (StringUtils.isEmpty(protocol)) { + throw new IllegalArgumentException("protocol must not be null!"); + } + RpcProtocol rpcProtocol = PROTOCOL_MAP.get(protocol); + if (rpcProtocol == null) { + throw new IllegalArgumentException("cannot find protocol, " + protocol); + } + return rpcProtocol; + } + + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (o == null || getClass() != o.getClass()) { + return false; + } + RpcProtocol that = (RpcProtocol) o; + return protocol.equals(that.protocol); + + } + + @Override + public int hashCode() { + return 31 * protocol.hashCode() + 29; + } +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTracker.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTracker.java new file mode 100644 index 00000000000..8db4c414e9e --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTracker.java @@ -0,0 +1,17 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs + */ +public interface RpcTracker { + + void trackClientRequest(ClientRequestAdapter clientRequestAdapter); + + void trackClientResponse(ClientResponseAdapter clientResponseAdapter); + + void trackServerRequest(ServerRequestAdapter serverRequestAdapter); + + void trackServerResponse(ServerResponseAdapter serverResponseAdapter); + + RpcTrackerEngine trackerEngine(); +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerEngine.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerEngine.java new file mode 100644 index 00000000000..8bd2889f9eb --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerEngine.java @@ -0,0 +1,19 @@ +package com.alibaba.dubbo.tracker; + +/** + * RpcTracker引擎 + * + * @author Xs + */ +public interface RpcTrackerEngine { + + Object clientRequestInterceptor(); + + Object clientResponseInterceptor(); + + Object serverRequestInterceptor(); + + Object serverResponseInterceptor(); + + TraceIdReporter traceIdReporter(); +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerEngineFactory.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerEngineFactory.java new file mode 100644 index 00000000000..0c6825dd69f --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerEngineFactory.java @@ -0,0 +1,16 @@ +package com.alibaba.dubbo.tracker; + +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.extension.Adaptive; +import com.alibaba.dubbo.common.extension.SPI; + +/** + * @author Xs + */ +@SPI("zipkin") +public interface RpcTrackerEngineFactory { + + @Adaptive("protocol") + RpcTrackerEngine createRpcTrackerEngine(URL url); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerFactory.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerFactory.java new file mode 100644 index 00000000000..be1ce7aec20 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerFactory.java @@ -0,0 +1,16 @@ +package com.alibaba.dubbo.tracker; + +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.extension.Adaptive; +import com.alibaba.dubbo.common.extension.SPI; + +/** + * @author Xs + */ +@SPI("zipkin") +public interface RpcTrackerFactory { + + @Adaptive("protocol") + RpcTracker createRpcTracker(URL url); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerManager.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerManager.java new file mode 100644 index 00000000000..80535d5a713 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/RpcTrackerManager.java @@ -0,0 +1,63 @@ +package com.alibaba.dubbo.tracker; + +import com.alibaba.dubbo.common.URL; + +import java.util.HashMap; +import java.util.Map; + +/** + * @author Xs. + */ +public final class RpcTrackerManager { + + private static RpcTrackerFactory rpcTrackerFactory; + + private static RpcTrackerEngine rpcTrackerEngine; + + private static Map rpcTrackerMap = new HashMap(); + + public static RpcTrackerFactory getTrackerFactory() { + return rpcTrackerFactory; + } + + public static synchronized void setRpcTrackerFactory(RpcTrackerFactory rpcTrackerFactory) { + RpcTrackerManager.rpcTrackerFactory = rpcTrackerFactory; + } + + public static synchronized RpcTrackerEngine getRpcTrackerEngine() { + return rpcTrackerEngine; + } + + public static synchronized RpcTrackerEngine createRpcTrackerEngine(RpcTrackerEngineFactory factory, URL url) { + if (rpcTrackerEngine == null) { + rpcTrackerEngine = factory.createRpcTrackerEngine(url); + } + return rpcTrackerEngine; + } + + public static synchronized void setRpcTrackerEngine(RpcTrackerEngine engine) { + rpcTrackerEngine = engine; + } + + public static synchronized RpcTracker getRpcTracker(URL url) { + if (rpcTrackerEngine == null || rpcTrackerFactory == null) { + return null; + } + String protocol = url.getProtocol(); + RpcTracker rpcTracker = rpcTrackerMap.get(RpcProtocol.valueOf(protocol)); + if (rpcTracker == null) { + rpcTracker = rpcTrackerFactory.createRpcTracker(url); + if (rpcTracker == null) { + throw new IllegalStateException("rpcTracker should not be null here, url: " + url); + } + rpcTrackerMap.put(RpcProtocol.valueOf(protocol), rpcTracker); + } + return rpcTracker; + } + + public static RpcTracker mockRpcTracker(String address, String application) { + String urlStr = "zipkin://" + address + "?application=" + application + "&collector=http"; + URL url = URL.valueOf(urlStr); + return getRpcTracker(url); + } +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerRequestAdapter.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerRequestAdapter.java new file mode 100644 index 00000000000..d3563b624ef --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerRequestAdapter.java @@ -0,0 +1,7 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs. + */ +public interface ServerRequestAdapter extends Traceable{ +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerRequestInterceptor.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerRequestInterceptor.java new file mode 100644 index 00000000000..3502ff3a0be --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerRequestInterceptor.java @@ -0,0 +1,7 @@ +package com.alibaba.dubbo.tracker; + +public interface ServerRequestInterceptor { + + void handle(ServerRequestAdapter serverRequestAdapter); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerResponseAdapter.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerResponseAdapter.java new file mode 100644 index 00000000000..80d56237618 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerResponseAdapter.java @@ -0,0 +1,7 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs. + */ +public interface ServerResponseAdapter extends Traceable { +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerResponseInterceptor.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerResponseInterceptor.java new file mode 100644 index 00000000000..ee5947279b8 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/ServerResponseInterceptor.java @@ -0,0 +1,7 @@ +package com.alibaba.dubbo.tracker; + +public interface ServerResponseInterceptor { + + void handle(ServerResponseAdapter serverResponseAdapter); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TraceId.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TraceId.java new file mode 100644 index 00000000000..a02f3252035 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TraceId.java @@ -0,0 +1,41 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs + */ +public class TraceId { + + public static final TraceId NOT_TRACE = new TraceId(false, ""); + + private final boolean sampled; + + private final String traceId; + + public TraceId(boolean sampled, String traceId) { + this.sampled = sampled; + this.traceId = traceId; + } + + public boolean isSampled() { + return sampled; + } + + public String get() { + return traceId; + } + + @Override + public boolean equals(Object object) { + if (this == object) return true; + if (object == null || getClass() != object.getClass()) { + return false; + } + TraceId that = (TraceId) object; + return traceId.equals(that.traceId); + } + + @Override + public int hashCode() { + return traceId.hashCode(); + } +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TraceIdReporter.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TraceIdReporter.java new file mode 100644 index 00000000000..5a13f382196 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TraceIdReporter.java @@ -0,0 +1,10 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs + */ +public interface TraceIdReporter { + + void report(TraceId traceId); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/Traceable.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/Traceable.java new file mode 100644 index 00000000000..788c5bb304e --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/Traceable.java @@ -0,0 +1,10 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs. + */ +public interface Traceable { + + boolean isTraceable(); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TrackerKeys.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TrackerKeys.java new file mode 100644 index 00000000000..ae1247e59ca --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/TrackerKeys.java @@ -0,0 +1,16 @@ +package com.alibaba.dubbo.tracker; + +/** + * @author Xs. + */ +public class TrackerKeys { + + public static final String PROVIDER_ADDRESS = "provider.address"; + + public static final String REMOTE_METHOD = "remote.method"; + + public static final String SERVICE_VERSION = "service.version"; + + public static final String RETURN_STATUS = "return.status"; + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/exceptions/RequestIllegalException.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/exceptions/RequestIllegalException.java new file mode 100644 index 00000000000..9cace7211ca --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/exceptions/RequestIllegalException.java @@ -0,0 +1,17 @@ +package com.alibaba.dubbo.tracker.exceptions; + +public class RequestIllegalException extends RuntimeException { + + public RequestIllegalException(String message) { + super(message); + } + + public RequestIllegalException(String message, Throwable cause) { + super(message, cause); + } + + public RequestIllegalException(Throwable cause) { + super(cause); + } + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/HttpRequestResponseInterceptorBuilder.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/HttpRequestResponseInterceptorBuilder.java new file mode 100644 index 00000000000..d43777ef1b5 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/HttpRequestResponseInterceptorBuilder.java @@ -0,0 +1,17 @@ +package com.alibaba.dubbo.tracker.http; + +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.extension.Adaptive; +import com.alibaba.dubbo.common.extension.SPI; +import okhttp3.Interceptor; + +/** + * @author Xs. + */ +@SPI("zipkin") +public interface HttpRequestResponseInterceptorBuilder { + + @Adaptive({"tracker"}) + Interceptor build(URL url); + +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/ServletFilter.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/ServletFilter.java new file mode 100644 index 00000000000..18d22ed7bc6 --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/ServletFilter.java @@ -0,0 +1,6 @@ +package com.alibaba.dubbo.tracker.http; + +import javax.servlet.Filter; + +public interface ServletFilter extends Filter { +} diff --git a/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/ServletFilterBuilder.java b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/ServletFilterBuilder.java new file mode 100644 index 00000000000..59240ae9e2d --- /dev/null +++ b/dubbo-tracker/dubbo-tracker-api/src/main/java/com/alibaba/dubbo/tracker/http/ServletFilterBuilder.java @@ -0,0 +1,13 @@ +package com.alibaba.dubbo.tracker.http; + +import com.alibaba.dubbo.common.URL; +import com.alibaba.dubbo.common.extension.Adaptive; +import com.alibaba.dubbo.common.extension.SPI; + +@SPI("zipkin") +public interface ServletFilterBuilder { + + @Adaptive("tracker") + ServletFilter build(URL url); + +} diff --git a/dubbo-tracker/pom.xml b/dubbo-tracker/pom.xml new file mode 100644 index 00000000000..2742ec069bf --- /dev/null +++ b/dubbo-tracker/pom.xml @@ -0,0 +1,18 @@ + + + + dubbo-parent + com.alibaba + 3.0.1 + + 4.0.0 + + dubbo-tracker + pom + + dubbo-tracker-api + + + \ No newline at end of file diff --git a/dubbo/pom.xml b/dubbo/pom.xml index 1ff4074b884..a8202304a01 100644 --- a/dubbo/pom.xml +++ b/dubbo/pom.xml @@ -19,15 +19,17 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 dubbo jar ${project.artifactId} The all in one project of dubbo + false + com.alibaba @@ -156,17 +158,6 @@ - - com.alibaba - dubbo-rpc-thrift - ${project.parent.version} - - - org.apache.thrift - libthrift - - - com.alibaba dubbo-rpc-memcached @@ -318,6 +309,7 @@ + @@ -373,6 +365,7 @@ com.alibaba:hessian-lite com.alibaba:dubbo-common com.alibaba:dubbo-remoting-api + com.alibaba:dubbo-remoting-common com.alibaba:dubbo-remoting-netty com.alibaba:dubbo-remoting-mina com.alibaba:dubbo-remoting-grizzly @@ -386,7 +379,6 @@ com.alibaba:dubbo-rpc-hessian com.alibaba:dubbo-rpc-http com.alibaba:dubbo-rpc-webservice - com.alibaba:dubbo-rpc-thrift com.alibaba:dubbo-rpc-memcached com.alibaba:dubbo-rpc-redis com.alibaba:dubbo-rpc-rest @@ -408,28 +400,36 @@ com.alibaba:dubbo-container-jetty com.alibaba:dubbo-container-log4j com.alibaba:dubbo-container-logback + + com.alibaba:dubbo-tracker-api - META-INF/dubbo/internal/com.alibaba.dubbo.common.compiler.Compiler + META-INF/dubbo/internal/com.alibaba.dubbo.common.compiler.Compiler + - META-INF/dubbo/internal/com.alibaba.dubbo.common.extension.ExtensionFactory + + META-INF/dubbo/internal/com.alibaba.dubbo.common.extension.ExtensionFactory + - META-INF/dubbo/internal/com.alibaba.dubbo.common.serialize.Serialization + META-INF/dubbo/internal/com.alibaba.dubbo.common.serialize.Serialization + - META-INF/dubbo/internal/com.alibaba.dubbo.common.status.StatusChecker + META-INF/dubbo/internal/com.alibaba.dubbo.common.status.StatusChecker + - META-INF/dubbo/internal/com.alibaba.dubbo.common.threadpool.ThreadPool + META-INF/dubbo/internal/com.alibaba.dubbo.common.threadpool.ThreadPool + @@ -441,27 +441,34 @@ - META-INF/dubbo/internal/com.alibaba.dubbo.remoting.Transporter + META-INF/dubbo/internal/com.alibaba.dubbo.remoting.transport.Transporter + - META-INF/dubbo/internal/com.alibaba.dubbo.remoting.exchange.Exchanger + META-INF/dubbo/internal/com.alibaba.dubbo.remoting.exchange.Exchanger + - META-INF/dubbo/internal/com.alibaba.dubbo.remoting.http.HttpBinder + META-INF/dubbo/internal/com.alibaba.dubbo.remoting.http.HttpBinder + - META-INF/dubbo/internal/com.alibaba.dubbo.remoting.p2p.Networker + META-INF/dubbo/internal/com.alibaba.dubbo.remoting.p2p.Networker + - META-INF/dubbo/internal/com.alibaba.dubbo.remoting.telnet.TelnetHandler + META-INF/dubbo/internal/com.alibaba.dubbo.remoting.telnet.TelnetHandler + - META-INF/dubbo/internal/com.alibaba.dubbo.remoting.zookeeper.ZookeeperTransporter + + META-INF/dubbo/internal/com.alibaba.dubbo.remoting.zookeeper.ZookeeperTransporter + @@ -489,7 +496,8 @@ - META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.LoadBalance + META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.LoadBalance + @@ -497,11 +505,14 @@ - META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.RouterFactory + META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.RouterFactory + - META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.ConfiguratorFactory + + META-INF/dubbo/internal/com.alibaba.dubbo.rpc.cluster.ConfiguratorFactory + @@ -509,15 +520,18 @@ - META-INF/dubbo/internal/com.alibaba.dubbo.container.page.PageHandler + META-INF/dubbo/internal/com.alibaba.dubbo.container.page.PageHandler + - META-INF/dubbo/internal/com.alibaba.dubbo.monitor.MonitorFactory + META-INF/dubbo/internal/com.alibaba.dubbo.monitor.MonitorFactory + - META-INF/dubbo/internal/com.alibaba.dubbo.registry.RegistryFactory + META-INF/dubbo/internal/com.alibaba.dubbo.registry.RegistryFactory + @@ -529,11 +543,26 @@ - META-INF/dubbo/internal/com.alibaba.dubbo.common.store.DataStore + META-INF/dubbo/internal/com.alibaba.dubbo.common.store.DataStore + + + + META-INF/dubbo/internal/com.alibaba.dubbo.common.logger.LoggerAdapter + + + + + + META-INF/dubbo/internal/com.alibaba.dubbo.tracker.RpcTrackerFactory + + - META-INF/dubbo/internal/com.alibaba.dubbo.common.logger.LoggerAdapter + META-INF/dubbo/internal/com.alibaba.dubbo.tracker.RpcTrackerEngineFactory + diff --git a/hessian-lite/pom.xml b/hessian-lite/pom.xml index c377884a45e..d5f153a3898 100644 --- a/hessian-lite/pom.xml +++ b/hessian-lite/pom.xml @@ -6,7 +6,7 @@ com.alibaba dubbo-parent - 2.8.4 + 3.0.1 hessian-lite jar diff --git a/hessian-lite/src/main/java/com/alibaba/com/caucho/hessian/io/Hessian2Output.java b/hessian-lite/src/main/java/com/alibaba/com/caucho/hessian/io/Hessian2Output.java index 657d4d2edde..663a78dfc0e 100644 --- a/hessian-lite/src/main/java/com/alibaba/com/caucho/hessian/io/Hessian2Output.java +++ b/hessian-lite/src/main/java/com/alibaba/com/caucho/hessian/io/Hessian2Output.java @@ -130,9 +130,8 @@ public void call(String method, Object []args) int length = args != null ? args.length : 0; startCall(method, length); - - for (int i = 0; i < args.length; i++) - writeObject(args[i]); + + for (Object arg : args) writeObject(arg); completeCall(); } diff --git a/pom.xml b/pom.xml index 2f1517bd3c9..af9d091a83f 100644 --- a/pom.xml +++ b/pom.xml @@ -14,371 +14,382 @@ - limitations under the License. --> - 4.0.0 - - com.alibaba - dubbo-parent - 2.8.4 - pom - ${project.artifactId} - The parent project of dubbo - http://code.alibabatech.com/wiki/display/dubbo - 2011 - - - Apache 2 - http://www.apache.org/licenses/LICENSE-2.0.txt - repo - A business-friendly OSS license - - - - Alibaba - http://www.alibaba.com - - - dubbo-common - dubbo-container - dubbo-remoting - dubbo-rpc - dubbo-filter - dubbo-cluster - dubbo-registry - dubbo-monitor - dubbo-config - dubbo - dubbo-simple - dubbo-admin - dubbo-demo - hessian-lite - - - - - test - - - .project - - - - dubbo-test - - - - hudson - - - - org.apache.maven.plugins - maven-surefire-plugin - - true - - - - - - - - - 3.2.9.RELEASE - 3.20.0-GA - 3.7.0.Final - 1.1.7 - 2.1.4 - 4.2.1 - 3.2.1-fixed-2 - 1.4.1 - 1.1.39 - 3.1 - 0.8 - 3.4.6 - 0.1 - 2.5.0 - 2.1.0 - 1.3.6 - 2.6.1 - 0.8.0 - 1.0.13 - 4.0.7 - 3.1.0 - 6.1.26 - 1.0.0.GA - 4.2.0.Final - 0.4 - 2.0-M5.1 - 3.0 - 2.2 - 3.0.8 + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> + 4.0.0 + + com.alibaba + dubbo-parent + 3.0.1 + pom + ${project.artifactId} + The parent project of dubbo + http://code.alibabatech.com/wiki/display/dubbo + 2011 + + + + Apache 2 + http://www.apache.org/licenses/LICENSE-2.0.txt + repo + A business-friendly OSS license + + + + + Alibaba + http://www.alibaba.com + + + + dubbo-common + dubbo-container + dubbo-remoting + dubbo-rpc + dubbo-filter + dubbo-cluster + dubbo-registry + dubbo-monitor + dubbo-config + dubbo + dubbo-simple + dubbo-admin + dubbo-demo + hessian-lite + dubbo-tracker + + + + + test + + + .project + + + + dubbo-test + + + + hudson + + + + org.apache.maven.plugins + maven-surefire-plugin + + true + + + + + + + + + 3.2.9.RELEASE + 3.20.0-GA + 3.7.0.Final + 1.1.7 + 2.1.4 + 4.2.1 + 3.2.1-fixed-2 + 1.4.1 + 1.1.39 + 3.1 + 0.8 + 3.4.6 + 0.1 + 2.5.0 + 2.1.0 + 1.3.6 + 2.6.1 + 0.8.0 + 1.0.13 + 4.0.7 + 3.1.0 + 6.1.26 + 1.0.0.GA + 4.2.0.Final + 0.4 + 2.0-M5.1 + 3.0 + 2.2 + 3.0.8 2.3.3 1.6 8.0.11 - - 1.6.2 - 1.1 - 1.2.16 - 1.0.6 - - 4.10 - 3.0 - 0.999.8 - - - false - true - ${file_encoding} + + 1.6.2 + 1.1 + 1.2.16 + 1.0.6 + + 4.10 + 3.0 + 0.999.8 + + + false + true + ${file_encoding} - - Copyright 1999-2012 Alibaba Group. Licensed under - the Apache License, Version 2.0 (the "License"); you - may not use this file except in compliance with the License. You - may obtain a copy of the License at - http://www.apache.org/licenses/LICENSE-2.0 Unless required - by applicable law or agreed to in writing, software distributed - under the License is distributed on an "AS IS" - BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either - express or implied. See the License for the specific language - governing permissions and limitations under the License. - oss + + Copyright 1999-2012 Alibaba Group. Licensed under + the Apache License, Version 2.0 (the "License"); you + may not use this file except in compliance with the License. You + may obtain a copy of the License at + http://www.apache.org/licenses/LICENSE-2.0 Unless required + by applicable law or agreed to in writing, software distributed + under the License is distributed on an "AS IS" + BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either + express or implied. See the License for the specific language + governing permissions and limitations under the License. + + oss - - 2.3.2 - 1.6 - 1.6 - UTF-8 + + 2.3.2 + 1.6 + 1.6 + UTF-8 - 2.1.1 - 2.3.2 - 2.1.1 - 2.3.1 - 2.7 + 2.4 + 2.3.2 + 2.1.1 + 2.3.1 + 2.7 2.17 - - - - - - org.springframework - spring-framework-bom - ${spring.bom.version} - pom - import - - - org.javassist - javassist - ${javassist_version} - - - io.netty - netty - ${netty_version} - - - org.apache.mina - mina-core - ${mina_version} - - - org.glassfish.grizzly - grizzly-core - ${grizzly_version} - - - org.apache.httpcomponents - httpclient - ${httpclient_version} - - - com.alibaba - hessian-lite - ${hessian_lite_version} - - - com.alibaba - fastjson - ${fastjson_version} - - - com.thoughtworks.xstream - xstream - ${xstream_version} - - - org.apache.bsf - bsf-api - ${bsf_version} - - - org.jvnet.sorcerer - sorcerer-javac - ${sorcerer_version} - - - org.apache.zookeeper - zookeeper - ${zookeeper_version} - - - com.github.sgroschupf - zkclient - ${zkclient_version} - - - org.apache.curator - curator-framework - ${curator_version} - - - redis.clients - jedis - ${jedis_version} - - - com.googlecode.xmemcached - xmemcached - ${xmemcached_version} - - - org.apache.cxf - cxf-rt-frontend-simple - ${cxf_version} - - - org.apache.cxf - cxf-rt-transports-http - ${cxf_version} - - - org.apache.thrift - libthrift - ${thrift_version} - - - jfree - jfreechart - ${jfreechart_version} - - - com.caucho - hessian - ${hessian_version} - - - javax.servlet - javax.servlet-api - ${servlet_version} - - - org.mortbay.jetty - jetty - ${jetty_version} - - - javax.validation - validation-api - ${validation_version} - - - org.hibernate - hibernate-validator - ${hibernate_validator_version} - - - javax.cache - cache-api - ${jcache_version} - - - org.apache.tuscany.sca - tuscany-sca-api - ${sca_version} - - - com.google.inject - guice - ${guice_version} - - - com.alibaba.citrus - citrus-webx-all - ${webx_version} - - - com.fasterxml.jackson.core - jackson-core - ${jackson_version} - - - com.fasterxml.jackson.core - jackson-databind - ${jackson_version} - - - - org.slf4j - slf4j-api - ${slf4j_version} - - - org.slf4j - slf4j-log4j12 - ${slf4j_version} - - - commons-logging - commons-logging-api - ${jcl_version} - - - log4j - log4j - ${log4j_version} - - - ch.qos.logback - logback-classic - ${logback_version} - - - - junit - junit - ${junit_version} - test - - - org.easymock - easymock - ${easymock_version} - test - - - com.googlecode.jmockit - jmockit - ${jmockit_version} - test - - - org.easymock - easymockclassextension - ${easymock_version} - test - - - cglib - cglib-nodep - ${cglib_version} - - - commons-pool - commons-pool - ${commons_pool_version} - + + + + + + org.springframework + spring-framework-bom + ${spring.bom.version} + pom + import + + + org.javassist + javassist + ${javassist_version} + + + io.netty + netty + ${netty_version} + + + org.apache.mina + mina-core + ${mina_version} + + + org.glassfish.grizzly + grizzly-core + ${grizzly_version} + + + org.apache.httpcomponents + httpclient + ${httpclient_version} + + + com.alibaba + hessian-lite + ${hessian_lite_version} + + + com.alibaba + fastjson + ${fastjson_version} + + + com.thoughtworks.xstream + xstream + ${xstream_version} + + + org.apache.bsf + bsf-api + ${bsf_version} + + + org.jvnet.sorcerer + sorcerer-javac + ${sorcerer_version} + + + org.apache.zookeeper + zookeeper + ${zookeeper_version} + + + com.github.sgroschupf + zkclient + ${zkclient_version} + + + org.apache.curator + curator-framework + ${curator_version} + + + com.google.guava + guava + + + + + redis.clients + jedis + ${jedis_version} + + + com.googlecode.xmemcached + xmemcached + ${xmemcached_version} + + + org.apache.cxf + cxf-rt-frontend-simple + ${cxf_version} + + + org.apache.cxf + cxf-rt-transports-http + ${cxf_version} + + + org.apache.thrift + libthrift + ${thrift_version} + + + jfree + jfreechart + ${jfreechart_version} + + + com.caucho + hessian + ${hessian_version} + + + javax.servlet + javax.servlet-api + ${servlet_version} + + + org.mortbay.jetty + jetty + ${jetty_version} + + + javax.validation + validation-api + ${validation_version} + + + org.hibernate + hibernate-validator + ${hibernate_validator_version} + + + javax.cache + cache-api + ${jcache_version} + + + org.apache.tuscany.sca + tuscany-sca-api + ${sca_version} + + + com.google.inject + guice + ${guice_version} + + + com.alibaba.citrus + citrus-webx-all + ${webx_version} + + + com.fasterxml.jackson.core + jackson-core + ${jackson_version} + + + com.fasterxml.jackson.core + jackson-databind + ${jackson_version} + + + + org.slf4j + slf4j-api + ${slf4j_version} + + + org.slf4j + slf4j-log4j12 + ${slf4j_version} + + + commons-logging + commons-logging-api + ${jcl_version} + + + log4j + log4j + ${log4j_version} + + + ch.qos.logback + logback-classic + ${logback_version} + + + + junit + junit + ${junit_version} + test + + + org.easymock + easymock + ${easymock_version} + test + + + com.googlecode.jmockit + jmockit + ${jmockit_version} + test + + + org.easymock + easymockclassextension + ${easymock_version} + test + + + cglib + cglib-nodep + ${cglib_version} + + + commons-pool + commons-pool + ${commons_pool_version} + org.apache.tomcat.embed tomcat-embed-core @@ -441,287 +452,296 @@ fst 1.55 - - - - - junit - junit - - - org.easymock - easymock - - - org.easymock - easymockclassextension - - - com.googlecode.jmockit - jmockit - - - - - - org.apache.maven.plugins - maven-jar-plugin - - - true - true - - true - true - - - - - - maven-source-plugin - - - attach-sources - package - - jar-no-fork - - - - - - org.apache.maven.plugins - maven-surefire-plugin + + + com.squareup.okhttp3 + okhttp + 3.2.0 + + + + org.apache.commons + commons-lang3 + 3.3.2 + + + + + + + + junit + junit + + + org.easymock + easymock + + + org.easymock + easymockclassextension + + + com.googlecode.jmockit + jmockit + + + + + + org.apache.maven.plugins + maven-jar-plugin + + + true + true + + true + true + + + + + + maven-source-plugin + + + attach-sources + package + + jar-no-fork + + + + 2.4 + + + org.apache.maven.plugins + maven-surefire-plugin ${maven-surefire-plugin_version} - - true - once - ${argline} - - - - transporter - ${transporter} - - - serialization - ${serialization} - - - - port - ${port} - - - threadpool - ${threadpool} - - - threads - ${threads} - - - iothreads - ${iothreads} - - - - server - ${server} - - - timeout - ${timeout} - - - length - ${length} - - - connections - ${connections} - - - base - ${base} - - - concurrent - ${concurrent} - - - runs - ${runs} - - - onerror - ${onerror} - - - - - - org.apache.maven.plugins - maven-deploy-plugin - - ${skip_maven_deploy} - - - + + true + once + ${argline} + + + + transporter + ${transporter} + + + serialization + ${serialization} + + + + port + ${port} + + + threadpool + ${threadpool} + + + threads + ${threads} + + + iothreads + ${iothreads} + + + + server + ${server} + + + timeout + ${timeout} + + + length + ${length} + + + connections + ${connections} + + + base + ${base} + + + concurrent + ${concurrent} + + + runs + ${runs} + + + onerror + ${onerror} + + + + + + org.apache.maven.plugins + maven-deploy-plugin + + ${skip_maven_deploy} + + + - - - - org.apache.maven.plugins - maven-jar-plugin - ${maven_jar_plugin_version} - - - org.apache.maven.plugins - maven-war-plugin - ${maven_war_plugin_version} - - - org.apache.maven.plugins - maven-install-plugin - ${maven_install_plugin_version} - - - org.apache.maven.plugins - maven-deploy-plugin - ${maven_deploy_plugin_version} - - - org.apache.maven.plugins - maven-compiler-plugin - ${maven_compiler_plugin_version} - + + + + org.apache.maven.plugins + maven-jar-plugin + ${maven_jar_plugin_version} + + + org.apache.maven.plugins + maven-war-plugin + ${maven_war_plugin_version} + + + org.apache.maven.plugins + maven-install-plugin + ${maven_install_plugin_version} + + + org.apache.maven.plugins + maven-deploy-plugin + ${maven_deploy_plugin_version} + + + org.apache.maven.plugins + maven-compiler-plugin + ${maven_compiler_plugin_version} + true - ${java_source_version} - ${java_target_version} - ${file_encoding} - - -XX:MaxPermSize=512M - - - - - - org.eclipse.m2e - lifecycle-mapping - 1.0.0 - - - - - - - org.apache.maven.plugins - - - maven-dependency-plugin - - - [2.1,) - - - unpack - - - - - - - - - - - - + ${java_source_version} + ${java_target_version} + ${file_encoding} + + + + + org.eclipse.m2e + lifecycle-mapping + 1.0.0 + + + + + + + org.apache.maven.plugins + + + maven-dependency-plugin + + + [2.1,) + + + unpack + + + + + + + + + - + - - jira - http://code.alibabatech.com/jira/browse/DUBBO - - - http://code.alibabatech.com/svn/dubbo/trunk - scm:svn:http://code.alibabatech.com/svn/dubbo/trunk - - - - Dubbo User Mailling List - dubbo-subscribe AT googlegroups DOT com - dubbo-unsubscribe AT googlegroups DOT com - dubbo AT googlegroups DOT com - http://groups.google.com/group/dubbo - - - - - QianXiao(Shawn) - shawn.qianx - shawn.qianx (AT) alibaba-inc.com - - Developer - - +8 - - - LiangFei(William) - william.liangf - william.liangf (AT) alibaba-inc.com - - Developer - - +8 - - - LiDing(Jerry) - ding.lid - ding.lid (AT) alibaba-inc.com - - Developer - - +8 - - - LiuChao(Charles) - chao.liuc - chao.liuc (AT) alibaba-inc.com - - Developer - - +8 - - - LiuHaoMin(Ludvik) - haoming.liuhm - haoming.liuhm (AT) alibaba-inc.com - - Developer - - +8 - - - ChenLei(Tony) - tony.chenl - tony.chenl (AT) alibaba-inc.com - - Developer - - +8 - - - LvGang(Kimi) - gang.lvg - gang.lvg (AT) alibaba-inc.com - - Developer - - +8 - - + + jira + http://code.alibabatech.com/jira/browse/DUBBO + + + http://code.alibabatech.com/svn/dubbo/trunk + scm:svn:http://code.alibabatech.com/svn/dubbo/trunk + + + + Dubbo User Mailling List + dubbo-subscribe AT googlegroups DOT com + dubbo-unsubscribe AT googlegroups DOT com + dubbo AT googlegroups DOT com + http://groups.google.com/group/dubbo + + + + + QianXiao(Shawn) + shawn.qianx + shawn.qianx (AT) alibaba-inc.com + + Developer + + +8 + + + LiangFei(William) + william.liangf + william.liangf (AT) alibaba-inc.com + + Developer + + +8 + + + LiDing(Jerry) + ding.lid + ding.lid (AT) alibaba-inc.com + + Developer + + +8 + + + LiuChao(Charles) + chao.liuc + chao.liuc (AT) alibaba-inc.com + + Developer + + +8 + + + LiuHaoMin(Ludvik) + haoming.liuhm + haoming.liuhm (AT) alibaba-inc.com + + Developer + + +8 + + + ChenLei(Tony) + tony.chenl + tony.chenl (AT) alibaba-inc.com + + Developer + + +8 + + + LvGang(Kimi) + gang.lvg + gang.lvg (AT) alibaba-inc.com + + Developer + + +8 + +