代码拉取完成,页面将自动刷新
package service
import (
	"context"
	"gitee.com/jason_elva8325/micro-quickstart/common"
	"github.com/go-kit/kit/log"
	"github.com/go-kit/kit/metrics"
)
// Middleware 中间件对象定义,需要实现服务的接口定义,并返回服务对象
type Middleware func(Service) Service
// LoggingMiddleware 日志中间件定义方法
func LoggingMiddleware(logger log.Logger) Middleware {
	return func(next Service) Service {
		return loggingMiddleware{logger, next}
	}
}
type loggingMiddleware struct {
	logger log.Logger // 日志服务对象
	next   Service    // 服务逻辑本身
}
func (mw loggingMiddleware) SayHello(ctx context.Context, lang, target string) (v string, err error) {
	defer func() {
		mw.logger.Log("method", "SayHello", "sessionid", ctx.Value(common.ContextKey).(string), "lang", lang, "target", target, "v", v, "err", err)
	}()
	return mw.next.SayHello(ctx, lang, target)
}
func (mw loggingMiddleware) SayGoodby(ctx context.Context, lang, target string) (v string, err error) {
	defer func() {
		mw.logger.Log("method", "SayGoodby", "sessionid", ctx.Value(common.ContextKey).(string), "lang", lang, "target", target, "v", v, "err", err)
	}()
	return mw.next.SayGoodby(ctx, lang, target)
}
// InstrumentingMiddleware 度量中间件定义方法
func InstrumentingMiddleware(helloInts, goodbyInts metrics.Counter) Middleware {
	return func(next Service) Service {
		return instrumentingMiddleware{
			helloInts:  helloInts,
			goodbyInts: goodbyInts,
			next:       next,
		}
	}
}
type instrumentingMiddleware struct {
	helloInts  metrics.Counter // 记录hello服务调用次数
	goodbyInts metrics.Counter // 记录googby服务调用次数
	next       Service         // 服务逻辑本身
}
func (mw instrumentingMiddleware) SayHello(ctx context.Context, lang, target string) (string, error) {
	v, err := mw.next.SayHello(ctx, lang, target)
	mw.helloInts.Add(1)
	return v, err
}
func (mw instrumentingMiddleware) SayGoodby(ctx context.Context, lang, target string) (string, error) {
	v, err := mw.next.SayGoodby(ctx, lang, target)
	mw.goodbyInts.Add(1)
	return v, err
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。
 马建仓 AI 助手
马建仓 AI 助手