You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

72 lines
2.3 KiB

package main
import (
common "git.mashibing.com/msb_47094/shopping-comm"
consul "github.com/asim/go-micro/plugins/registry/consul/v4"
"github.com/go-micro/plugins/v4/wrapper/monitoring/prometheus"
ratelimiter "github.com/go-micro/plugins/v4/wrapper/ratelimiter/uber"
opentracing2 "github.com/go-micro/plugins/v4/wrapper/trace/opentracing"
"github.com/opentracing/opentracing-go"
"go-micro.dev/v4"
"go-micro.dev/v4/registry"
"log"
"time"
"trade-order/domain/repository"
"trade-order/domain/service"
"trade-order/handler"
"trade-order/proto"
)
func main() {
//0 配置中心
consulConfig, err := common.GetConsulConfig(common.ConsulStr, common.TradeFileKey)
if err != nil {
log.Println("consulConfig err :", err)
}
// 1.consul注册中心
consulReist := consul.NewRegistry(func(options *registry.Options) {
options.Addrs = []string{common.ConsulReistStr}
})
//链路追踪实列化 注意addr是 jaeper地址 端口号6831
t, io, err := common.NewTracer("trade-order", common.ConsulIp+":6831")
if err != nil {
log.Fatal(err)
}
defer io.Close()
//设置全局的Tracing
opentracing.SetGlobalTracer(t)
//开始监控prometheus 默认暴露9092
common.PrometheusBoot(9092)
repcService := micro.NewService(
micro.RegisterTTL(time.Second*30),
micro.RegisterInterval(time.Second*30),
micro.Name("trade-order"),
micro.Address(":8085"),
micro.Version("v1"),
micro.Registry(consulReist),
//链路追踪
micro.WrapHandler(opentracing2.NewHandlerWrapper(opentracing.GlobalTracer())),
//server 限流
micro.WrapHandler(ratelimiter.NewHandlerWrapper(common.QPS)),
//添加监控
micro.WrapHandler(prometheus.NewHandlerWrapper()),
)
//2.初始化db
db, _ := common.GetMysqlFromConsul(consulConfig)
//3.创建服务实例
tradeService := service.NewTradeOrderService(repository.NewTradeRepository(db))
//4.注册handler
proto.RegisterAddTradeOrderHandler(repcService.Server(), &handler.TradeOrderHandler{tradeService})
//4.注册handler
proto.RegisterUpdateTradeOrderHandler(repcService.Server(), &handler.TradeOrderHandler{tradeService})
//4.注册handler
proto.RegisterFindOrderHandler(repcService.Server(), &handler.TradeOrderHandler{tradeService})
//5.启动服务
if err := repcService.Run(); err != nil {
log.Println("start cart service err :", err)
}
}