Skip to content

Commit

Permalink
*fix an issue where inputstream is sometimes lost.
Browse files Browse the repository at this point in the history
Signed-off-by: provenceee <[email protected]>
  • Loading branch information
provenceee committed Nov 29, 2024
1 parent e8b7e3c commit a9155ed
Show file tree
Hide file tree
Showing 32 changed files with 328 additions and 616 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2023-2023 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2023-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -32,7 +32,7 @@ public class LaneTestEntity implements Serializable {
private final boolean enabled;

/**
* 构造方法
* constructor
*
* @param id id
* @param enabled enabled
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2023-2023 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2023-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -53,7 +53,7 @@ public class LaneTest {
private final boolean isExecuteSpringTest;

/**
* 构造方法
* constructor
*/
public LaneTest() {
baseUrl = "http://127.0.0.1:" + System.getProperty("controller.port", "28019") + "/controller/getLaneBy";
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2022-2022 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2022-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -41,7 +41,7 @@ public class ConsumerTest {
private final String dubboVersion;

/**
* 构造方法
* constructor
*/
public ConsumerTest() {
dubboVersion = System.getProperty("dubbo.running.version");
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2022-2022 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2022-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -38,7 +38,7 @@ public class SpringAndDubboTest {
private final String baseUrl;

/**
* 构造方法
* constructor
*/
public SpringAndDubboTest() {
baseUrl = "http://127.0.0.1:" + System.getProperty("controller.port", "28020") + "/consumer/";
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2022-2023 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2022-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -60,7 +60,7 @@ public class RouterTest {
private final boolean isExecuteSpringTest;

/**
* 构造方法
* constructor
*/
public RouterTest() throws InterruptedException {
testTagRouterBaseUrl =
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2023-2023 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2023-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -90,7 +90,7 @@ public class LaneTest {
private final boolean shouldTestWebclient;

/**
* 构造方法
* constructor
*/
public LaneTest() {
springCloudVersion = Optional.ofNullable(System.getenv("SPRING_CLOUD_VERSION")).orElse("Hoxton.RELEASE");
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2022-2023 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2022-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -92,7 +92,7 @@ public class TagRouterTest {
private final String springCloudVersion;

/**
* 构造方法
* constructor
*/
public TagRouterTest() throws InterruptedException {
springCloudVersion = Optional.ofNullable(System.getenv("SPRING_CLOUD_VERSION")).orElse("Hoxton.RELEASE");
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2022-2022 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2022-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -66,7 +66,7 @@ public class UrlInterceptor extends AbstractInterceptor {
private Set<String> supportRules;

/**
* 构造方法
* constructor
*/
public UrlInterceptor() {
config = PluginConfigManager.getPluginConfig(LoadbalancerConfig.class);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2022-2022 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2022-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -32,7 +32,7 @@ public class ClientFactoryDeclarer extends AbstractDeclarer {
private static final String METHOD_NAME = "getInstance";

/**
* 构造方法
* constructor
*/
public ClientFactoryDeclarer() {
super(ENHANCE_CLASS, INTERCEPT_CLASS, METHOD_NAME);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ public class DispatcherServletInterceptor extends AbstractInterceptor {
private Function<Object, String> getRequestUri;

/**
* 构造方法
* constructor
*/
public DispatcherServletInterceptor() {
initFunction();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ public class ServiceDiscoveryRegistryDirectoryInterceptor extends AbstractInterc
private final AtomicBoolean isInitialized = new AtomicBoolean();

/**
* 构造方法
* constructor
*/
public ServiceDiscoveryRegistryDirectoryInterceptor() {
invokerRuleStrategyService = PluginServiceManager.getPluginService(InvokerRuleStrategyService.class);
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
/*
* Copyright (C) 2023-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* 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 io.sermant.router.spring.entity;

import java.util.Set;

/**
* Transparent transmission marks the key entity
*
* @author provenceee
* @since 2023-02-21
*/
public class Keys {
private final Set<String> matchedKeys;

private final Set<String> injectedTags;

/**
* Constructor
*
* @param matchedKeys Label routing transparent transmission markers
* @param injectedTags Swim lane transparent markers
*/
public Keys(Set<String> matchedKeys, Set<String> injectedTags) {
this.matchedKeys = matchedKeys;
this.injectedTags = injectedTags;
}

public Set<String> getMatchedKeys() {
return matchedKeys;
}

public Set<String> getInjectedTags() {
return injectedTags;
}
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (C) 2023-2023 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (C) 2023-2024 Huawei Technologies Co., Ltd. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand All @@ -16,11 +16,18 @@

package io.sermant.router.spring.handler;

import io.sermant.core.plugin.config.PluginConfigManager;
import io.sermant.router.common.cache.AppCache;
import io.sermant.router.common.config.RouterConfig;
import io.sermant.router.common.constants.RouterConstant;
import io.sermant.router.common.handler.Handler;
import io.sermant.router.common.metric.MetricsManager;
import io.sermant.router.common.utils.CollectionUtils;
import io.sermant.router.spring.entity.Keys;

import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
Expand All @@ -32,6 +39,8 @@
* @since 2023-02-21
*/
public abstract class AbstractHandler implements Handler {
private final RouterConfig routerConfig = PluginConfigManager.getPluginConfig(RouterConfig.class);

/**
* From the headers, obtain the request token that needs to be transparently transmitted
*
Expand All @@ -51,4 +60,45 @@ protected Map<String, List<String>> getRequestTag(Map<String, List<String>> head
}
return map;
}
}

/**
* Obtain transparent tags
*
* @param path The path of the request
* @param methodName http method
* @param headers HTTP request headers
* @param parameters URL parameter
* @param keys The key of the tag to be obtained
* @return Marks for transparent transmission
*/
public abstract Map<String, List<String>> getRequestTag(String path, String methodName,
Map<String, List<String>> headers, Map<String, List<String>> parameters, Keys keys);

/**
* Collect Lane Count Metric.
*
* @param laneTag lane tag
*/
protected void collectLaneCountMetric(Map<String, List<String>> laneTag) {
if (!routerConfig.isEnableMetric()) {
return;
}
Set<String> tagValues = new HashSet<>();
laneTag.forEach((key, values) -> {
if (CollectionUtils.isEmpty(values)) {
return;
}
values.forEach(tagValue -> {
if (tagValues.contains(tagValue)) {
return;
}
tagValues.add(tagValue);
Map<String, String> tagsMap = new HashMap<>();
tagsMap.put(RouterConstant.LANE_TAG, key + ":" + tagValue);
tagsMap.put(RouterConstant.CLIENT_SERVICE_NAME, AppCache.INSTANCE.getAppName());
tagsMap.put(RouterConstant.PROTOCOL, RouterConstant.HTTP_PROTOCOL);
MetricsManager.addOrUpdateCounterMetricValue(RouterConstant.LANE_TAG_COUNT, tagsMap, 1);
});
});
}
}

This file was deleted.

Loading

0 comments on commit a9155ed

Please sign in to comment.