超时时间

配置超时时间

1.介绍

本示例演示如何在 Dubbo-go 客户端发起调用时设置请求超时时间。可在此查看 完整示例源码地址

2.如何设置请求超时时间

在创建客户端时,可以使用 client.WithRequestTimeout() 方法设置全局超时时间(所有使用改 client 的服务代理共享)。

  1. cli, err := client.NewClient(
  2. client.WithClientURL("tri://127.0.0.1:20000"),
  3. client.WithClientRequestTimeout(3 * time.Second),
  4. )

可以使用 client.WithRequestTimeout() 创建服务粒度的超时时间(以下服务代理 svc 发起的方法调用都使用这个时间)。

  1. svc, err := greet.NewGreetService(cli, client.WithRequestTimeout(5 * time.Second))

也可以在调用发起时,使用 client.WithCallRequestTimeout() 指定一个超时时间

  1. resp, err := svc.GreetTimeout(context.Background(), &greet.GreetRequest{Name: "hello world"}, client.WithCallRequestTimeout(10 * time.Second))

从上往下,以上三种方式的优先级逐步提高,client.WithCallRequestTimeout() 指定的超时时间优先级最高。

3.示例详解

3.1服务端介绍

服务端proto文件

源文件路径:dubbo-go-sample/timeout/proto/greet.proto

  1. syntax = "proto3";
  2. package greet;
  3. option go_package = "github.com/apache/dubbo-go-samples/timeout/proto;greet";
  4. message GreetRequest {
  5. string name = 1;
  6. }
  7. message GreetResponse {
  8. string greeting = 1;
  9. }
  10. service GreetService {
  11. rpc Greet(GreetRequest) returns (GreetResponse) {}
  12. rpc GreetTimeout(GreetRequest) returns (GreetResponse) {}
  13. }

服务端handler文件

Greet方法直接响应,GreetTimeout方法等待五秒后响应(模拟超时)。

源文件路径:dubbo-go-sample/timeout/go-server/handler.go

  1. package main
  2. import (
  3. "context"
  4. "time"
  5. greet "github.com/apache/dubbo-go-samples/timeout/proto"
  6. )
  7. type GreetTripleServer struct {
  8. }
  9. func (srv *GreetTripleServer) Greet(ctx context.Context, req *greet.GreetRequest) (*greet.GreetResponse, error) {
  10. resp := &greet.GreetResponse{Greeting: req.Name}
  11. return resp, nil
  12. }
  13. func (srv *GreetTripleServer) GreetTimeout(ctx context.Context, req *greet.GreetRequest) (*greet.GreetResponse, error) {
  14. time.Sleep(5 * time.Second)
  15. resp := &greet.GreetResponse{Greeting: req.Name}
  16. return resp, nil
  17. }

3.2客户端介绍

客户端client文件,创建客户端,设置超时时间为3s,分别请求GreetGreetTimeout,输出响应结果。

源文件路径:dubbo-go-sample/timeout/go-client/client.go

  1. package main
  2. import (
  3. "context"
  4. "time"
  5. "dubbo.apache.org/dubbo-go/v3/client"
  6. _ "dubbo.apache.org/dubbo-go/v3/imports"
  7. greet "github.com/apache/dubbo-go-samples/timeout/proto"
  8. "github.com/dubbogo/gost/log/logger"
  9. )
  10. func main() {
  11. cli, err := client.NewClient(
  12. client.WithClientURL("tri://127.0.0.1:20000"),
  13. client.WithClientRequestTimeout(3*time.Second),
  14. )
  15. if err != nil {
  16. panic(err)
  17. }
  18. svc, err := greet.NewGreetService(cli)
  19. if err != nil {
  20. panic(err)
  21. }
  22. // test timeout
  23. resp, err := svc.GreetTimeout(context.Background(), &greet.GreetRequest{Name: "hello world"})
  24. if err != nil {
  25. logger.Error("call [greet.GreetService.GreetTimeout] service timeout")
  26. logger.Error(err)
  27. } else {
  28. logger.Infof("Greet response: %s", resp.Greeting)
  29. }
  30. // test normal
  31. resp, err = svc.Greet(context.Background(), &greet.GreetRequest{Name: "hello world"})
  32. if err != nil {
  33. logger.Error(err)
  34. }
  35. logger.Infof("Greet response: %s", resp.Greeting)
  36. }

3.3案例效果

先启动服务端,再启动客户端,可以观察到GreetTimeout请求响应超时,Greet请求响应正常

  1. [call [greet.GreetService.GreetTimeout] service timeout]
  2. Greet response: [hello world]

最后修改 September 13, 2024: Refactor website structure (#2860) (1a4b998f54b)