This is an automated email from the ASF dual-hosted git repository.
wujimin pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/servicecomb-java-chassis.git
The following commit(s) were added to refs/heads/master by this push:
new 0ec976d [SCB-2127]when timeout, will not isolate service
0ec976d is described below
commit 0ec976d29b77b07601e3514d12794d52b5793b22
Author: liubao <[email protected]>
AuthorDate: Thu Nov 26 14:20:43 2020 +0800
[SCB-2127]when timeout, will not isolate service
---
.../servicecomb/demo/jaxrs/client/JaxrsClient.java | 43 ----------
.../demo/jaxrs/client/TestClientTimeout.java | 96 ++++++++++++++++++++++
.../loadbalance/LoadbalanceHandler.java | 3 +-
3 files changed, 98 insertions(+), 44 deletions(-)
diff --git
a/demo/demo-jaxrs/jaxrs-client/src/main/java/org/apache/servicecomb/demo/jaxrs/client/JaxrsClient.java
b/demo/demo-jaxrs/jaxrs-client/src/main/java/org/apache/servicecomb/demo/jaxrs/client/JaxrsClient.java
index ae6a7dd..9ee4b40 100644
---
a/demo/demo-jaxrs/jaxrs-client/src/main/java/org/apache/servicecomb/demo/jaxrs/client/JaxrsClient.java
+++
b/demo/demo-jaxrs/jaxrs-client/src/main/java/org/apache/servicecomb/demo/jaxrs/client/JaxrsClient.java
@@ -25,7 +25,6 @@ import javax.ws.rs.core.Response.Status;
import org.apache.http.HttpStatus;
import org.apache.servicecomb.common.rest.codec.RestObjectMapperFactory;
-import org.apache.servicecomb.core.Const;
import org.apache.servicecomb.demo.CategorizedTestCaseRunner;
import org.apache.servicecomb.demo.CodeFirstRestTemplate;
import org.apache.servicecomb.demo.DemoConst;
@@ -84,7 +83,6 @@ public class JaxrsClient {
codeFirstClient.testCodeFirst(templateNew, "jaxrs", "/codeFirstJaxrs/");
testCompute(templateNew);
testValidator(templateNew);
- testClientTimeOut(templateNew);
testJaxRSDefaultValuesAllTransport(templateNew);
testSpringMvcDefaultValuesJavaPrimitiveAllTransport(templateNew);
@@ -479,47 +477,6 @@ public class JaxrsClient {
TestMgr.check("hello test 15", result);
}
- private static void testClientTimeOut(RestTemplate template) {
- String microserviceName = "jaxrs";
- for (String transport : DemoConst.transports) {
- if (transport.equals(Const.ANY_TRANSPORT)) {
- continue;
- }
- ArchaiusUtils.setProperty("servicecomb.references.transport." +
microserviceName, transport);
- TestMgr.setMsg(microserviceName, transport);
-
- String cseUrlPrefix = "cse://" + microserviceName + "/clientreqtimeout/";
-
- testClientTimeoutSayHi(template, cseUrlPrefix);
- testClientTimeoutAdd(template, cseUrlPrefix);
- }
- }
-
- private static void testClientTimeoutSayHi(RestTemplate template, String
cseUrlPrefix) {
- Student student = new Student();
- student.setName("timeout");
- student.setAge(30);
- Student result = template.postForObject(cseUrlPrefix + "sayhello",
student, Student.class);
- TestMgr.check("hello timeout 30", result);
- }
-
- private static void testClientTimeoutAdd(RestTemplate template, String
cseUrlPrefix) {
- Map<String, String> params = new HashMap<>();
- params.put("a", "5");
- params.put("b", "20");
- boolean isExcep = false;
- try {
- template.postForObject(cseUrlPrefix + "add", params, Integer.class);
- } catch (InvocationException e) {
- isExcep = true;
- // implement timeout with same error code and message for rest and
highway
- TestMgr.check(408, e.getStatus().getStatusCode());
- TestMgr.check(true,
- e.getErrorData().toString().contains("CommonExceptionData
[message=Request Timeout. Details:"));
- }
-
- TestMgr.check(true, isExcep);
- }
private static void testSpringMvcDefaultValuesJavaPrimitiveRest(RestTemplate
template) {
String microserviceName = "jaxrs";
diff --git
a/demo/demo-jaxrs/jaxrs-client/src/main/java/org/apache/servicecomb/demo/jaxrs/client/TestClientTimeout.java
b/demo/demo-jaxrs/jaxrs-client/src/main/java/org/apache/servicecomb/demo/jaxrs/client/TestClientTimeout.java
new file mode 100644
index 0000000..9c3ea15
--- /dev/null
+++
b/demo/demo-jaxrs/jaxrs-client/src/main/java/org/apache/servicecomb/demo/jaxrs/client/TestClientTimeout.java
@@ -0,0 +1,96 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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 org.apache.servicecomb.demo.jaxrs.client;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import org.apache.servicecomb.demo.CategorizedTestCase;
+import org.apache.servicecomb.demo.TestMgr;
+import org.apache.servicecomb.demo.validator.Student;
+import org.apache.servicecomb.loadbalance.ServiceCombLoadBalancerStats;
+import org.apache.servicecomb.loadbalance.ServiceCombServer;
+import org.apache.servicecomb.loadbalance.ServiceCombServerStats;
+import org.apache.servicecomb.provider.springmvc.reference.RestTemplateBuilder;
+import org.apache.servicecomb.registry.DiscoveryManager;
+import org.apache.servicecomb.registry.RegistrationManager;
+import org.apache.servicecomb.registry.cache.InstanceCache;
+import org.apache.servicecomb.swagger.invocation.exception.InvocationException;
+import org.springframework.stereotype.Component;
+import org.springframework.web.client.RestTemplate;
+
+@Component
+public class TestClientTimeout implements CategorizedTestCase {
+ private static RestTemplate template = RestTemplateBuilder.create();
+
+ public void testAllTransport() throws Exception {
+ testClientTimeOut(template);
+ }
+
+ private static void testClientTimeOut(RestTemplate template) {
+ String microserviceName = "jaxrs";
+
+ String cseUrlPrefix = "cse://" + microserviceName + "/clientreqtimeout/";
+
+ testClientTimeoutSayHi(template, cseUrlPrefix);
+ testClientTimeoutAdd(template, cseUrlPrefix);
+ }
+
+ private static void testClientTimeoutSayHi(RestTemplate template, String
cseUrlPrefix) {
+ Student student = new Student();
+ student.setName("timeout");
+ student.setAge(30);
+ Student result = template.postForObject(cseUrlPrefix + "sayhello",
student, Student.class);
+ TestMgr.check("hello timeout 30", result);
+ }
+
+ private static void testClientTimeoutAdd(RestTemplate template, String
cseUrlPrefix) {
+ Map<String, String> params = new HashMap<>();
+ params.put("a", "5");
+ params.put("b", "20");
+ boolean failed = false;
+ long failures = 0;
+ ServiceCombServerStats serviceCombServerStats = null;
+ try {
+ serviceCombServerStats = getServiceCombServerStats();
+ failures = serviceCombServerStats.getContinuousFailureCount();
+ template.postForObject(cseUrlPrefix + "add", params, Integer.class);
+ } catch (InvocationException e) {
+ failed = true;
+ // implement timeout with same error code and message for rest and
highway
+ TestMgr.check(408, e.getStatus().getStatusCode());
+ TestMgr.check(true,
+ e.getErrorData().toString().contains("CommonExceptionData
[message=Request Timeout. Details:"));
+ TestMgr.check(serviceCombServerStats.getContinuousFailureCount(),
failures + 1);
+ }
+
+ TestMgr.check(true, failed);
+ }
+
+ private static ServiceCombServerStats getServiceCombServerStats() {
+ InstanceCache instanceCache =
DiscoveryManager.INSTANCE.getInstanceCacheManager()
+ .getOrCreate(RegistrationManager.INSTANCE.getAppId(),
+ "jaxrs", "0+");
+ org.apache.servicecomb.registry.api.registry.MicroserviceInstance
microserviceInstance = instanceCache
+ .getInstanceMap().values().iterator().next();
+ ServiceCombServer serviceCombServer = ServiceCombLoadBalancerStats.INSTANCE
+ .getServiceCombServer(microserviceInstance);
+ return ServiceCombLoadBalancerStats.INSTANCE
+ .getServiceCombServerStats(serviceCombServer);
+ }
+}
diff --git
a/handlers/handler-loadbalance/src/main/java/org/apache/servicecomb/loadbalance/LoadbalanceHandler.java
b/handlers/handler-loadbalance/src/main/java/org/apache/servicecomb/loadbalance/LoadbalanceHandler.java
index 8f7a524..dc507c6 100644
---
a/handlers/handler-loadbalance/src/main/java/org/apache/servicecomb/loadbalance/LoadbalanceHandler.java
+++
b/handlers/handler-loadbalance/src/main/java/org/apache/servicecomb/loadbalance/LoadbalanceHandler.java
@@ -441,7 +441,8 @@ public class LoadbalanceHandler implements Handler {
if (InvocationException.class.isInstance(resp.getResult())) {
InvocationException e = (InvocationException) resp.getResult();
return e.getStatusCode() == ExceptionFactory.CONSUMER_INNER_STATUS_CODE
- || e.getStatusCode() == 503;
+ || e.getStatusCode() == Status.SERVICE_UNAVAILABLE.getStatusCode()
+ || e.getStatusCode() == Status.REQUEST_TIMEOUT.getStatusCode();
} else {
return true;
}