登录
首页 >  Golang >  Go问答

结合 Sentry 和 go.uber.org/zap/zapcore 记录器进行日志记录

来源:stackoverflow

时间:2024-02-17 16:27:19 119浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《结合 Sentry 和 go.uber.org/zap/zapcore 记录器进行日志记录》,这篇文章主要讲到等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

问题内容

我正在使用 go.uber.org/zap/zapcore 登录我的 go 应用。

package logger

import (
    "go.uber.org/zap"
    "go.uber.org/zap/zapcore"
    "log"
)

var l *zap.Logger

func Get() *zap.Logger {
    return l
}

func Init() {
    conf := zap.NewProductionConfig()

    logger, err := conf.Build()
    if err != nil {
        log.Fatal("Init logger failed", err)
    }
    l = logger
}

我也有 sentry 项目并使用 github.com/getsentry/raven-go

我想将 error 及以上级别的日志发送到 sentry。

例如,当使用 logger.info()info 级别进行日志记录时,我想像往常一样记录它们,但如果是 errorfatal 日志,我需要将这些消息发送到 sentry。我怎样才能实现这一目标?

解决方案


答案是你应该使用 zap 包装器来添加钩子,然后你必须使用记录器的功能,称为 withoptions

sentryOptions := zap.WrapCore(func(core zapcore.Core) zapcore.Core {
    return zapcore.RegisterHooks(core, func(entry zapcore.Entry) error {
        // your logic here
    })
})

logger.WithOptions(sentryOptions)

今天关于《结合 Sentry 和 go.uber.org/zap/zapcore 记录器进行日志记录》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>