main.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. package main
  2. import (
  3. "context"
  4. "fmt"
  5. mgrpc "github.com/go-micro/plugins/v4/client/grpc"
  6. "github.com/go-micro/plugins/v4/registry/consul"
  7. mhttp "github.com/go-micro/plugins/v4/server/http"
  8. "github.com/redis/go-redis/v9"
  9. "github.com/sirupsen/logrus"
  10. "go-micro.dev/v4"
  11. "go-micro.dev/v4/logger"
  12. "go-micro.dev/v4/registry"
  13. "go.opentelemetry.io/otel"
  14. "go.opentelemetry.io/otel/propagation"
  15. "os"
  16. "sghgogs.com/micro/shopping-service-client/config"
  17. "sghgogs.com/micro/shopping-service-client/router"
  18. "sghgogs.com/micro/shopping-service-client/utils/authutil"
  19. "sghgogs.com/micro/shopping-service-client/utils/miniohelper"
  20. "sghgogs.com/micro/shopping-service-client/utils/tracing"
  21. "time"
  22. )
  23. const (
  24. version = "1.0.0"
  25. endpoint = "127.0.0.1:9000"
  26. accessKey = "N7nb2yRoNtkbvq7l3xAv"
  27. secretKey = "FbJiQGN8xHLpddsjexDj274M06mKLfeB4rN9bqEQ"
  28. )
  29. // @title Swagger Example API
  30. // @version 1.0.0
  31. // @description This is a sample server celler server.
  32. // @termsOfService http://swagger.io/terms/
  33. // @contact.name API Support
  34. // @contact.url http://www.swagger.io/support
  35. // @contact.email support@swagger.io
  36. // @license.name Apache 2.0
  37. // @license.url http://www.apache.org/licenses/LICENSE-2.0.html
  38. // @host localhost:8106
  39. // @BasePath /v1/api/shopping
  40. // @securityDefinitions.basic BasicAuth
  41. // @externalDocs.description OpenAPI
  42. // @externalDocs.url https://swagger.io/resources/open-api/
  43. func main() {
  44. if err := config.Load(); err != nil {
  45. logrus.Fatal(err)
  46. }
  47. if cfg := config.RedisAddress(); cfg.Enable {
  48. authutil.NewJWTAuth(redis.NewClient(&redis.Options{
  49. Addr: cfg.URL, // Redis 服务器地址
  50. Password: cfg.Password, // Redis 密码,如果有的话
  51. DB: 0, // 默认数据库
  52. }), config.ShoppingClientName(), cfg.Enable)
  53. }
  54. minioClient, err := miniohelper.NewMinioClient(endpoint, accessKey, secretKey)
  55. fmt.Println("minioClient err", err)
  56. srv := micro.NewService(
  57. micro.Server(mhttp.NewServer()),
  58. micro.Client(mgrpc.NewClient()),
  59. )
  60. authService := authutil.JWTAuthService.Auth
  61. opts := []micro.Option{
  62. micro.Name(config.ShoppingClientName()),
  63. micro.Version(version),
  64. micro.Address(config.Address()),
  65. micro.Auth(
  66. authService,
  67. ),
  68. }
  69. if cfg := config.Tracing(); cfg.Enable {
  70. tp, err := tracing.NewTracerProvider(config.ShoppingClientName(), version, srv.Server().Options().Id, cfg.Jaeger.URL)
  71. if err != nil {
  72. logger.Fatal(err)
  73. }
  74. defer func() {
  75. ctx, cancel := context.WithTimeout(context.Background(), time.Second*5)
  76. defer cancel()
  77. if err = tp.Shutdown(ctx); err != nil {
  78. logger.Fatal(err)
  79. }
  80. }()
  81. otel.SetTracerProvider(tp)
  82. otel.SetTextMapPropagator(propagation.NewCompositeTextMapPropagator(propagation.TraceContext{}, propagation.Baggage{}))
  83. }
  84. if cfg := config.Registry(); cfg.Enable {
  85. consul := consul.NewRegistry(func(options *registry.Options) {
  86. options.Addrs = []string{
  87. cfg.Consul.URL,
  88. }
  89. })
  90. opts = append(opts, micro.Registry(consul))
  91. }
  92. srv.Init(opts...)
  93. log := logrus.New()
  94. log.Level = logrus.DebugLevel
  95. log.Formatter = &logrus.JSONFormatter{
  96. FieldMap: logrus.FieldMap{
  97. logrus.FieldKeyTime: "timestamp",
  98. logrus.FieldKeyLevel: "severity",
  99. logrus.FieldKeyMsg: "message",
  100. },
  101. TimestampFormat: time.RFC3339Nano,
  102. }
  103. log.Out = os.Stdout
  104. client := srv.Client()
  105. if err = micro.RegisterHandler(srv.Server(), router.NewRouter(
  106. config.ShoppingServiceName(),
  107. client,
  108. minioClient,
  109. )); err != nil {
  110. logger.Fatal(err)
  111. }
  112. logrus.Info("Run server")
  113. if err := srv.Run(); err != nil {
  114. logger.Fatal("run", err)
  115. }
  116. }