[go-micro实战]14 gin.wrap的使用

日志加入(测试用)

package main

import (
	"context"
	"flag"
	"fmt"
	"gitee.com/Hind3ight/easy-go-micro/go-micro/Server"
	"gitee.com/Hind3ight/easy-go-micro/go-micro/Services"
	"github.com/gin-gonic/gin"
	"github.com/micro/go-micro"
	"github.com/micro/go-micro/client"
	"github.com/micro/go-micro/metadata"
	"github.com/micro/go-micro/registry"
	"github.com/micro/go-micro/web"
	"github.com/micro/go-plugins/registry/consul" // micro版本变迁
	"log"
)

type logWrapper struct {
	client.Client
}

func (this *logWrapper) Call(ctx context.Context, req client.Request, rsp interface{}, opts ...client.CallOption) error {
	md,_ := metadata.FromContext(ctx)
	fmt.Printf("[Log Wrapper] ctx : %v service: %s method: %s\n", md, req.Service(), req.Endpoint())
	return this.Client.Call(ctx, req, rsp)
}

func NewLogWrapper(c client.Client) client.Client {
	return &logWrapper{c}
}

func main() {
	consulReg := consul.NewRegistry(registry.Addrs("192.168.31.246:8500"))
	r := gin.Default()
	httpServer := web.NewService(
		web.Name("httpService"),
		//web.Address(flagParser()),
		web.Address(":8001"),
		web.Handler(r),
		web.Registry(consulReg),
		web.Metadata(map[string]string{"protocol": "http"}), // 为注册的服务添加Metadata,指定请求协议为http
	)
	myService := micro.NewService(micro.Name("prodService.client"), micro.WrapClient(NewLogWrapper))
	prodService := Services.NewProdService("prodService", myService.Client())
	v1Group := r.Group("/v1")
	{
		v1Group.Use(Server.InitMiddleware(prodService))
		v1Group.Handle("POST", "/prods", func(c *gin.Context) {
			Server.GetProdListServer(c)
		})
	}
	err := httpServer.Init()
	if err != nil {
		log.Fatalln("Server Init error: ", err)
	}
	err = httpServer.Run()
	if err != nil {
		log.Fatal("Server Run error: ", err)
	}
}

// simple 自定义命令行解析
func flagParser() string {
	serverAddress := flag.String("server_address", ":8080", "服务端口")
	flag.Parse()
	fmt.Println("端口号:", *serverAddress)
	return *serverAddress
}

测试接口时,终端输出

[Log Wrapper] ctx : map[Micro-From-Service:prodService.client] service: prodService method: ProdService.GetProdList

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值