2 Star 4 Fork 6

Jason的雷哥/micro-quickstart
关闭

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
middleware.go 2.06 KB
一键复制 编辑 原始数据 按行查看 历史
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
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/jason_elva8325/micro-quickstart.git
git@gitee.com:jason_elva8325/micro-quickstart.git
jason_elva8325
micro-quickstart
micro-quickstart
v0.4.0

搜索帮助