client.go 1.7 KB

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