From d696edd8002facc8d01907635eec8d1f03a61bab Mon Sep 17 00:00:00 2001 From: chenzhiguo Date: Fri, 10 May 2024 19:45:08 +0800 Subject: [PATCH] Adjust the definition of limit strategy --- .../invoke/ratelimit/AbstractRateLimiter.java | 14 +------- .../invoke/ratelimit/RateLimiter.java | 4 --- .../service/limit/AbstractLimitPolicy.java | 6 ++++ .../service/limit/ConcurrencyLimitPolicy.java | 6 ---- .../main/assembly/config/microservice.json | 35 ++++++++++++++++--- 5 files changed, 38 insertions(+), 27 deletions(-) diff --git a/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/invoke/ratelimit/AbstractRateLimiter.java b/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/invoke/ratelimit/AbstractRateLimiter.java index 88446131b..54eeebb6c 100644 --- a/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/invoke/ratelimit/AbstractRateLimiter.java +++ b/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/invoke/ratelimit/AbstractRateLimiter.java @@ -55,19 +55,7 @@ public abstract class AbstractRateLimiter implements RateLimiter { public AbstractRateLimiter(RateLimitPolicy policy) { this.policy = policy; this.option = MapOption.of(policy.getActionParameters()); - this.timeout = getTimeout(option); - } - - /** - * Retrieves the timeout duration for permit acquisition based on the provided option. - * The timeout is determined by the `maxWaitMs` parameter set in actionParameters. - * - * @param option The option that may contain the max wait time in milliseconds. - * @return The timeout duration as a Duration object. - */ - protected Duration getTimeout(Option option) { - // The timeout period is set by `maxWaitMs` set in actionParameters - return Duration.ofMillis(option.getLong(MAX_WAIT_MS, DEFAULT_MAX_WAIT_MS)); + this.timeout = Duration.ofMillis(policy.getMaxWaitMs()); } @Override diff --git a/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/invoke/ratelimit/RateLimiter.java b/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/invoke/ratelimit/RateLimiter.java index 5abb20f21..683585279 100644 --- a/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/invoke/ratelimit/RateLimiter.java +++ b/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/invoke/ratelimit/RateLimiter.java @@ -28,10 +28,6 @@ public interface RateLimiter { String MAX_BURST_SECONDS = "maxBurstSeconds"; - String MAX_WAIT_MS = "maxWaitMs"; - - long DEFAULT_MAX_WAIT_MS = 0L; - /** * Try to get a permit return the result * diff --git a/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/policy/service/limit/AbstractLimitPolicy.java b/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/policy/service/limit/AbstractLimitPolicy.java index af7c22da5..c67119d59 100644 --- a/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/policy/service/limit/AbstractLimitPolicy.java +++ b/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/policy/service/limit/AbstractLimitPolicy.java @@ -64,6 +64,12 @@ public abstract class AbstractLimitPolicy extends PolicyId implements LimitPolic */ private String strategyType; + /** + * The maximum time, in milliseconds, a request can wait to be executed before it is rejected, when the maximum + * concurrency or rate limit has been reached. + */ + private long maxWaitMs; + /** * A map of parameters that further customize the action of the limiting strategy. */ diff --git a/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/policy/service/limit/ConcurrencyLimitPolicy.java b/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/policy/service/limit/ConcurrencyLimitPolicy.java index 5c745ccb4..fb7a10255 100644 --- a/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/policy/service/limit/ConcurrencyLimitPolicy.java +++ b/joylive-core/joylive-governance-api/src/main/java/com/jd/live/agent/governance/policy/service/limit/ConcurrencyLimitPolicy.java @@ -51,12 +51,6 @@ public class ConcurrencyLimitPolicy extends AbstractLimitPolicy implements Polic */ private int maxConcurrency; - /** - * The maximum time, in milliseconds, a request can wait to be executed before it is rejected, when the maximum - * concurrency limit has been reached. - */ - private long maxWaitMs; - /** * Constructs a new {@code ConcurrencyLimitPolicy} with default settings. */ diff --git a/joylive-package/src/main/assembly/config/microservice.json b/joylive-package/src/main/assembly/config/microservice.json index b7d89032a..aafe21f5a 100644 --- a/joylive-package/src/main/assembly/config/microservice.json +++ b/joylive-package/src/main/assembly/config/microservice.json @@ -28,8 +28,8 @@ "timeWindowInMs": 2000 } ], + "maxWaitMs": 100, "actionParameters": { - "maxWaitMs": 100 }, "relationType": "AND", "conditions": [ @@ -96,8 +96,13 @@ "retry": 10, "retryInterval": 1000, "timeout": 5000, - "retryStatuses": [500, 502], - "retryExceptions": ["java.lang.NullPointException"], + "retryStatuses": [ + 500, + 502 + ], + "retryExceptions": [ + "java.lang.NullPointException" + ], "version": 1704038400000 }, "rateLimitPolicies": [ @@ -115,8 +120,30 @@ "timeWindowInMs": 2000 } ], + "maxWaitMs": 100, + "actionParameters": { + }, + "relationType": "AND", + "conditions": [ + { + "type": "header", + "opType": "EQUAL", + "key": "x-live-ext-demo", + "value": [ + "abc" + ] + } + ] + } + ], + "concurrencyLimitPolicies": [ + { + "name": "limit-rule-2", + "version": 1704038400000, + "strategyType": "Resilience4j", + "maxConcurrency": 10, + "maxWaitMs": 100, "actionParameters": { - "maxWaitMs": 100 }, "relationType": "AND", "conditions": [