client.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package grpc
  2. import (
  3. "context"
  4. "time"
  5. "git.ikuban.com/server/kratos-nacos/registry"
  6. "git.ikuban.com/server/kratos-utils/http/middleware/logging"
  7. "github.com/go-kratos/kratos/v2/log"
  8. "github.com/go-kratos/kratos/v2/middleware"
  9. "github.com/go-kratos/kratos/v2/transport/grpc"
  10. grpc2 "google.golang.org/grpc"
  11. )
  12. var connMap = make(map[string]*grpc2.ClientConn)
  13. type DialOption struct {
  14. Middlewares []middleware.Middleware
  15. Timeout time.Duration
  16. GrpcOptions []grpc2.DialOption
  17. }
  18. func GetDialInsecure(
  19. r *registry.Registry,
  20. logger log.Logger,
  21. endpointNameKey string, option *DialOption) (*grpc2.ClientConn, error) {
  22. option = checkOption(option)
  23. if _, ok := connMap[endpointNameKey]; ok {
  24. return connMap[endpointNameKey], nil
  25. }
  26. endpoint := grpc.WithEndpoint(endpointNameKey)
  27. option.Middlewares = append(option.Middlewares, logging.Client(logger))
  28. if r == nil {
  29. return nil, nil
  30. }
  31. conn, err := grpc.DialInsecure(context.Background(),
  32. endpoint,
  33. grpc.WithDiscovery(r),
  34. grpc.WithMiddleware(option.Middlewares...),
  35. grpc.WithTimeout(option.Timeout),
  36. grpc.WithOptions(option.GrpcOptions...),
  37. )
  38. if err != nil {
  39. return nil, err
  40. }
  41. connMap[endpointNameKey] = conn
  42. return conn, nil
  43. }
  44. func checkOption(option *DialOption) *DialOption {
  45. if option == nil {
  46. option = &DialOption{
  47. Middlewares: make([]middleware.Middleware, 0),
  48. Timeout: time.Second * 60,
  49. }
  50. }
  51. if option.Timeout.Milliseconds() == 0 {
  52. option.Timeout = time.Second * 60
  53. }
  54. if len(option.GrpcOptions) == 0 {
  55. option.GrpcOptions = append(option.GrpcOptions, grpc2.WithDefaultCallOptions(grpc2.MaxCallRecvMsgSize(ReceiveMsgSize)))
  56. }
  57. return option
  58. }