main.go 3.2 KB

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