Go-Spring :: Log v0.0.1 发布,基于 Tag 路由的结构化日志库

Go-Spring :: Log 是一个高性能、可扩展的日志处理库,专为 Go 语言设计。它提供了灵活的日志记录功能,支持结构化日志、 上下文字段提取、多级日志配置以及多种输出方式,适用于各种服务端应用场景。

特性

  • 多级日志支持:提供 Trace, Debug, Info, Warn, Error, Panic, Fatal 等日志级别,满足不同场景下的调试和监控需求。

  • 结构化日志:支持以结构化的方式记录日志字段(如 trace_id, span_id),便于日志分析系统解析。

  • 上下文支持:通过 context.Context 提取额外信息(如请求 ID、用户 ID)并自动附加到日志中。

  • 标签系统:使用标签(Tag)机制区分不同模块或业务线的日志。

  • 插件机制
    • Appender:支持多种日志输出方式,包括控制台输出(Console)、文件写入(File)等。

    • Layout:提供文本格式(Text)和 JSON 格式(JSON)两种日志布局方式。

    • Logger:支持同步和异步日志记录器,异步记录器可防止日志写入阻塞主线程。

  • 性能优化:提供缓冲区管理、事件池化(Event Pooling)以减少内存分配开销。

  • 日志刷新:支持从配置文件动态刷新日志设置,方便运行时调整日志行为。

  • 测试完备:所有核心模块均配有单元测试,确保稳定性和可靠性。

安装

go get github.com/go-spring/log

快速开始

以下是一个简单的示例,展示如何使用 Go-Spring :: Log 记录日志:

package main
import (	"context"
	"github.com/go-spring/log")
func main() {	// 设置上下文字段提取函数	log.FieldsFromContext = func(ctx context.Context) []log.Field {		return []log.Field{			log.String("trace_id", "0a882193682db71edd48044db54cae88"),			log.String("span_id", "50ef0724418c0a66"),		}	}
	// 加载配置文件	err := log.RefreshFile("log.xml")	if err != nil {		panic(err)	}
	ctx := context.Background()
	// 记录日志	log.Infof(ctx, log.TagDef, "This is an info message")	log.Errorf(ctx, log.TagBiz, "This is an error message")}

配置说明

Go-Spring :: Log 支持通过 XML 配置文件定义日志行为,例如:​​​​​​​

<?xml version="1.0" encoding="UTF-8"?><Configuration>    <Properties>        <Property name="LayoutBufferSize">100KB</Property>    </Properties>    <Appenders>        <Console name="console">            <JSONLayout bufferSize="${LayoutBufferSize}"/>        </Console>    </Appenders>    <Loggers>        <Root level="warn">            <AppenderRef ref="console"/>        </Root>        <Logger name="logger" level="info" tags="_com_request_*">            <AppenderRef ref="console"/>        </Logger>    </Loggers></Configuration>

插件开发

Go-Spring :: Log 提供了丰富的插件接口,开发者可以轻松实现自定义的 Appender、Layout 和 Logger。

许可证

Go-Spring :: Log 使用 Apache License 2.0 许可证发布。

 

优秀的个人博客,低调大师

微信关注我们

原文链接:https://www.oschina.net/news/355307/go-spring-0-0-1-released

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Eclipse(集成开发环境)

Eclipse(集成开发环境)

Eclipse 是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括Java开发工具(Java Development Kit,JDK)。

Java Development Kit(Java开发工具)

Java Development Kit(Java开发工具)

JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Java系统类库)和JAVA工具。