Comments (1)
🤖
The issue you're experiencing might be due to the gRPC connection going into the IDLE state and not being able to recover when the service instance changes. This could be a problem with the gRPC resolver not being able to update the connection when the service instance changes.
To resolve this issue, you can try to add a custom gRPC resolver that can handle the service instance changes more effectively. Here's an example of how you can do this:
package main
import (
"github.com/go-kratos/kratos/v2/transport/grpc/resolver"
"google.golang.org/grpc/resolver"
)
type customBuilder struct {
discovery registry.Discovery
}
func (b *customBuilder) Build(target resolver.Target, cc resolver.ClientConn, opts resolver.BuildOptions) (resolver.Resolver, error) {
r := &customResolver{
target: target,
cc: cc,
d: b.discovery,
}
r.start()
return r, nil
}
func (b *customBuilder) Scheme() string {
return "custom"
}
type customResolver struct {
target resolver.Target
cc resolver.ClientConn
d registry.Discovery
}
func (r *customResolver) start() {
// Implement your logic to watch the service instance changes and update the gRPC connection accordingly.
}
func (r *customResolver) ResolveNow(resolver.ResolveNowOptions) {}
func (r *customResolver) Close() {}
func main() {
// Register your custom resolver builder.
resolver.Register(&customBuilder{discovery: yourDiscovery})
// Use your custom resolver when dialing.
conn, err := grpc.Dial("custom:///your-service-name", grpc.WithInsecure())
}
In the start
method of the customResolver
, you should implement your logic to watch the service instance changes from the registry.Discovery
and call resolver.ClientConn.UpdateState
to update the gRPC connection accordingly.
Please replace yourDiscovery
and your-service-name
with your actual discovery instance and service name.
This way, when the service instance changes, your custom resolver can update the gRPC connection to point to the latest service instance, which should resolve the issue you're experiencing.
You can refer to the transport/grpc/client.go for more details on how gRPC connections are handled in Kratos.
As for how Kratos handles gRPC connections entering idle mode, I wasn't able to find specific information within the repository. It's possible that this behavior is managed by the underlying gRPC library rather than Kratos itself. If you have more specific questions or need further clarification, please let me know!
Sources
This response is meant to be useful and save you time. It is not meant to be a precise solution, but rather a starting point for your own research.
Help me be more useful! Please leave a 👍 if this is helpful and 👎 if it is irrelevant.
If you want to continue the conversation, start your reply with @dosu-bot.
from kratos.
Related Issues (20)
- [Question] http API returns json parameter name not as expected HOT 7
- In version 1.0.0, Mergo moves to a vanity URL: dario.cat/mergo. Can update to the latest version? HOT 6
- How to configure when dealing with multiple DB instances? Are there any practices?[Question] HOT 5
- [Question]Why kratos load yaml as json and unmarshal to struct HOT 1
- 使用openapiv2,出现protoc-gen-openapiv2/options/annotations.proto: File not found. HOT 3
- After rpc call, error cannot be returned correctly HOT 3
- [Question]After rpc call, error cannot be returned correctly [rpc调用后,错误无法解析] HOT 4
- [Feature] Logo adjustment suggestions HOT 2
- Unable to customize http.ResponseWriter because of wrong implementation of Kratos' http.wrapper.Result() HOT 4
- Test failed on different time zone. HOT 1
- [Question]Why design middleware after bind? HOT 1
- [Question] Shall we follow the behavior of the document of http.ResponseWriter? HOT 1
- kratos run runs successfully but docker run fails HOT 5
- Issue with configuration file to render the values from environment variables HOT 7
- [Question]Use make config under windows to report an error HOT 3
- github.com/go-kratos/kratos/pkg/cache/redis 代码找不到了, 新版位置在哪里啊 HOT 6
- [Feature] log Helper sprint, sprintf is executed before Filter Level, the performance consumption is very high HOT 3
- [Question]Transaction nested conflict stuck HOT 3
- [Feature] consule register need suport tags[] HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from kratos.