client.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  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. clientName string,
  22. endpointNameKey string, option *DialOption) (*grpc2.ClientConn, error) {
  23. option = checkOption(option)
  24. if _, ok := connMap[clientName]; ok {
  25. return connMap[clientName], nil
  26. }
  27. endpoint := grpc.WithEndpoint(endpointNameKey)
  28. option.Middlewares = append(option.Middlewares, logging.Client(logger))
  29. if r == nil {
  30. return nil, nil
  31. }
  32. conn, err := grpc.DialInsecure(context.Background(),
  33. endpoint,
  34. grpc.WithDiscovery(r),
  35. grpc.WithMiddleware(option.Middlewares...),
  36. grpc.WithTimeout(option.Timeout),
  37. grpc.WithOptions(option.GrpcOptions...),
  38. )
  39. if err != nil {
  40. return nil, err
  41. }
  42. connMap[clientName] = conn
  43. return conn, nil
  44. }
  45. func checkOption(option *DialOption) *DialOption {
  46. if option == nil {
  47. option = &DialOption{
  48. Middlewares: make([]middleware.Middleware, 0),
  49. Timeout: time.Second * 60,
  50. }
  51. }
  52. if option.Timeout.Milliseconds() == 0 {
  53. option.Timeout = time.Second * 60
  54. }
  55. if len(option.GrpcOptions) == 0 {
  56. option.GrpcOptions = append(option.GrpcOptions, grpc2.WithDefaultCallOptions(grpc2.MaxCallRecvMsgSize(ReceiveMsgSize)))
  57. }
  58. return option
  59. }