package main import ( "context" "flag" "github.com/zeromicro/go-zero/core/conf" "github.com/zeromicro/go-zero/core/logx" "github.com/zeromicro/go-zero/core/service" "github.com/zeromicro/go-zero/rest" "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/config" "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/cron" "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/handler" "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/mqs" "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/svc" commonConfig "gitlink.org.cn/jcce-pcm/utils/nacos" ) var configFile = flag.String("f", "api/etc/pcm.yaml", "the config file") func main() { flag.Parse() var bootstrapConfig commonConfig.BootstrapConfig conf.MustLoad(*configFile, &bootstrapConfig) //解析业务配置 var c config.Config nacosConfig := bootstrapConfig.NacosConfig serviceConfigContent := nacosConfig.InitConfig(func(data string) { err := conf.LoadFromYamlBytes([]byte(data), &c) if err != nil { panic(err) } }) err := conf.LoadFromYamlBytes([]byte(serviceConfigContent), &c) if err != nil { panic(err) } // 注册到nacos nacosConfig.DiscoveryRest(&c.RestConf) serviceGroup := service.NewServiceGroup() defer serviceGroup.Stop() server := rest.MustNewServer(c.RestConf, rest.WithCors()) ctx := svc.NewServiceContext(c) // start log component logx.MustSetup(c.LogConf) ctx.Cron.Start() cron.AddCronGroup(ctx) handler.RegisterHandlers(server, ctx) serviceGroup.Add(server) services := []service.Service{ mqs.MustNewQueue("ai", ctx.RedisClient, mqs.NewAiMq(context.Background(), ctx)), mqs.MustNewQueue("cloud", ctx.RedisClient, mqs.NewCloudMq(context.Background(), ctx)), mqs.MustNewQueue("hpc", ctx.RedisClient, mqs.NewHpcMq(context.Background(), ctx)), } for _, mq := range services { serviceGroup.Add(mq) } logx.Infof("Starting server at %s:%d...\n", c.Host, c.Port) serviceGroup.Start() }