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
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)
|
|
}
|
|
|
|
}
|