-
Notifications
You must be signed in to change notification settings - Fork 31
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add Configurable Max Retries for get_config in ConfigService #242
Conversation
src/api/props.rs
Outdated
@@ -26,6 +26,8 @@ pub struct ClientProps { | |||
client_version: String, | |||
/// auth context | |||
auth_context: HashMap<String, String>, | |||
/// max retries | |||
max_retries: Option<i32>, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
次数肯定非负,考虑 u32 ?与 retry_count
一同修改
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👌 retry_count 我一起改为 u32
@@ -480,6 +483,13 @@ where | |||
debug_span!(parent: None, "grpc_connection", id = self.id.clone()).entered(); | |||
|
|||
loop { | |||
if let Some(max_retries) = self.max_retries { | |||
if self.retry_count >= max_retries { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
这里是提前判断了,很可能需要的是 self.retry_count > max_retries
,比如 max_retries=1 时,应该有一次重试的机会。max_retries=0 才不回有任何重试
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👌
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
This pull request seeks to address the issue described in #241, where the get_config method in ConfigService blocks the main thread if the connection to the configuration server fails. The main issue arises from NacosGrpcConnection’s poll_ready method, which continuously retries without a limit.
Changes Introduced:
Rationale:
Implementing a maximum retries limit offers greater control over service initialization, ensuring that services are not indefinitely blocked by failed attempts to fetch remote configurations.